在iOS中通过Core Location框架进行定位操作。Core Location自身可以单独使用,和地图开发框架MapKit完全是独立的,但是往往地图开发要配合定位框架使用。在Core Location中主要包含了定位、地理编码(包括反编码)功能,实现的方式一般是通过location定位,然后显示在maokit上。



如一些地图软件打开之后如果用户允许软件定位的话,那么打开软件后就会自动锁定到当前位置,如果用户手机移动那么当前位置也会跟随着变化。要实现这个功能需要使用Core Loaction中CLLocationManager类。

类方法

说明

+ (BOOL)locationServicesEnabled;

是否启用定位服务,通常如果用户没有启用定位服务可以提示用户打开定位服务

+ (CLAuthorizationStatus)authorizationStatus;

定位服务授权状态,返回枚举类型:

kCLAuthorizationStatusNotDetermined: 用户尚未做出决定是否启用定位服务

kCLAuthorizationStatusRestricted: 没有获得用户授权使用定位服务,可能用户没有自己禁止访问授权

kCLAuthorizationStatusDenied :用户已经明确禁止应用使用定位服务或者当前系统定位服务处于关闭状态

kCLAuthorizationStatusAuthorizedAlways: 应用获得授权可以一直使用定位服务,即使应用不在使用状态

kCLAuthorizationStatusAuthorizedWhenInUse: 使用此应用过程中允许访问定位服务

属性

说明

desiredAccuracy

定位精度,枚举类型:

kCLLocationAccuracyBest:最精确定位
CLLocationAccuracy kCLLocationAccuracyNearestTenMeters:十米误差范围
kCLLocationAccuracyHundredMeters:百米误差范围
kCLLocationAccuracyKilometer:千米误差范围
kCLLocationAccuracyThreeKilometers:三千米误差范围

distanceFilter

位置信息更新最小距离,只有移动大于这个距离才更新位置信息,默认为kCLDistanceFilterNone:不进行距离限制

对象方法

说明

startUpdatingLocation

开始定位追踪,开始定位后将按照用户设置的更新频率执行-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations;方法反馈定位信息

stopUpdatingLocation

停止定位追踪

startUpdatingHeading

开始导航方向追踪

stopUpdatingHeading

停止导航方向追踪

:

开始对某个区域进行定位追踪,开始对某个区域进行定位后。如果用户进入或者走出某个区域会调用- (void)locationManager:(CLLocationManager *)manager
   
- (void)locationManager:(CLLocationManager *)manager
   
代理方法反馈相关信息

stopMonitoringForRegion:

停止对某个区域进行定位追踪

ation

请求获得应用使用时的定位服务授权,注意使用此方法前在要在info.plist中配置NSLocationWhenInUseUsageDescription

on

请求获得应用一直使用定位服务授权,注意使用此方法前要在info.plist中配置NSLocationAlwaysUsageDescription

代理方法

说明

-(void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations;

位置发生改变后执行(第一次定位到某个位置之后也会执行)

- (void)locationManager:(CLLocationManager *)manager

      

导航方向发生变化后执行

- (void)locationManager:(CLLocationManager *)manager

   

进入某个区域之后执行

- (void)locationManager:(CLLocationManager *)manager

   

走出某个区域之后执行