CLLocationManagerDelegate не улавливает события

#ios #swift

#iOS #swift

Вопрос:

прежде всего, я новичок в разработке iOS, поэтому, пожалуйста, не объясняйте мне на примерах objective-c.

мой вопрос:
я создал этот класс:

 import UIKit
import CoreLocation

class BeaconRadar: NSObject, CLLocationManagerDelegate {

    var manager : CLLocationManager!
    var region  : CLBeaconRegion!

    var seenError           = false
    var locationFixAchieved = false
    var locationStatus      = "Not Started"

    init() {
        super.init()

        var major   = CLBeaconMajorValue( 10 )
        var uuid    = NSUUID( UUIDString: "E2C56DB5-DFFB-48D2-B060-D0F5A71096E0" )
        var id      = "test"

        manager = CLLocationManager()
        region  = CLBeaconRegion( proximityUUID: uuid, major: major, identifier: id )

        manager.delegate        = self
        manager.desiredAccuracy = kCLLocationAccuracyBest

        manager.requestAlwaysAuthorization()
        manager.startRangingBeaconsInRegion(region)
    }

    func locationManager(manager: CLLocationManager!, didRangeBeacons beacons: AnyObject[], inRegion region: CLBeaconRegion! ){

        if (locationFixAchieved == false) {
            locationFixAchieved = true

            println(beacons)

        }

    }

    // If failed
    func locationManager(_manager: CLLocationManager!, rangingBeaconsDidFailForRegion region: CLBeaconRegion!, withError error: NSError!){

        manager.stopUpdatingLocation()
        if (error) {
            if (seenError == false) {
                seenError = true
                println("Error getting location")
            }
        }
    }

    //  // authorization status
    func locationManager(_manager: CLLocationManager!, didChangeAuthorizationStatus status: CLAuthorizationStatus){
        println("2")
        var shouldIAllow = false

        switch status {
            case CLAuthorizationStatus.Restricted:
                locationStatus = "Restricted Access"
            case CLAuthorizationStatus.Denied:
                locationStatus = "User denied access"
            case CLAuthorizationStatus.NotDetermined:
                locationStatus = "Status not determined"
            default:
                locationStatus = "Allowed Access"
                shouldIAllow = true
        }

        NSNotificationCenter.defaultCenter().postNotificationName("LabelHasbeenUpdated", object: nil)
        if (shouldIAllow == true) {
            println("Location Allowed")
            // Start location services
            manager.startUpdatingLocation()
        } else {
            println("Denied access: (locationStatus)")
        }
    }
}
  

и мой ViewController:

 class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view, typically from a nib.

        var location = BeaconRadar()

    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

}
  

я ожидаю получить одно из сообщений в функции реализации для статуса авторизации. (последнее в BeaconRadar). но я ничего не получаю.

если я буду реализовывать все эти методы в ViewController, а не в новом классе (т. е:

 class ViewController: UIViewController, CLLocationManagerDelegate {
.....
}
  

тогда это будет работать просто отлично…

Я что-то упускаю?

Ответ №1:

Вы объявили свой BeaconRadar экземпляр как локальную переменную внутри viewDidLoad , поэтому, как только эта функция завершится, экземпляр BeaconRadar будет выпущен.

Вам следует удалить переменную BeaconRegion из функции —

 class ViewController: UIViewController {

    let location = BeaconRadar()

    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view, typically from a nib.

    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

}