CLLocationManager: didChangeAuthorization и didRangeBeacons не вызывается - PullRequest
1 голос
/ 19 сентября 2019

Я разрабатываю фреймворк, в котором есть вся логика для измерения радиомаяков и мониторинга.

Все обратные вызовы CLLocationManager не работают.Это происходит только тогда, когда я использую фреймворк.Если я перенесу всю логику в тестовое приложение, оно будет работать.

Вот части кода:

Это основной класс фреймворка (который вызывается из тестового приложения):

//Test App
let miniK = Kanban()
miniK.startBeaconSearch(forApiKey: "apikeytest", userID: "1")
public class Kanban: NSObject {


    public override init() {
        super.init()
    }

    public func startBeaconSearch(forApiKey apikey: String, userID: String){
        let beaconController = BeaconController.init(apikey: apikey, userId: userID)
        beaconController.startScanning()
    }

}

BeaconController:

import Foundation
import CoreLocation
import CoreBluetooth

class BeaconController : NSObject, CLLocationManagerDelegate {
    var locationManager: CLLocationManager!
    var apiKey: String!
    var userID: String!
    var beaconsJson : [BeaconItem]?

    public override init(){
        super.init()
        locationManager = CLLocationManager()
        locationManager.delegate = self
        locationManager.requestAlwaysAuthorization()
    }

    public init(apikey:String, userId:String){
        super.init()
        locationManager = CLLocationManager()
        locationManager.delegate = self
        locationManager.requestAlwaysAuthorization()
        apiKey = apikey
        userID = userId
        self.loadBeacons()
    }

    func locationManager(_ manager: CLLocationManager, didChangeAuthorization status: CLAuthorizationStatus)
    {
        if status == .authorizedAlways
        {
            if CLLocationManager.isMonitoringAvailable(for: CLBeaconRegion.self){
                if CLLocationManager.isRangingAvailable() {
                    startScanning()
                }
            }
        }
    }


    func locationManager(_ manager: CLLocationManager, didRangeBeacons beacons: [CLBeacon], in region: CLBeaconRegion) {
        print("didRangeBeacons")
        if beacons.count > 0 {
            self.beaconReached(uuid: beacons[0].proximityUUID, minor: beacons[0].minor, major: beacons[0].major)
        }
    }

    func locationManager(_ manager: CLLocationManager, rangingBeaconsDidFailFor region: CLBeaconRegion, withError error: Error) {
        print(error)
        print(error.localizedDescription)
    }

    public func startScanning() {
        print("StartScanning")
        sleep(5)
        //let beacon = beaconsJson![0]

        for beacon in beaconsJson! {
            print(beacon.BeaconUUID)
            let identifier = "iBeacon" + beacon.BeaconMajor.description + beacon.BeaconMinor.description
            let uuid = UUID(uuidString: beacon.BeaconUUID)!
            let beaconRegion = CLBeaconRegion(proximityUUID: uuid, major: CLBeaconMajorValue(beacon.BeaconMajor), minor: CLBeaconMinorValue(beacon.BeaconMinor), identifier: identifier)
            //beaconRegion.notifyOnEntry = true
            locationManager.requestState(for: beaconRegion)
            locationManager.startMonitoring(for: beaconRegion)
            locationManager.startRangingBeacons(in: beaconRegion)
        }
        print(locationManager.rangedRegions)
    }
}

loadBeacons и beaconReached - сетевые функции, которые работают правильно.Тестовое приложение имеет разрешение на определение местоположения пользователя и все необходимые возможности.

Когда я печатаю удаленные регионы, маяки отображаются правильно.

1 Ответ

0 голосов
/ 22 сентября 2019

Проблема заключалась в жизненном цикле объекта locationManager.

Во-первых, вы должны определить locationManager как объект класса, подобный этому.

public class Kanban: NSObject, CLLocationManagerDelegate {
    var apiKey: String!
    var userID: String!
    var beaconsJson: [BeaconItem]?

    let locationManager = CLLocationManager()
    //...
}

И затем, в реализации фреймворка, он также должен быть объектом класса, напримерэто.

struct ContentView: View {
    @State private var selection = 0
    let miniK = Kanban()
    //...
}

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...