此处映射iOS SDK中的NMAvigationManagerDelegate不起作用

此处映射iOS SDK中的NMAvigationManagerDelegate不起作用,ios,swift,here-api,Ios,Swift,Here Api,我使用的是HERE iOS SDK,我正在实现一个逐轮导航,但是没有调用nmavailationmanagerdelegate的didUpdateManuevers方法或任何其他方法 当我尝试模拟移动和使用时: let source = NMARoutePositionSource(route: route.route) NMAPositioningManager.sharedInstance().dataSource = source 所有的工作都很好,但当我模拟移动通过GPX文件或实时测

我使用的是HERE iOS SDK,我正在实现一个逐轮导航,但是没有调用
nmavailationmanagerdelegate
didUpdateManuevers
方法或任何其他方法

当我尝试模拟移动和使用时:

let source = NMARoutePositionSource(route: route.route)
NMAPositioningManager.sharedInstance().dataSource = source 
所有的工作都很好,但当我模拟移动通过
GPX
文件或实时测试时,委托的方法并没有被调用

我的代码:

class HereMapViewController: UIViewController {

    @IBOutlet private weak var mapView: NMAMapView!

    fileprivate var navigationManager = NMANavigationManager.sharedInstance()
    var route : NMAMapRoute?


    // MARK: - life cycle

    override func viewDidLoad() {
        super.viewDidLoad()

        setupUI()
    }

    deinit {
        navigationManager.stop()
    }


    // MARK: - private

    private func setupUI() {
        mapView.copyrightLogoPosition = .center
        mapView.zoomLevel = 10
        mapView.positionIndicator.isVisible = true
        mapView.gestureDelegate = self
        navigationManager.voicePackageMeasurementSystem = NMAMeasurementSystem.imperialUS
        navigationManager.backgroundNavigationEnabled = true
        navigationManager.isVoiceEnabled = true

        navigationManager.delegate = self
        setupRoute()
    }

    private func setupRoute() {
        guard let mapRoute = route, let routeStart = mapRoute.route.start else {
                return
        }

        let start = NMAGeoCoordinates(latitude: routeStart.navigablePosition.latitude,
                                      longitude: routeStart.navigablePosition.longitude)

        mapView.add(mapObject: mapRoute)
        mapView.set(boundingBox: mapRoute.route.boundingBox!, animation: NMAMapAnimation.none)

        startNavigation()
        mapView.set(geoCenter: start, animation: .none)
    }
    private func startNavigation() {
        guard let route = route else {
            return
        }

        navigationManager.map = mapView
        NMAPositioningManager.sharedInstance().dataSource = NMAHEREPositionSource()
        navigationManager.startTurnByTurnNavigation(route.route)
        navigationManager.mapTrackingEnabled = false
        navigationManager.mapTrackingAutoZoomEnabled = false
        navigationManager.mapTrackingOrientation = .dynamic
        navigationManager.isSpeedWarningEnabled = true

    }
}


//MARK: - NMANavigationManagerDelegate

extension HereMapViewController : NMANavigationManagerDelegate {
    // Signifies that there is new instruction information available
    func navigationManager(_ navigationManager: NMANavigationManager, didUpdateManeuvers currentManeuver: NMAManeuver?, _ nextManeuver: NMAManeuver?) {
        print("didUpdateManeuvers")
    }

    // Signifies that the system has found a GPS signal
    func navigationManagerDidFindPosition(_ navigationManager: NMANavigationManager) {
        print("New position has been found")
    }

    func navigationManager(_ navigationManager: NMANavigationManager, didFindAlternateRoute routeResult: NMARouteResult) {
        print("didFindAlternateRoute")
    }

    func navigationManager(_ navigationManager: NMANavigationManager, didUpdateRoute routeResult: NMARouteResult) {
        print("didUpdateRoute")
    }
}


//MARK: - NMAMapGestureDelegate

extension HereMapViewController : NMAMapGestureDelegate {

    func mapView(_ mapView: NMAMapView, didReceiveTwoFingerPan translation: CGPoint, at location: CGPoint) {
        navigationManager.mapTrackingAutoZoomEnabled = false
    }
}

我想跟踪,当我应该改变操纵,或当我需要创建一个新的路线,如果用户走错了路。我将非常感谢您的帮助。

您需要确保正确设置类以接收委托行为

看看这个问题的答案,特别是MakeAppie的第二个


确保您已完成所有步骤

你的代码片段适合我。确保没有任何控制台错误:

Access to this operation is denied.

需要在Info.plist中设置密钥。你可以检查一下是否适合你

要使用GPX文件模拟移动,请使用


要强制定位广播,您可以使用

谢谢,当我使用NMADevicePositionSource all works时
This app has attempted to access privacy-sensitive data without a usage description. The app's Info.plist must contain both “NSLocationAlwaysAndWhenInUseUsageDescription” and “NSLocationWhenInUseUsageDescription” keys with string values explaining to the user how the app uses this data