您当前的位置: iOS SDK > 开发指南 > 计算工具
计算工具

简介

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

调启百度地图

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

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

如果在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];

空间计算

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

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

坐标转换

百度地图SDK采用的是百度自有的地理坐标系(bdll09),因此开发者在做位置标注的时候,需要将其他类型的坐标转换为百度坐标。相应的接口和转换方式如下:

CLLocationCoordinate2D coor = CLLocationCoordinate2DMake(39.90868, 116.3956);//原始坐标
//转换 google地图、soso地图、aliyun地图、mapabc地图和amap地图所用坐标至百度坐标
NSDictionary* testdic = BMKConvertBaiduCoorFrom(coor,BMK_COORDTYPE_COMMON);
//转换GPS坐标至百度坐标(加密后的坐标)
testdic = BMKConvertBaiduCoorFrom(coor,BMK_COORDTYPE_GPS);
NSLog(@"x=%@,y=%@",[testdic objectForKey:@"x"],[testdic objectForKey:@"y"]);
//解密加密后的坐标字典
CLLocationCoordinate2D baiduCoor = BMKCoorDictionaryDecode(testdic);//转换后的百度坐标

空间关系判断

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

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

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];