iOS 百度地图v2.9.1 API 的详细使用(五)

计算工具

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

你可能感兴趣的:(iOS 百度地图v2.9.1 API 的详细使用(五))