CoreLocation是iOS中一个提供设备定位的框架。通过这个框架可以实现定位处理,从而获取位置数据,比如经度、纬度、海拔信息等。
1、info.plist权限的设置(Value值为空也可以,主要显示在授权提示里)
NSLocationWhenInUseDescription :允许在前台获取GPS的描述
NSLocationAlwaysUsageDescription :允许在后台获取GPS的描述
2、效果展示

image.png
3、示例代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 | import UIKit import CoreLocation class ViewController: UIViewController, CLLocationManagerDelegate { //定位管理器 let locationManager:CLLocationManager = CLLocationManager() @IBOutlet weak var label1: UILabel! @IBOutlet weak var label2: UILabel! @IBOutlet weak var label3: UILabel! @IBOutlet weak var label4: UILabel! @IBOutlet weak var label5: UILabel! @IBOutlet weak var label6: UILabel! @IBOutlet weak var label7: UILabel! override func viewDidLoad() { super.viewDidLoad() view.backgroundColor = .white //设置定位服务管理器代理 locationManager.delegate = self //设置定位进度 locationManager.desiredAccuracy = kCLLocationAccuracyBest //更新距离 locationManager.distanceFilter = 10 ////发送授权申请 locationManager.requestAlwaysAuthorization() if (CLLocationManager.locationServicesEnabled()) { //允许使用定位服务的话,开启定位服务更新 locationManager.startUpdatingLocation() print("定位开始") } } //定位改变执行,可以得到新位置、旧位置 func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { //获取最新的坐标 let currLocation:CLLocation = locations.last! label1.text = "经度:\(currLocation.coordinate.longitude)" //获取纬度 label2.text = "纬度:\(currLocation.coordinate.latitude)" //获取海拔 label3.text = "海拔:\(currLocation.altitude)" //获取水平精度 label4.text = "水平精度:\(currLocation.horizontalAccuracy)" //获取垂直精度 label5.text = "垂直精度:\(currLocation.verticalAccuracy)" //获取方向 label6.text = "方向:\(currLocation.course)" //获取速度 label7.text = "速度:\(currLocation.speed)" } } |
3、定位精度的设置
定位服务管理类CLLocationManager的desiredAccuracy属性表示精准度,有如下6种选择:
kCLLocationAccuracyBestForNavigation :精度最高,一般用于导航
kCLLocationAccuracyBest : 精确度最佳
kCLLocationAccuracyNearestTenMeters :精确度10m以内
kCLLocationAccuracyHundredMeters :精确度100m以内
kCLLocationAccuracyKilometer :精确度1000m以内
kCLLocationAccuracyThreeKilometers :精确度3000m以内
4、位置管理器更新频率的设置
我们无法直接控制位置管理器更新的频率,但可使用位置管理器的distanceFilter属性(单位米)进行间接控制。
它指设备(水平或垂直)移动多少米后才将另一个更新发送给委托。定位要求的精度越高,distanceFilter属性的值越小,应用程序的耗电量就越大。
5、计算两个坐标间的距离
通过CCLocation对象的distanceTo方法,可以得到两个坐标间的距离,单位是米。
1 2 3 4 | var currentLocation = CLLocation(latitude: 53.224523, longitude: 52.114152) var targetLocation = CLLocation(latitude: 53.225523, longitude: 53.141152) var distance:CLLocationDistance = currentLocation.distance(from: targetLocation) print("两点间距离是:\(distance)") |
参考:https://www.hangge.com/blog/cache/detail_783.html