关于ios8以后CLLocationManager不定位不执行协议方法。zu
2015-10-04 19:34
489 查看
_instance.locationManager = [[CLLocationManager alloc] init];//创建位置管理器 _instance.locationManager.delegate=_instance; _instance.locationManager.desiredAccuracy=kCLLocationAccuracyBest; _instance.locationManager.distanceFilter=100.0f; _instance.updating=NO; //定位服务是否可用 BOOL enable=[CLLocationManager locationServicesEnabled]; if ([[[UIDevicecurrentDevice]systemVersion]doubleValue] > 8.0) { //是否具有定位权限 int status=[CLLocationManager authorizationStatus]; if(!enable || status<3){ //请求权限 [_instance.locationManager requestWhenInUseAuthorization]; //_instance.locationManager requestAlwaysAuthorization];// 前后台同时定位 } }
应该在[locationManager startUpdatingLocation];这一句上面加上判断。
if ([[[UIDevicecurrentDevice]systemVersion]doubleValue]
>8.0)
{
[locationManager requestWhenInUseAuthorization];//前台定位
// [locationManager requestAlwaysAuthorization];//
前后台同时定位
}
加上以后打开info.plist。
在最后一行添加NSLocationWhenInUseUsageDescription或者NSLocationAlwaysUsageDescription(根据上面写得前台定位还是前后台定位),键值对可以为空。
如图:
注意IOS9以后定位跟contacts一样都需要判断是否进行隐私授权的,方法跟contacts一样,借鉴contacts一篇。定位也有方法authorizationStatus
相关文章推荐
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 峰回路转,Firefox 浏览器即将重返 iOS 平台
- 不可修补的 iOS 漏洞可能导致 iPhone 4s 到 iPhone X 永久越狱
- iOS 12.4 系统遭黑客破解,漏洞危及数百万用户
- 每日安全资讯:NSO,一家专业入侵 iPhone 的神秘公司
- [转][源代码]Comex公布JailbreakMe 3.0源代码
- js判断客户端是iOS还是Android等移动终端的方法
- IOS开发环境windows化攻略
- .net平台推送ios消息的实现方法
- 探讨Android与iOS,我们将何去何从?
- Android、iOS和Windows Phone中的推送技术详解
- IOS 改变键盘颜色代码
- 举例详解iOS开发过程中的沙盒机制与文件
- Android和IOS的浏览器中检测是否安装某个客户端的方法
- javascript实现阻止iOS APP中的链接打开Safari浏览器
- IOS开发第三方语音-微信语音
- iOS开发之路--微博OAuth授权_取得用户授权的accessToken
- 基于UIControl控件实现ios点赞功能
- iOS开发中实现邮件和短信发送的简单示例