猫猫学iOS 之CoreLocation基本使用
2015-08-22 08:09
645 查看
猫猫分享,必须精品
原创文章,欢迎转载。转载请注明:翟乃玉的博客
地址:http://blog.csdn.net/u013357243
首先导入头文件
1.创建CoreLocation管理者
2.成为CoreLocation管理者的代理监听获取到的位置
3.开始监听(开始获取位置)
4.给类增加代理
5.实现代理方法
和
6.对当前iOS版本进行判断,分别进行授权处理
CLLocationManager 定位管理者
CLLocation 代表位置(经度/纬度/高度/速度/路线等)
CLHeading 代表移动方向
CLRegion 代表一个区域
CLCircularRegion 圆形区域
CLBeaconRegion 蓝牙信号区域
返回定位服务是否可用
[CLLocationManager locationServicesEnabled];
返回延迟定位更新是否可用
[CLLocationManager deferredLocationUpdatesAvailable];
返回重大位置改变监听是否可用
[CLLocationManager significantLocationChangeMonitoringAvailable];
返回是否支持磁力计算方向
[CLLocationManager headingAvailable];
返回蓝牙信号范围服务是否可用
[CLLocationManager isRangingAvailable];
设置是否可以暂停定位来节省电池电量, YES不需要定位数据时自动暂停定位
// mgr.pausesLocationUpdatesAutomatically
每隔多少米定位一次, 只有水平方向超过该值时才会重新定位
// mgr.distanceFilter = 100;
定位精确度
// mgr.desiredAccuracy;
kCLDistanceFilterNone;
kCLLocationAccuracyBestForNavigation 导航级最佳精准
kCLLocationAccuracyBest; 最佳精准
kCLLocationAccuracyNearestTenMeters; 10米误差
kCLLocationAccuracyHundredMeters; 百米胡茬
kCLLocationAccuracyKilometer; 千米误差
kCLLocationAccuracyThreeKilometers; 3千米误差
定位数据的用途
// mgr.activityType;
CLActivityTypeOther 作为普通用途
CLActivityTypeAutomotiveNavigation 作为车辆导航
CLActivityTypeFitness 作为不行
CLActivityTypeOtherNavigation 作为其它导航
// CLLocation
location.coordinate; 坐标, 包含经纬度
location.altitude; 设备海拔高度 单位是米
location.course; 设置前进方向 0表示北 90东 180南 270西
location.horizontalAccuracy; 水平精准度
location.verticalAccuracy; 垂直精准度
location.timestamp; 定位信息返回的时间
location.speed; 设备移动速度 单位是米/秒, 适用于行车速度而不太适用于不行
可以设置模拟器模拟速度
bicycle ride 骑车移动
run 跑动
freeway drive 高速公路驾车
CLAuthorizationStatus
用户从未选择过权限
kCLAuthorizationStatusNotDetermined
无法使用定位服务,该状态用户无法改变
kCLAuthorizationStatusRestricted
用户拒绝该应用使用定位服务,或是定位服务总开关处于关闭状态
kCLAuthorizationStatusDenied
已经授权(废弃)
kCLAuthorizationStatusAuthorized
用户允许该程序无论何时都可以使用地理信息
kCLAuthorizationStatusAuthorizedAlways
用户同意程序在可见时使用地理位置
kCLAuthorizationStatusAuthorizedWhenInUse
计算两个位置之间的距离, 单位是米
[newLocation distanceFromLocation:self.prevLocation];
获取方向信息不会提示用户(不需要授权), 因为不会泄露隐私
[self.mgr startUpdatingHeading];
magneticHeading 设备与磁北的相对角度
trueHeading 设置与真北的相对角度, 必须和定位一起使用, iOS需要设置的位置来计算真北
真北始终指向地理北极点
磁北对应随着时间变化的地球磁场北极
牛逼的地方
116.958776,36.721199
解决方法:
1.确定模拟器(手机)已经联网并且允许程序获取地理位置
2.重置地理位置服务或者网络服务
PS:如果是模拟器就果断直接重置模拟器吧 IOS Simulator - Reset Content and Settings..。
原创文章,欢迎转载。转载请注明:翟乃玉的博客
地址:http://blog.csdn.net/u013357243
一:CoreLocation的基本使用
使用步骤:首先导入头文件
#import <CoreLocation/CoreLocation.h>
1.创建CoreLocation管理者
2.成为CoreLocation管理者的代理监听获取到的位置
3.开始监听(开始获取位置)
4.给类增加代理
5.实现代理方法
- (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations
和
- (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status
6.对当前iOS版本进行判断,分别进行授权处理
二:代码实现
在控制台简单打印出位置以及各种调试,由于这个没啥可看的,直接贴代码了,哪里用到直接复制哪里#import "ViewController.h" #import <CoreLocation/CoreLocation.h> @interface ViewController ()<CLLocationManagerDelegate> /** * 定位管理者 */ @property (nonatomic ,strong) CLLocationManager *mgr; @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; // 1.创建CoreLocation管理者 // CLLocationManager *mgr = [[CLLocationManager alloc] init]; // 2.成为CoreLocation管理者的代理监听获取到的位置 self.mgr.delegate = self; // 判断是否是iOS8 if([[UIDevice currentDevice].systemVersion doubleValue] >= 8.0) { NSLog(@"是iOS8"); // 主动要求用户对我们的程序授权, 授权状态改变就会通知代理 [self.mgr requestAlwaysAuthorization]; // 请求前台和后台定位权限 }else { NSLog(@"是iOS7"); // 3.开始监听(开始获取位置) [self.mgr startUpdatingLocation]; } } /** * 授权状态发生改变时调用 * * @param manager 触发事件的对象 * @param status 当前授权的状态 */ - (void)locationManager:(CLLocationManager *)manager didChangeAuthorizationStatus:(CLAuthorizationStatus)status { if (status == kCLAuthorizationStatusNotDetermined) { NSLog(@"等待用户授权"); }else if (status == kCLAuthorizationStatusAuthorizedAlways || status == kCLAuthorizationStatusAuthorizedWhenInUse) { NSLog(@"授权成功"); // 开始定位 [self.mgr startUpdatingLocation]; }else { NSLog(@"授权失败"); } } #pragma mark - CLLocationManagerDelegate /** * 获取到位置信息之后就会调用(调用频率非常高) * * @param manager 触发事件的对象 * @param locations 获取到的位置 */ - (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations { // CLLocation; timestamp 当前获取到为止信息的时间 /* 获取走了多远(这一次的位置 减去上一次的位置) 获取走这段路花了多少时间 (这一次的时间 减去上一次的时间) 获取速度 (走了多远 / 花了多少时间) 获取总共走的路程 (把每次获取到走了多远累加起来) 获取平均速度 (用总路程 / 总时间) */ // 获取当前的位置 CLLocation *newLocation = [locations lastObject]; if (self.previousLocation != nil) { // 计算两次的距离(单位时米) CLLocationDistance distance = [newLocation distanceFromLocation:self.previousLocation]; // 计算两次之间的时间(单位只秒) NSTimeInterval dTime = [newLocation.timestamp timeIntervalSinceDate:self.previousLocation.timestamp]; // 计算速度(米/秒) CGFloat speed = distance / dTime; // 累加时间 self.sumTime += dTime; // 累加距离 self.sumDistance += distance; // 计算平均速度 CGFloat avgSpeed = self.sumDistance / self.sumTime; NSLog(@"距离%f 时间%f 速度%f 平均速度%f 总路程 %f 总时间 %f", distance, dTime, speed, avgSpeed, self.sumDistance, self.sumTime); } // 纪录上一次的位置 self.previousLocation = newLocation; } #pragma mark - 懒加载 - (CLLocationManager *)mgr { if (!_mgr) { _mgr = [[CLLocationManager alloc] init]; } return _mgr; } @end
三:CoreLocation基本知识扩充
百度地图坐标拾取系统: http://api.map.baidu.com/lbsapi/getpoint/index.htmlCLLocationManager 定位管理者
CLLocation 代表位置(经度/纬度/高度/速度/路线等)
CLHeading 代表移动方向
CLRegion 代表一个区域
CLCircularRegion 圆形区域
CLBeaconRegion 蓝牙信号区域
返回定位服务是否可用
[CLLocationManager locationServicesEnabled];
返回延迟定位更新是否可用
[CLLocationManager deferredLocationUpdatesAvailable];
返回重大位置改变监听是否可用
[CLLocationManager significantLocationChangeMonitoringAvailable];
返回是否支持磁力计算方向
[CLLocationManager headingAvailable];
返回蓝牙信号范围服务是否可用
[CLLocationManager isRangingAvailable];
设置是否可以暂停定位来节省电池电量, YES不需要定位数据时自动暂停定位
// mgr.pausesLocationUpdatesAutomatically
每隔多少米定位一次, 只有水平方向超过该值时才会重新定位
// mgr.distanceFilter = 100;
定位精确度
// mgr.desiredAccuracy;
kCLDistanceFilterNone;
kCLLocationAccuracyBestForNavigation 导航级最佳精准
kCLLocationAccuracyBest; 最佳精准
kCLLocationAccuracyNearestTenMeters; 10米误差
kCLLocationAccuracyHundredMeters; 百米胡茬
kCLLocationAccuracyKilometer; 千米误差
kCLLocationAccuracyThreeKilometers; 3千米误差
定位数据的用途
// mgr.activityType;
CLActivityTypeOther 作为普通用途
CLActivityTypeAutomotiveNavigation 作为车辆导航
CLActivityTypeFitness 作为不行
CLActivityTypeOtherNavigation 作为其它导航
// CLLocation
location.coordinate; 坐标, 包含经纬度
location.altitude; 设备海拔高度 单位是米
location.course; 设置前进方向 0表示北 90东 180南 270西
location.horizontalAccuracy; 水平精准度
location.verticalAccuracy; 垂直精准度
location.timestamp; 定位信息返回的时间
location.speed; 设备移动速度 单位是米/秒, 适用于行车速度而不太适用于不行
可以设置模拟器模拟速度
bicycle ride 骑车移动
run 跑动
freeway drive 高速公路驾车
CLAuthorizationStatus
用户从未选择过权限
kCLAuthorizationStatusNotDetermined
无法使用定位服务,该状态用户无法改变
kCLAuthorizationStatusRestricted
用户拒绝该应用使用定位服务,或是定位服务总开关处于关闭状态
kCLAuthorizationStatusDenied
已经授权(废弃)
kCLAuthorizationStatusAuthorized
用户允许该程序无论何时都可以使用地理信息
kCLAuthorizationStatusAuthorizedAlways
用户同意程序在可见时使用地理位置
kCLAuthorizationStatusAuthorizedWhenInUse
计算两个位置之间的距离, 单位是米
[newLocation distanceFromLocation:self.prevLocation];
获取方向信息不会提示用户(不需要授权), 因为不会泄露隐私
[self.mgr startUpdatingHeading];
magneticHeading 设备与磁北的相对角度
trueHeading 设置与真北的相对角度, 必须和定位一起使用, iOS需要设置的位置来计算真北
真北始终指向地理北极点
磁北对应随着时间变化的地球磁场北极
牛逼的地方
116.958776,36.721199
如果有错误:使用CoreLocation获取地理位置信息,报错
Error Domain=kCLErrorDomain Code=0 “The operation couldn’t be completed. (kCLErrorDomain error 0.)”解决方法:
1.确定模拟器(手机)已经联网并且允许程序获取地理位置
2.重置地理位置服务或者网络服务
PS:如果是模拟器就果断直接重置模拟器吧 IOS Simulator - Reset Content and Settings..。
相关文章推荐
- iOS链式编程框架介绍之LinkBlock(iOS链式编程)
- iOS开发学习概述及知识整理
- iOS各种调试
- 七款Debug工具推荐:iOS开发必备的调试利器
- IOS Storybroad和纯代码界面互联
- [IOS]CoreAnimation基础[翻译6部分]
- iOS 画地图上的标注气泡
- iOS ItunesStore 首页推荐
- ios通讯录差异
- 以phoneGap作为承载容器是ios会上下滑动
- iOS高效编程秘诀—坚持好的编程习惯
- iOS开发所需英语词汇整理
- 苹果官方 Crash文件分析方法 (iOS系统Crash文件分析方法)
- iOS逆向工程-动态分析
- iOS逆向工程-静态分析
- [IOS]CoreAnimation基础[翻译5部分]
- iOS7系统iLEX RAT冬青鼠安装教程:无需刷机还原纯净越狱系统
- iOS(总结)全局调试
- 【待整理】IOS开发之下载
- IOS——TableView 中利用Item模型进行 Cell 的开发(2)Item 模型篇