在iOS开发中,使用定位,必须基于2个框架进行开发
(1)Map Kit :用于地图展示
(2)Core Location :用于地理定位
两个热门专业术语
(1)LBS :Location Based Service(基于定位的服务)百度,(高德是定位与导行比较出色)
(2)SoLoMo :Social Local Mobile(索罗门)基于位置进行社交
CoreLocation框架的使用
1. 使用前提:
1》导入框架:
2》导入主头文件
#import <CoreLocation/CoreLocation.h>
2. CoreLocation框架使用须知
CoreLocation框架中所有数据类型的前缀都是CL
CoreLocation中使用CLLocationManager对象来做用户定位
【初学】
使用方法:
——实现一次定位
// 使用前注意:使用模拟器定位可能会出现bug(无法定位位置),
// 解决方案:切换模拟器,(比如模拟器iphone6切换成iphone7)
1. 创建位置管理器
// @property (nonatomic, strong) CLLocationManager *locationManager self.locationManager = [[CLLocationManager alloc] init];
2. 设置代理--为了获取经纬度
self.locationManager.delegate = self;
3. 请求授权-iOS8以后必须实现
详细——http://www.tuicool.com/articles/VN3632
// 在IOS8以后需要授权 —— 配置plist文件 /* 修改info.plist 新增Key: NSLocationAlwaysUsageDescription 和 NSLocationWhenInUseUsageDescription ,这两个Key的值将分别用于描述应用程序始终使用和使用期间使用定位的说明 这些说明将显示在用户设置中(弹窗授权时的说明)。 */ // 用户使用期间授权 [self.locationManager requestWhenInUseAutorization]; // 总是授权 [self.locationManager requestAlwaysAuthorization];
4. 开始请求定位
// [self.locationManager startUpdatingHeading]; 这个是获取定位方向 // 开始定位 [self.locationManager startUpdatingLocation];
5. 在代理方法中停止更新
// 用户更新位置时候调用, // 不停调用,所以会很耗电,所以使用一次定位后停止就可以 - (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray<CLLocation *> *)locations { NSLog(@"%@", locations); // locations包含的是CLLocation对象 // CLLocationCoordinate2D 2D位置坐标 也就是经纬度 // latitude 纬度 // longitude 经度 CLLocation *location = [locations lastObject]; NSLog(@"纬度 %f", location.coordinate.latitude); NSLog(@"经度 %f", location.coordinate.longitude); // 停止更新位置——实现一次定位 [self.locationManager stopUpdatingLocation]; }
——实现持续定位,比较两点间距离
- (void)viewDidLoad { [super viewDidLoad]; //1. 创建位置管理器 self.locationManager = [[CLLocationManager alloc] init]; //2. 设置代理 self.locationManager.delegate = self; //3. 请求用户授权--iOS8以后才需要授权 --配置plist文件 // 用户使用期间授权 [self.locationManager requestWhenInUseAuthorization];
// —————————————上边都一样————下边实现持续定位,设置经度,并比较两点间直线距离——————————————————— // 总是授权 [self.locationManager requestAlwaysAuthorization]; //4. 距离筛选器 比如: 当前设置10米 实现持续定位 当位置发生多大的改变后调用代理方法 self.locationManager.distanceFilter = 50; //5. 定位精准度 50米 周围50米的范围都会认为是同一地点 2000米 周围2000米的范围都会认为是同一地点 //desired 期望 //Accuracy 精准度 //kCLLocationAccuracyBest 默认 self.locationManager.desiredAccuracy = kCLLocationAccuracyBestForNavigation; //6. 开始定位 [self.locationManager startUpdatingLocation]; //7. 比较两个位置之间的距离 [self compareDistance]; } - (void)compareDistance { //北京到阿拉善左旗位置 CLLocation *location1 = [[CLLocation alloc] initWithLatitude:40.06 longitude:116.39]; CLLocation *location2 = [[CLLocation alloc ] initWithLatitude:38.85 longitude:105.68]; // 比较两点之间的直线距离 CGFloat distance = [location1 distanceFromLocation:location2]; NSLog(@"distance: %f",distance / 1000); }
IOS9新特性
iOS9新特性-只开启前台定位时, 临时开启后台定位功能
在之前的版本如果只开启了用户使用期间定位, 就无法后台定位. iOS9更加灵活的提供了属性, 可以再需要的时候临时开启后台定位.
首先设置allowsBackgroundLocationUpdates属性为YES
然后需要增加plist键值对: Required background modes : App registers for location updates
应用进入后台
//1. 创建位置管理器 self.locationManager = [CLLocationManager new]; //2. 设置代理 self.locationManager.delegate = self; //3. 请求用户授权--iOS8以后才需要授权 --配置plist文件 //1. 如果要适配iOS7, 需要增加判断 //2. 注意方法和键值对的匹配 //3. requestWhenInUseAuthorization 和 requestAlwaysAuthorization 二者实现其一即可, 通常实现requestWhenInUseAuthorization用户使用期间 // 版本判断 系统版本大于8时, 才需要请求授权 if ([UIDevice currentDevice].systemVersion.floatValue >= 8.0) { // 用户使用期间授权 [self.locationManager requestWhenInUseAuthorization]; // MARK: iOS9新增 // 临时开打后台定位功能 还要配置pllist self.locationManager.allowsBackgroundLocationUpdates = YES; // 总是授权 -- 显示其他程序时--程序在后台时可以定位 // [self.locationManager requestAlwaysAuthorization]; } //4. 开始定位 [self.locationManager startUpdatingLocation];
—— 后续预告 反地理编码(根据经纬度查询位置)