计算工具
1.简介
百度地图SDK目前提供的工具有:调启百度地图、空间计算、坐标转换、空间关系判断、收藏夹功能等。帮助开发者实现丰富的LBS功能。
2.调启百度地图
百度地图SDK为开发者提供了简单的接口调用,即可打开百度地图客户端,实现复杂的业务逻辑。目前所支持的调启类型有:POI周边检索、POI详情检索、步行线路规划、驾车线路规划、公交线路规划、导航。
如果在iOS9中使用了调起百度地图客户端功能,必须在"Info.plist"中进行如下配置,否则不能调起百度地图客户端。
如下以公交线路规划调启百度地图为例,向大家介绍具体使用方法。
当手机中安装了百度地图App并且App版本号是8.2.0及以上,可直接调起地图App,当没有安装或版本号不符合要求,则默认调起百度地图WebApp展示,开发者可通过SDK中对应的接口来设置是否支持调起WebApp。
BMKOpenTransitRouteOption *opt = [[BMKOpenTransitRouteOption alloc]init];
opt.appScheme = @"baidumapsdk://mapsdk.baidu.com";
//用于调起成功后,返回原应用
//初始化起点节点
BMKPlanNode *start = [[BMKPlanNode alloc]init];
//指定起点经纬度
CLLocationCoordinate2D coor1;
coor1.latitude = 39.90868;
coor1.longitude = 116.204;
//指定起点名称
start.name = @"西直门";
start.pt = coor1;
//指定起点
opt.startPoint = start;
//初始化终点节点
BMKPlanNode *end = [[BMKPlanNode alloc]init];
CLLocationCoordinate2D coor2;
coor2.latitude = 39.90868;
coor2.longitude = 116.3956;
end.pt = coor2;
//指定终点名称
end.name = @"天安门";
opt.endPoint=end;
//打开地图公交路线检索
BMKOpenErrorCode code = [BMKOpenRoute openBaiduMapTransitRoute:opt];
3.空间计算
根据用户指定的两个坐标点,计算这两个点的实际地理距离。核心代码如下:
BMKMapPoint point1 = BMKMapPointForCoordinate(CLLocationCoordinate2DMake(39.915,116.404));
BMKMapPoint point2 = BMKMapPointForCoordinate(CLLocationCoordinate2DMake(38.915,115.404));
CLLocationDistance distance = BMKMetersBetweenMapPoints(point1,point2);
4.坐标转换
百度地图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);
//转换后的百度坐标
5.空间关系判断
提供相应的接口能力,判断点与圆或多边形的位置关系。
判断点与圆位置关系的示例代码如下:
BOOL ptInCircle = BMKCircleContainsCoordinate(CLLocationCoordinate2DMake(39.918,116.408),CLLocationCoordinate2DMake(39.915,116.404),1000);
除以上位置关系判断方法外,SDK还提供获取折线上与折线外指定位置最近点的方法。核心代码如下:
BMKMapPoint *polylinePoints = newBMKMapPoint[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);
6.收藏夹功能
iOS地图SDK自v2.8.0版本起,向开发者开放了本地收藏夹功能,帮助开发者更好的收藏、管理本地空间点信息数据。
具体使用方法如下:
1、 初始化收藏夹管理类:
BMKFavPoiManager *_favManager = [[BMKFavPoiManager alloc]init];
//初始化收藏夹管理类
2、 添加一个收藏点,核心代码如下:
//构造收藏点信息
BMKFavPoiInfo *poiInfo = [[BMKFavPoiInfo alloc]init];
poiInfo.pt = CLLocationCoordinate2DMake(39.908,116.204);
//收藏点坐标
poiInfo.poiName = @"收藏点名称";
//收藏点名称
//添加收藏点(收藏点功后会得到favId)
NSInteger res = [_favManager addFavPoi:poiInfo];
3、 获取收藏点,核心代码如下:
//获取所有收藏点
NSArray *allFavPois = [_favManager getAllFavPois];
//获取某个收藏点(收藏点成功后会得到favId)
BMKFavPoiInfo *favPoi = [_favManager getFavPoi:favId];
4、 删除收藏的点,核心代码如下:
//删除所有收藏点
BOOL res = [_favManager clearAllFavPois];
//删除某个收藏点(收藏点成功后会得到favId)
BOOL res = [_favManager deleteFavPoi:favId];