作者:jiajiajy323 | 来源:互联网 | 2023-05-19 00:50
在iOS开发中,使用定位,必须基于2个框架进行开发(1)MapKit:用于地图展示(2)CoreLocation:用于地理定位两个热门专业术语(1)LBS:LocationBase
在iOS开发中,使用定位,必须基于2个框架进行开发
(1)Map Kit :用于地图展示
(2)Core Location :用于地理定位
两个热门专业术语
(1)LBS :Location Based Service(基于定位的服务)百度,(高德是定位与导行比较出色)
(2)SoLoMo :Social Local Mobile(索罗门)基于位置进行社交
CoreLocation框架的使用
1. 使用前提:
1》导入框架:
2》导入主头文件
#import
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 *)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];
—— 后续预告 反地理编码(根据经纬度查询位置)