Commit 955c41c1 by Sarkizz

调整定位逻辑

parent 2b5183b3
...@@ -9,6 +9,12 @@ ...@@ -9,6 +9,12 @@
import Foundation import Foundation
import CoreLocation import CoreLocation
func MRLog(_ items: Any...) {
#if DEBUG
print(items)
#endif
}
// MARK: 定位管理器 // MARK: 定位管理器
public class MRLocation: NSObject { public class MRLocation: NSObject {
...@@ -49,6 +55,7 @@ public class MRLocation: NSObject { ...@@ -49,6 +55,7 @@ public class MRLocation: NSObject {
private var _status: LocationStatus = .idle private var _status: LocationStatus = .idle
private var callbacks = [LocationCallback]() private var callbacks = [LocationCallback]()
private var stayCallbacks = [LocationCallback]() private var stayCallbacks = [LocationCallback]()
private var authCallback: ((_ status: CLAuthorizationStatus) -> Void)?
override init() {} override init() {}
...@@ -73,6 +80,17 @@ extension MRLocation { ...@@ -73,6 +80,17 @@ extension MRLocation {
return CLLocationManager.locationServicesEnabled() return CLLocationManager.locationServicesEnabled()
} }
/// 请求获取定位权限
/// - Parameter completion: 回调
public func requestAuthorization(_ completion: ((_ status: CLAuthorizationStatus) -> Void)?) {
authCallback = completion
if Bundle.main.infoDictionary?["NSLocationWhenInUseUsageDescription"] != nil {
systemLocation.requestWhenInUseAuthorization()
} else if Bundle.main.infoDictionary?["NSLocationAlwaysUsageDescription"] != nil {
systemLocation.requestAlwaysAuthorization()
}
}
/// 开始定位 /// 开始定位
/// - Parameter finish: 定位回调 /// - Parameter finish: 定位回调
/// - Parameter stay: 是否常驻,若常驻,则这个回调在每次定位后都会调用 /// - Parameter stay: 是否常驻,若常驻,则这个回调在每次定位后都会调用
...@@ -83,30 +101,42 @@ extension MRLocation { ...@@ -83,30 +101,42 @@ extension MRLocation {
if !isEnable { if !isEnable {
return return
} }
let authorizate = authorization?(CLLocationManager.authorizationStatus())
let isStartLocating = authorizate ?? true let start: (_ status: CLAuthorizationStatus) -> Void = { status in
if isStartLocating { let authorizate = authorization?(status)
/// 存储回调 let isStartLocating = authorizate ?? true
if let finish = finish { if isStartLocating {
let callback = LocationCallback(callback: finish) /// 存储回调
if stay { if let finish = finish {
stayCallbacks.append(callback) let callback = LocationCallback(callback: finish)
} else { if stay {
callbacks.append(callback) self.stayCallbacks.append(callback)
} else {
self.callbacks.append(callback)
}
} }
}
if self._status != .locating || force {
if _status != .locating || force { switch self.locationType {
switch locationType { case .system:
case .system: self.systemLocation.stopUpdatingLocation()
systemLocation.stopUpdatingLocation() self.systemLocation.startUpdatingLocation()
systemLocation.startUpdatingLocation() self._status = .locating
_status = .locating default:
default: break
break }
} }
} }
} }
let current = CLLocationManager.authorizationStatus()
if current == .notDetermined || current == .restricted {
requestAuthorization { (status) in
start(status)
}
} else {
start(current)
}
} }
/// 停止定位 /// 停止定位
...@@ -136,11 +166,7 @@ extension MRLocation { ...@@ -136,11 +166,7 @@ extension MRLocation {
private func setupSystemLocation() { private func setupSystemLocation() {
systemLocation.delegate = self systemLocation.delegate = self
if Bundle.main.infoDictionary?["NSLocationWhenInUseUsageDescription"] != nil { requestAuthorization(nil)
systemLocation.requestWhenInUseAuthorization()
} else if Bundle.main.infoDictionary?["NSLocationAlwaysUsageDescription"] != nil {
systemLocation.requestAlwaysAuthorization()
}
systemLocation.distanceFilter = 5 systemLocation.distanceFilter = 5
systemLocation.desiredAccuracy = 300//300米 systemLocation.desiredAccuracy = 300//300米
} }
...@@ -159,6 +185,7 @@ extension MRLocation { ...@@ -159,6 +185,7 @@ extension MRLocation {
// MARK: CLLocationManagerDelegate // MARK: CLLocationManagerDelegate
extension MRLocation: CLLocationManagerDelegate { extension MRLocation: CLLocationManagerDelegate {
public func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) { public func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) {
MRLog("location manager did fail: \(error)")
invokeCallbacks(with: nil, error: error) invokeCallbacks(with: nil, error: error)
if stayCallbacks.count == 0 { if stayCallbacks.count == 0 {
stopLocation() stopLocation()
...@@ -167,6 +194,7 @@ extension MRLocation: CLLocationManagerDelegate { ...@@ -167,6 +194,7 @@ extension MRLocation: CLLocationManagerDelegate {
} }
public func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { public func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) {
MRLog("location manager did update: \(locations)")
lastLocation = locations.last lastLocation = locations.last
invokeCallbacks(with: locations.last, error: nil) invokeCallbacks(with: locations.last, error: nil)
if stayCallbacks.count == 0 { if stayCallbacks.count == 0 {
...@@ -174,6 +202,11 @@ extension MRLocation: CLLocationManagerDelegate { ...@@ -174,6 +202,11 @@ extension MRLocation: CLLocationManagerDelegate {
_status = .idle _status = .idle
} }
} }
public func locationManager(_ manager: CLLocationManager, didChangeAuthorization status: CLAuthorizationStatus) {
MRLog("location manager authorization did change: \(status.desc)")
authCallback?(status)
}
} }
// MARK: 定位回调 // MARK: 定位回调
...@@ -184,3 +217,23 @@ public final class LocationCallback: NSObject { ...@@ -184,3 +217,23 @@ public final class LocationCallback: NSObject {
self.callback = callback self.callback = callback
} }
} }
// MARK: CLAuthorizationStatus
extension CLAuthorizationStatus {
var desc: String {
switch self {
case .notDetermined:
return "notDetermined"
case .restricted:
return "restricted"
case .denied:
return "denied"
case .authorizedAlways:
return "authorizedAlways"
case .authorizedWhenInUse:
return "authorizedWhenInUse"
@unknown default:
return "unknow"
}
}
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or sign in to comment