一、定位功能权限
首先使用定位功能需要导入框架#import <CoreLocation/CoreLocation.h>
,并且在info.plist中需要配置响应字段,其中根据配置不同数量字段具有不同请求授权弹框展示效果。
1.只配置
NSLocationWhenInUseUsageDescription
字段,并且使用CLLocationManager对象
的requestWhenInUseAuthorization
方法调起授权请求,表示只在使用应用期间使用位置,请求授权弹框样式为:
2.需要配置两个字段
NSLocationAlwaysAndWhenInUseUsageDescription
及NSLocationWhenInUseUsageDescription
并使用CLLocationManager对象
的requestAlwaysAuthorization
方法调起授权请求,明确具体的授权方式,请求弹框样式为:
<<<下面展示具体判断权限的逻辑>>>
首先需要明确的是判断应用当前定位功能的授权状态以及用户在设置中的定位功能是否开启(如果没有开启一切白说)。定位功能是否开启可以使用CLLocationManager
类的类方法locationServicesEnabled
来获取,当返回值为YES时表示开启。定位授权状态可以用CLLocationManager
类的类方法authorizationStatus
来获得,返回值是一个CLAuthorizationStatus
枚举
// 定位服务授权是用户没有决定是否使用定位服务
kCLAuthorizationStatusNotDetermined = 0,
// 定位服务是受限制的这个状态可能不是用户拒绝的定位服务
kCLAuthorizationStatusRestricted,
// 定位服务授权已被用户明确禁止或在设置中将定位服务关闭
kCLAuthorizationStatusDenied,
// 定位服务授权允许在任何状态下获取位置信息
kCLAuthorizationStatusAuthorizedAlways,
// 定位服务授权状态仅被允许在使用应用程序的时候
kCLAuthorizationStatusAuthorizedWhenInUse,
// 已废弃相当于kCLAuthorizationStatusAuthorizedAlways
kCLAuthorizationStatusAuthorized,
(为什么不是左对齐好诡异)
在获得的授权状态取值为kCLAuthorizationStatusNotDetermined
时表示还未获得用户授权,此时如果想要实现定位授权弹框在使用的时候才弹出这个效果,可以把上面的调用授权放到这里。如果想要监听用户点击弹框授权的状态需要实现一下CLLocationManagerDelegate
协议中的locationManager:didChangeAuthorizationStatus:
方法,该方法的作用是定位授权状态发生变化时就会回调最新的授权状态(仅在App处于前台活跃状态时才会调起,其中飞行模式未知),如需对变化的状态做各种反应只需判断枚举类型即可。
注:CLLocationManager的对象最好长期持有防止请求授权方法执行时超出作用域后对象被销毁导致授权弹框一闪而逝。