浏览器版本低!无法浏览完整内容,建议升级或更换浏览器。

iOS 地图SDK

百度地图SDK是一套应用程序接口, 通过调用地图SDK接口,开发者可以轻松访问百度地图的服务和数据,构建功能丰富、交互性强的地图类应用程序。

简介

百度地图SDK目前提供的工具有:调启百度地图、空间计算、坐标转换、空间关系判断、收藏夹功能等。帮助开发者实现丰富的LBS功能。

调启百度地图

百度地图SDK提供简单的接口调用,通过调起百度地图客户端,实现复杂的业务逻辑。

目前所支持的调启类型有:POI周边检索、POI详情检索、POI全景、步行线路规划、驾车线路规划、公交线路规划、驾车导航、步行导航、骑行导航(调启步行导航、骑行导航,需百度地图App 8.8以上版本才可以支持)。

自iOS v3.3起,增加调启步行AR导航。

如果在iOS9中使用了调起百度地图客户端功能,必须在"Info.plist"中进行如下配置,否则不能调起百度地图客户端。

    <key>LSApplicationQueriesSchemes</key>
    <array>
        <string>baidumap</string>
    </array>

当手机中安装了百度地图App(版本号为8.6.6及以上版本),可直接调起百度地图客户端;当没有安装或版本号不符合要求,则默认调起百度地图WebApp展示,开发者可以通过BaiduMapRoutePlan中的setSupportWebRoute设置是否支持调起WebApp。

调启百度地图公交线路规划

以公交线路规划调启百度地图为例,介绍具体使用方法:

BMKOpenTransitRouteOption *opt = [[BMKOpenTransitRouteOptionalloc] init];
opt.appScheme = @"baidumapsdk://mapsdk.baidu.com";//用于调起成功后,返回原应用
//初始化起点节点
BMKPlanNode* start = [[BMKPlanNodealloc]init];
//指定起点经纬度
CLLocationCoordinate2D coor1;
coor1.latitude = 39.90868;
coor1.longitude = 116.204;
//指定起点名称
    start.name = @"西直门";
start.pt = coor1;
//指定起点
opt.startPoint = start;
 
//初始化终点节点
BMKPlanNode* end = [[BMKPlanNodealloc]init];
CLLocationCoordinate2D coor2;
coor2.latitude = 39.90868;
coor2.longitude = 116.3956;
end.pt = coor2;
//指定终点名称
    end.name = @"天安门";
opt.endPoint = end;
 
//打开地图公交路线检索
BMKOpenErrorCode code = [BMKOpenRouteopenBaiduMapTransitRoute:opt];

调启百度地图步行AR导航

自iOS v3.3起,增加调启步行AR导航。当手机中安装了百度地图App(版本号为9.7.5及以上版本),可直接调起百度地图App步行AR导航功能;低于此版本,则直接调启普通步行导航,但是用户可以手动切换为步行AR导航功能;注:客户端版本低于8.6.9,不支持步行导航。

调启客户端步行AR导航的代码如下:

     //初始化调启导航时的参数管理类
    BMKNaviPara* para = [[BMKNaviPara alloc]init];
 
 
    //初始化终点节点
    BMKPlanNode* end = [[BMKPlanNode alloc]init];
 
 
    //指定终点经纬度
    end.pt = CLLocationCoordinate2DMake(39.90868, 116.3956);
    //指定终点名称
    end.name = @"天安门”;
 
 
    //指定终点
    para.endPoint = end;
    //指定返回自定义scheme
    para.appScheme = @"baidumapsdk://mapsdk.baidu.com";
 
    //调启百度地图客户端
    BMKOpenErrorCode code = [BMKNavigation openBaiduMapwalkARNavigation:para];
    NSLog(@"调起步行导航:errorcode=%d", code);

空间计算

根据用户指定的两个坐标点,计算这两个点的实际地理距离。核心代码如下:

BMKMapPoint point1 = BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.915,116.404));  
BMKMapPoint point2 = BMKMapPointForCoordinate(CLLocationCoordinate2DMake(38.915,115.404));  
CLLocationDistance distance = BMKMetersBetweenMapPoints(point1,point2);

空间关系判断

提供相应的接口能力,判断点与圆或多边形的位置关系。

判断点与圆位置关系的示例代码如下:

BOOL ptInCircle = BMKCircleContainsCoordinate(CLLocationCoordinate2DMake(39.918,116.408), CLLocationCoordinate2DMake(39.915,116.404), 1000);

除以上位置关系判断方法外,SDK还提供获取折线上与折线外指定位置最近点的方法。核心代码如下:

BMKMapPoint *polylinePoints = new BMKMapPoint[4];
polylinePoints[0]= BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.915,116.404));
polylinePoints[1]= BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.915,116.454));;
polylinePoints[2]= BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.975,116.524));;
polylinePoints[3]= BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.855,116.554));
BMKMapPoint point = BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.815,116.504));
BMKMapPoint nearestPoint = BMKGetNearestMapPointFromPolyline(point, polylinePoints, 4);

收藏夹功能

iOS地图SDK自v2.8.0版本起,向开发者开放了本地收藏夹功能,帮助开发者更好的收藏、管理本地空间点信息数据。

具体使用方法如下:

1、 初始化收藏夹管理类:

BMKFavPoiManager *_favManager = [[BMKFavPoiManageralloc] init];//初始化收藏夹管理类

2、 添加一个收藏点,核心代码如下:

//构造收藏点信息
BMKFavPoiInfo *poiInfo = [[BMKFavPoiInfoalloc] init];
    poiInfo.pt = CLLocationCoordinate2DMake(39.908, 116.204);//收藏点坐标
poiInfo.poiName = @"收藏点名称";//收藏点名称
//添加收藏点(收藏点功后会得到favId)
NSInteger res = [_favManageraddFavPoi:poiInfo];

3、 获取收藏点,核心代码如下:

//获取所有收藏点
NSArray *allFavPois = [_favManagergetAllFavPois];
//获取某个收藏点(收藏点成功后会得到favId)
BMKFavPoiInfo *favPoi = [_favManagergetFavPoi:favId];

4、 删除收藏的点,核心代码如下:

//删除所有收藏点
BOOL res = [_favManagerclearAllFavPois];
//删除某个收藏点(收藏点成功后会得到favId)
BOOL res = [_favManagerdeleteFavPoi:favId];