三、模拟器定位
由于定位需要GPS,所以一般情况下,都需要真机进行测试,笔者在教学过程中,经常使用的是一种模拟定位,这种定位需要准备一个gpx 的文件,可以取名 XXX.gpx,里面的内容如下:
creator="GMapToGPX 6.4j - http://www.elsewhere.org/GMapToGPX/"
xmlns="http://www.topografix.com/GPX/1/1"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://www.topografix.com/GPX/1/1 http://www.topografix.com/GPX/1/1/gpx.xsd">
安徽商贸职业技术学院name>
中国安徽省芜湖市弋江区文昌西路24号 邮政编码: 241002cmt>
中国安徽省芜湖市弋江区文昌西路24号 邮政编码: 241002desc>
wpt>gpx>
将自己的定位信息填写进xml对应的位置即可,然后选择Edit Scheme,在Options中选择自己的gpx 的文件,这样模拟器运行的时候就会读取该文件的位置信息。
Edit Scheme
四、后台定位
如果你的App需要后台定位,可以这样做,首先在Capabilities中打开后台模式
后台模式
前面说过定位权限分两种,针对这两种情况,后台定位的代码不一样,效果也不一样
使用时才定位权限需要加上locationManager.allowsBackgroundLocationUpdates = true
开启后台定位,而一直可以定位权限不需要写任何额外代码
使用时才定位权限退出后,手机顶部会有蓝条提示,而一直可以定位权限则没有
后台定位蓝条提醒
五、开发步骤与示例代码
导入CoreLocation模块
创建CLLcationManager对象,设置参数和代理,请求定位授权并配置info.plist
调用CLLcationManager对象的startUpdatingLocation方法进行定位
实现代理方法,在定位成功的方法中进行位置信息的处理
importUIKit
importCoreLocation
class ViewController: UIViewController {
//定位需要一个CLLocationManager
lazy varlocationManager:CLLocationManager = CLLocationManager()
override funcviewDidLoad(){
super.viewDidLoad()
setupManager()
}
funcsetupManager(){
//默认情况是这样的,每当位置改变时LocationManager就调用一次代理。通过设置distanceFilter可以实现当位置改变超出一定范围时LocationManager才调用相应的代理方法。这样可以达到省电的目的。
locationManager.distanceFilter = 300
//精度 比如为10 就会尽量达到10米以内的精度
locationManager.desiredAccuracy = kCLLocationAccuracyBest
//代理
locationManager.delegate = self
//第一种:能后台定位但是会在顶部出现大蓝条(打开后台定位的开关)
//允许后台定位
locationManager.allowsBackgroundLocationUpdates = true
locationManager.requestWhenInUseAuthorization()
//第二种:能后台定位并且不会出现大蓝条
//locationManager.requestAlwaysAuthorization()
}
override functouchesBegan(_ touches: Set, with event: UIEvent?){
//发起位置更新(定位)会一直轮询,耗电
self.locationManager.startUpdatingLocation()
}
}
extension ViewController : CLLocationManagerDelegate{
//定位成功
funclocationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]){
let location = locations.last
//地理编码的类
let gecoder = CLGeocoder()
iflet location = location {
//反地理编码 转换成 具体的地址
gecoder.reverseGeocodeLocation(location) { (placeMarks, error) in
//CLPlacemark -- 国家 城市 街道
let placeMark = placeMarks?.first
iflet placeMark = placeMark{
print( "(placeMark.country!) -- (placeMark.name!) -- (placeMark.locality!)")
}
}
}
self.locationManager.stopUpdatingLocation()
}
//定位失败
funclocationManager(_ manager: CLLocationManager, didFailWithError error: Error){
print(error)
}
}
六、代码运行效果运行效果
运行效果
长
按
关