扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
ios16.0.2可以设置虚拟定位。流程是:
目前成都创新互联公司已为近1000家的企业提供了网站建设、域名、网页空间、网站托管、服务器托管、企业网站设计、丰泽网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
1、下载最新的iBackupBotforiTunes,安装好之后先不要打开,先打开iTunes连接iPhone并进行备份,完成备份后关闭iTunes,打开iBackupBotforiTunes,单击UsesAppFiles。
1、鼠标右键单击左上角蓝色选中区域,并在弹出菜单中选择Restoretodevice。需要注意的是,我们要先关闭“查找我的iPhone”。打开iPhone自带地图,在任意一个上拉菜单中都将会看到SimulateLocation这个选项,点击即可完成虚拟定位。虚拟定位完成之后,位置是固定死的,它并不会随iPhone的移动而移动。若要恢复真实定位重启手机即可。
(一)关于定位的一些设置
--------------------------------------------------------------------------------------------------------
//初始化定位服务
_locService = [[BMKLocationService alloc] init];
//设置距离过滤器(默认距离是米)
_locService.distanceFilter = 10;
//设置定位精度
_locService.desiredAccuracy = kCLLocationAccuracyBest;
//开启定位服务
[_locService startUserLocationService];
//指定定位:是否允许后台定位更新。默认为NO。只在iOS 9.0之后起作用
if ([[UIDevice currentDevice].systemVersion doubleValue] = 9) {
_locService.allowsBackgroundLocationUpdates = YES;
}
//设置定位的状态
_mapView.userTrackingMode = BMKUserTrackingModeNone;
//显示定位图层
_mapView.showsUserLocation = YES;
//设置定位图层自定义样式
BMKLocationViewDisplayParam *userlocationStyle = [[BMKLocationViewDisplayParam alloc] init];
//精度圈是否显示
userlocationStyle.isRotateAngleValid = YES;
//跟随态旋转角度是否生效
userlocationStyle.isAccuracyCircleShow = NO;
//定位图标
userlocationStyle.locationViewImgName = [UIImage imageNamed:@"图标名称"];
//更新参样式信息
[_mapView updateLocationViewWithParam:userlocationStyle];
--------------------------------------------------------------------------------------------------------
(二)关于当前定位位置
首先,显示当前位置,百度地图提供了三种模式:
typedef enum {
BMKUserTrackingModeNone = 0, /// 普通定位模式
BMKUserTrackingModeFollow, /// 定位跟随模式
BMKUserTrackingModeFollowWithHeading, /// 定位罗盘模式
} BMKUserTrackingMode;
使用下面代码就能设置定位状态:
//设置定位的状态
_mapView.userTrackingMode = BMKUserTrackingModeNone;
普通定位模式没有问题,但是如果设置定位跟随或定位罗盘模式,运行app,你会发现定位点确实是对应的状态,但是当你拖动地图的时候,你就会发现后两种模式,又变回了普通定位模式.
我问了百度地图的工程师,他们说这是当前的策略...
所以我感觉设置跟随模式和罗盘模式没有什么卵用...
关于用户方向更新后的设置
如上面(一)所述,定位点可是设置样式参数,当你自定义了定位图标后,你会发现定位图标确实换为了自己定义的图标,而且当用户方向更新后,定位图标是回发生旋转的,但是当你点击触摸屏幕后,定位图标马上变为初始的情况,并且用户方向更新,定位图标不在发生变化.
对于这种情况,我想了一个办法,就是使用系统的定位,在地图界面添加一个方向的图标,
- (void)viewDidLoad {
//版本号
if ([[UIDevice currentDevice].systemVersion doubleValue] = 8.0) {
//主动请求权限
[self.mgr requestAlwaysAuthorization];
}
if ([[UIDevice currentDevice].systemVersion doubleValue] = 9) {
self.mgr.allowsBackgroundLocationUpdates = YES;
}
//对系统定位进行设置
self.mgr.delegate = self;
[self.mgr startUpdatingLocation];
//开始监听(开始获取位置)
[self.mgr startUpdatingHeading];
}
//pragma mark -用户方向更新后,会调用此函数
- (void)locationManager:(CLLocationManager *)manager didUpdateHeading:(CLHeading *)newHeading {
// 将获取到的角度转为弧度 = (角度 * π) / 180;
CGFloat angle = newHeading.magneticHeading * M_PI / 180;
// 旋转图片
self.compasspointer.transform = CGAffineTransformMakeRotation(-angle);
}
//pragma mark - 懒加载
- (CLLocationManager *)mgr
{
if (!_mgr) {
_mgr = [[CLLocationManager alloc] init];
}
return _mgr;
}(四)关于app切换到后台产生的问题
当app切换到后台再切换回前台,`mapView`可能会产生黑屏的情况,此时只需在
`AppDelegate.m`中的`applicationWillResignActive:(UIApplication
*)application`和`applicationDidBecomeActive:(UIApplication
*)application`添加如下代码:
- (void)applicationWillResignActive:(UIApplication *)application {
//程序将要进入后台
[BMKMapView willBackGround];
}
- (void)applicationDidBecomeActive:(UIApplication *)application {
//程序进入前台
[BMKMapView didForeGround];
}
(五)关于BMKLocationServiceDelegate
设置定位的委托有如下两种方式:
- 方式1:
- (void)viewDidLoad {
[super viewDidLoad];
_mapView.delegate = self;
_locService.delegate = self;
}
-(void)viewWillDisappear:(BOOL)animated {
[super viewWillDisappear:animated];
_locService.delegate = nil;
}
- 方式2
-(void)viewWillDisappear:(BOOL)animated {
[super viewWillDisappear:animated];
_locService.delegate = nil;
}
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
_locService.delegate = self;
}
上面两种方式的区别:
如
果在viewDidLoad里写定位委托的话,加载完mapView后,定位当前位置是可以正常显示,并且可以随着位置的变化,定位点也随之发生变化.如
果切换到后台,然后再切换回mapView界面,定位点还是会变化.但是会产生一个问题,当点击别的tabbar,切换到别的界面后,再切换回
mapView界面,定位点就不再随着位置的变化而发生变化了.
如果采用方式2的话,就会避免这种问题.
1、请求获得应用使用时的定位服务授权,注意使用此方法前在要在info.plist中配置NSLocationWhenInUseUsageDescription
2、 请求获得应用一直使用定位服务授权,注意使用此方法前要在info.plist中配置NSLocationAlwaysUsageDescription
在项目功能中有一个定位CLLocation的需求,遇到了一些知识难点,经过各位大侠的帮助,问题解决,特此分享供大家学习,希望大家共同学习进步。
一、简单说明
1.CLLocationManager
CLLocationManager的常用操作和属性
开始用户定位- (void)startUpdatingLocation;
停止用户定位- (void) stopUpdatingLocation;
说明:当调用了startUpdatingLocation方法后,就开始不断地定位用户的'位置,中途会频繁地调用代理的下面方法
- (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations;
每隔多少米定位一次
@property(assign, nonatomic) CLLocationDistance distanceFilter;
定位精确度(越精确就越耗电)
@property(assign, nonatomic) CLLocationAccuracy desiredAccuracy;
使用定位功能,首先要导入框架,遵守CLLocationManagerDelegate协议,再创建位置管理器CLLocationManager
在iOS8.0后,定位功能需要在info.plist中加入NSLocationWhenInUseUsageDescription和NSLocationAlwaysUsageDescription这两个NSString类型字段,才能够使用定位功能
代码贴出来与大家共勉,各位看官自行研究
{ self.locationManager = [[CLLocationManager alloc] init]; _locationManager.delegate = self; if([CLLocationManager locationServicesEnabled] == NO) { // NSLog(@"没有GPS服务"); } //地理位置精确度 _locationManager.desiredAccuracy=kCLLocationAccuracyNearestTenMeters; //设置距离筛选器,double类型,只要距离变化多少,就调用委托代理 self.locationManager.distanceFilter = kCLDistanceFilterNone; // meters [_locationManager requestWhenInUseAuthorization];// 前台定位 [_locationManager startUpdatingLocation];}- (void)locationManager:(CLLocationManager *)manager didUpdateLocations:(NSArray *)locations{ NSLog(@"longitude = %f", ((CLLocation *)[locations lastObject]).coordinate.longitude); NSLog(@"latitude = %f", ((CLLocation *)[locations lastObject]).coordinate.latitude); CGFloat longTI=((CLLocation *)[locations lastObject]).coordinate.longitude; CGFloat latTI=((CLLocation *)[locations lastObject]).coordinate.latitude; //将经度显示到label上 _longitudeLabel.text = [NSString stringWithFormat:@"%f",longTI]; //将纬度现实到label上 _latitudeLabel.text = [NSString stringWithFormat:@"%f",latTI]; // 获取当前所在的城市名 CLGeocoder *geocoder = [[CLGeocoder alloc] init]; //根据经纬度反向地理编译出地址信息 [geocoder reverseGeocodeLocation:locations.lastObject completionHandler:^(NSArray *array, NSError *error) { if (array.count 0) { CLPlacemark *placemark = [array objectAtIndex:0];// //将获得的所有信息显示到label上// self.location.text = placemark.name; //获取城市 NSString *city = placemark.locality; if (!city) { //四大直辖市的城市信息无法通过locality获得,只能通过获取省份的方法来获得(如果city为空,则可知为直辖市) city = placemark.administrativeArea; } // NSLog(@"city = %@", city); _cityName=city; } else if (error == nil [array count] == 0) { // NSLog(@"No results were returned."); } else if (error != nil) { // NSLog(@"An error occurred = %@", error); } }]; //系统会一直更新数据,直到选择停止更新,因为我们只需要获得一次经纬度即可,所以获取之后就停止更新 [manager stopUpdatingLocation];}
以上是关于我给大家整理的IOS开发之详解定位CLLocation,后续还会持续更新,希望大家能够喜欢。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流