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

Другие вопросы по тегам