CLCircularRegion didEnterRegion не работает
У меня есть GPX, который имитирует движение к координате. Я не могу заставить CLCircularRegion стрелять даром. Я пытался разместить код везде. Вот что я использую:
var center: CLLocationCoordinate2D = CLLocationCoordinate2DMake(37.33171100, -122.03018400)
var radius: CLLocationDistance = CLLocationDistance(300)
var identifier: String = "Destination"
let region = CLCircularRegion(center: center, radius: radius, identifier: identifier)
manager!.startMonitoringForRegion(region)
Я разместил это везде. Я положил это в:
viewDidLoad
viewWillAppear
viewDidAppear
mapViewDidFinishLoadingMap(mapView: MKMapView!
mapViewDidFinishRenderingMap(mapView: MKMapView!, fullyRendered: Bool)
locationManager(manager: CLLocationManager!, didUpdateLocations locations: [AnyObject]!)
Вот мой файл GPX:
<?xml version="1.0"?>
<gpx version="1.1" creator="Xcode">
<wpt lat="37.331711" lon="-122.030184">
<name>Apple</name>
</wpt>
<wpt lat="37.422455" lon="-122.084306">
<name>Google</name>
</wpt>
</gpx>
Println
работает в didStartMonitoringRegion
и он печатает информацию о регионе в журналах, но не срабатывает. Ничто, кажется, не работает, и это сводит меня с ума. Вот моя полная программа.
import UIKit
import CoreLocation
import MapKit
class ViewController: UIViewController, CLLocationManagerDelegate, MKMapViewDelegate {
var mapView: MKMapView?
var manager: CLLocationManager?
override func viewDidLoad() {
super.viewDidLoad()
mapView = MKMapView(frame: CGRectMake(0.0, 0.0, view.frame.size.width, view.frame.size.height))
self.mapView!.delegate = self
mapView!.showsUserLocation = true
view.addSubview(mapView!)
}
func locationManager(manager: CLLocationManager!, didEnterRegion region: CLRegion!) {
println("Entered")
}
func locationManager(manager: CLLocationManager!, didStartMonitoringForRegion region: CLRegion!) {
println("Monitoring")
println(region)
}
func mapViewDidFinishLoadingMap(mapView: MKMapView!) {
manager = CLLocationManager()
manager!.delegate = self
manager!.desiredAccuracy = kCLLocationAccuracyBest
manager!.startUpdatingLocation()
var center: CLLocationCoordinate2D = CLLocationCoordinate2DMake(37.33171100, -122.03018400)
var radius: CLLocationDistance = CLLocationDistance(300)
var identifier: String = "Destination"
let region = CLCircularRegion(center: center, radius: radius, identifier: identifier)
manager!.startMonitoringForRegion(region)
}
}
1 ответ
Решение
Ты, должно быть, шутишь. Это потому что я использовал NSLocationWhenInUseUsageDescription
вместо NSLocationAlwaysUsageDescription
в info.plist