Swift - 使用CoreLocation获取设备方向(真实方向,磁极方向)

前端之家收集整理的这篇文章主要介绍了Swift - 使用CoreLocation获取设备方向(真实方向,磁极方向)前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
CoreLocation这个定位框架除了可以获取设备的位置数据,还可以获取设备的方向(可以用来实现指南针功能等)。

1,CLHeading对象通过一组属性提供航向相关数据:@H_301_6@
magneticHeading@H_301_6@:磁极方向(磁北对应于随时间变化的地球磁场极点)
trueHeading@H_301_6@:真实方向(真北始终指向地理北极点)
headingAccuracy@H_301_6@:方向的精度
timestamp@H_301_6@:Core Loaction确定位置时的时间戳
description@H_301_6@: 方向数据

2,方向值的含义@H_301_6@
不管是磁极方向还是真实方向,值的单位是度,类型为CLLocationDirection,即双精度浮点数。
0.0@H_301_6@:前进方向为北
90.0@H_301_6@:前进方向为东
180.0@H_301_6@:前进方向为南
270.0@H_301_6@:前进方向为西

3,下面通过样例进行演示@H_301_6@
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
@H_502_130@ 31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
import UIKit
import CoreLocation
class ViewController : UIViewController , CLLocationManagerDelegate {
//定位管理器
let locationManager: CLLocationManager = ()
@IBOutlet weak var label1: UILabel !
label2: !
label3: UILabel !
label4: !
override func viewDidLoad() {
super .viewDidLoad()
//设置定位服务管理器代理
locationManager.delegate = self
//设置定位进度
locationManager.desiredAccuracy = kCLLocationAccuracyBest
//发送授权申请
locationManager.requestAlwaysAuthorization()
}
//获取设备是否允许使用定位服务
locationManager(manager: !,
didChangeAuthorizationStatus status: CLAuthorizationStatus ) {
if status == . NotDetermined || status == Denied {
} else {
//允许使用定位服务的话,开启定位服务更新
locationManager.startUpdatingHeading()
println ( "方向定位开始" )
//关闭定位
//locationManager.stopUpdatingHeading()
}
}
//方向改变执行
CLHeading !) {
label1.text = "磁极方向:\(newHeading.magneticHeading)"
label2.text = "真实方向:\(newHeading.trueHeading)"
label3.text = "方向的精度:\(newHeading.headingAccuracy)"
label4.text = "时间:\(newHeading.timestamp)"
}
}

原文出自:@H_301_6@ www.hangge.com 转载请保留原文链接:@H_301_6@ http://www.hangge.com/blog/cache/detail_784.html

猜你在找的Swift相关文章