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

iOS 地图SDK

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

定位产品简介

由于系统原因,iOS不允许使用第三方定位,因此地图SDK中的定位方法,本质上是对原生定位的二次封装。通过封装,开发者可更便捷的使用。此外,地图SDK中还提供了相应的定位图层(支持定位三态效果),帮助开发者显示当前位置信息。

百度地图开放平台在系统定位基础之上,为广大开发者全新提供了iOS端独立的定位SDK产品,欢迎广大开发者的使用。

展示定位

自iOS 地图SDK v2.5.0起,为了对iOS8的定位能力做兼容,做了相应的修改,使用注意事项如下:

需要在info.plist里添加(以下二选一,两个都添加默认使用NSLocationWhenInUseUsageDescription):

1) NSLocationWhenInUseUsageDescription ,允许在前台使用时获取GPS的描述

2) NSLocationAlwaysUsageDescription ,允许永久使用GPS的描述。

功能位于“基础地图(Map)”功能模块,开发者使用时请注意选择。

核心代码如下:(完整信息请参考Demo)

//以下_mapView为BMKMapView对象  
_mapView.showsUserLocation = YES;//显示定位图层  
_mapView.userTrackingMode = BMKUserTrackingModeNone;//设置定位的状态为普通定位模式
获取位置信息

连续获取

定位功能可以和地图功能分离使用,单独的定位功能使用方式如下:

-(void)viewDidLoad  
{    
    //初始化BMKLocationService  
    _locService = [[BMKLocationService alloc]init];  
    _locService.delegate = self;  
    //启动LocationService  
    [_locService startUserLocationService];  
}  
//实现相关delegate 处理位置信息更新  
//处理方向变更信息  
- (void)didUpdateUserHeading:(BMKUserLocation *)userLocation  
{  
    //NSLog(@"heading is %@",userLocation.heading);  
}  
//处理位置坐标更新  
- (void)didUpdateBMKUserLocation:(BMKUserLocation *)userLocation  
{  
    //NSLog(@"didUpdateUserLocation lat %f,long %f",userLocation.location.coordinate.latitude,userLocation.location.coordinate.longitude);  
}
定位模式

目前为止,BMKMapView的定位模式(userTrackingMode)有4种分别是:

BMKUserTrackingModeNone:

普通定位模式,显示我的位置,我的位置图标和地图都不会旋转

BMKUserTrackingModeFollow :

定位跟随模式,我的位置始终在地图中心,我的位置图标会旋转,地图不会旋转

BMKUserTrackingModeFollowWithHeading :

定位罗盘模式,我的位置始终在地图中心,我的位置图标和地图都会跟着旋转

BMKUserTrackingModeHeading:

v4.1起支持,普通定位+定位罗盘模式,显示我的位置,我的位置始终在地图中心,我的位置图标会旋转,地图不会旋转。即在普通定位模式的基础上显示方向。

定位精度圈填充颜色和边框

BMKLocationViewDisplayParam 新增属性:

///精度圈填充颜色
@property (nonatomic, strong) UIColor *accuracyCircleFillColor;
///精度圈边框颜色
@property (nonatomic, strong) UIColor *accuracyCircleStrokeColor;