mirror of
https://github.com/meshtastic/Meshtastic-Apple.git
synced 2026-04-20 22:13:56 +00:00
100 lines
3 KiB
Swift
100 lines
3 KiB
Swift
import CoreLocation
|
|
|
|
class LocationHelper: NSObject, ObservableObject {
|
|
|
|
static let shared = LocationHelper()
|
|
|
|
// Apple Park
|
|
static let DefaultLocation = CLLocationCoordinate2D(latitude: 37.3346, longitude: -122.0090)
|
|
|
|
static let DefaultAltitude = CLLocationDistance(integerLiteral: 0)
|
|
static let DefaultSpeed = CLLocationSpeed(integerLiteral: 0)
|
|
static let DefaultHeading = CLLocationDirection(integerLiteral: 0)
|
|
|
|
static var currentLocation: CLLocationCoordinate2D {
|
|
|
|
guard let location = shared.locationManager.location else {
|
|
return DefaultLocation
|
|
}
|
|
return location.coordinate
|
|
}
|
|
|
|
static var currentAltitude: CLLocationDistance {
|
|
|
|
guard let altitude = shared.locationManager.location?.altitude else {
|
|
return DefaultAltitude
|
|
}
|
|
return altitude
|
|
}
|
|
|
|
static var currentSpeed: CLLocationSpeed {
|
|
|
|
guard let speed = shared.locationManager.location?.speed else {
|
|
return DefaultSpeed
|
|
}
|
|
return speed
|
|
}
|
|
|
|
static var currentHeading: CLLocationDirection {
|
|
|
|
guard let speed = shared.locationManager.location?.course else {
|
|
return DefaultHeading
|
|
}
|
|
return speed
|
|
}
|
|
|
|
static var currentTimestamp: Date {
|
|
|
|
guard let timestamp = shared.locationManager.location?.timestamp else {
|
|
return Date.now
|
|
}
|
|
return timestamp
|
|
}
|
|
|
|
static var satsInView: Int {
|
|
// If we have a position we have a sat
|
|
var sats = 1
|
|
if shared.locationManager.location?.verticalAccuracy ?? 0 > 0 {
|
|
sats = 4
|
|
if 0...5 ~= shared.locationManager.location?.horizontalAccuracy ?? 0{
|
|
sats = 12
|
|
} else if 6...15 ~= shared.locationManager.location?.horizontalAccuracy ?? 0{
|
|
sats = 10
|
|
} else if 16...30 ~= shared.locationManager.location?.horizontalAccuracy ?? 0{
|
|
sats = 9
|
|
} else if 31...45 ~= shared.locationManager.location?.horizontalAccuracy ?? 0{
|
|
sats = 7
|
|
} else if 46...60 ~= shared.locationManager.location?.horizontalAccuracy ?? 0{
|
|
sats = 5
|
|
}
|
|
} else if shared.locationManager.location?.verticalAccuracy ?? 0 < 0 && 60...300 ~= shared.locationManager.location?.horizontalAccuracy ?? 0 {
|
|
sats = 3
|
|
} else if shared.locationManager.location?.verticalAccuracy ?? 0 < 0 && shared.locationManager.location?.horizontalAccuracy ?? 0 > 300 {
|
|
sats = 2
|
|
}
|
|
return sats
|
|
}
|
|
|
|
private let locationManager = CLLocationManager()
|
|
|
|
private override init() {
|
|
|
|
super.init()
|
|
locationManager.delegate = self
|
|
locationManager.desiredAccuracy = kCLLocationAccuracyBest
|
|
locationManager.requestWhenInUseAuthorization()
|
|
locationManager.startUpdatingLocation()
|
|
}
|
|
}
|
|
|
|
extension LocationHelper: CLLocationManagerDelegate {
|
|
func locationManager(_ manager: CLLocationManager, didUpdateLocations locations: [CLLocation]) { }
|
|
|
|
public func locationManager(_ manager: CLLocationManager, didFailWithError error: Error) {
|
|
print("Location manager failed with error: \(error.localizedDescription)")
|
|
}
|
|
|
|
public func locationManager(_ manager: CLLocationManager, didChangeAuthorization status: CLAuthorizationStatus) {
|
|
print("Location manager changed the status: \(status)")
|
|
}
|
|
}
|