ios定位权限plist_iOS开发之定位

本文介绍了如何在iOS开发中进行模拟器定位,包括创建gpx文件并编辑定位信息,以及设置Edit Scheme来使用模拟定位。同时,详细讲解了后台定位的开启方法,区分了使用时才定位和一直可以定位两种权限的区别,并提供了相应的代码示例。最后展示了代码运行效果。
摘要由CSDN通过智能技术生成

三、模拟器定位

由于定位需要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)

}

}

六、代码运行效果运行效果

运行效果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值