监听导航事件

您的应用可以监听用户沿路线导航时发生的事件。

概览

使用以下界面监听导航事件:

查看代码

检测是否到达目的地

此处,目的地是指最终目的地或航点。如需检测到达,请调用 Navigator.addArrivalListener(),该方法会在设备到达目的地时注册回调。

抵达后,Navigation SDK for Android 会触发 onArrival() 回调并停止精细导航。您必须明确调用 Navigator.continueToNextDestination() 才能前进到下一个航点,必须明确调用 Navigator.startGuidance() 才能继续精细导航。

当您调用 continueToNextDestination() 时,导航器会舍弃有关上一个目的地的所有信息。如果您要分析上一路段的相关信息,必须先从导航器检索这些信息,然后再调用 continueToNextDestination()

为了避免内存泄漏,当您不再需要监听器时,必须调用 removeArrivalListener(listener)

mNavigator.addArrivalListener(new Navigator.ArrivalListener() {
    @Override
    public void onArrival(ArrivalEvent arrivalEvent) {
        displayMessage("onArrival: You've arrived at a waypoint: "
                + mNavigator.getCurrentRouteSegment().getDestinationWaypoint().getTitle(),
                DISPLAY_BOTH);
        // Start turn-by-turn guidance for the next leg of the route.
        if (arrivalEvent.isFinalDestination()) {
            displayMessage("onArrival: You've arrived at the final destination.",
                    DISPLAY_BOTH);
        } else {
            mNavigator.continueToNextDestination();
            mNavigator.startGuidance();
        }
    }
});

接收位置信息更新

NavigationApi 获取 RoadSnappedLocationProvider,然后调用 RoadSnappedLocationProvider.addLocationListener(),以便在设备的位置或方向发生变化时注册回调。请注意,此位置与道路对应,因此可能与 Google Play 服务地理位置 API 中的一体化位置信息提供程序返回的位置不同。

Navigation SDK 会尽可能频繁地提供位置信息更新。当有可用的位置信息更新时,Navigation SDK 会触发 onLocationChanged() 回调。

道路贴靠位置信息更新与导航无关,即使在导航停止后仍会继续。如果您将位置信息更新在后台运行,则订阅位置信息更新可能会导致耗电、内存泄漏或无意中收集设备位置数据。当您不再需要该监听器时,请调用 RoadSnappedLocationProvider.removeLocationListener

mRoadSnappedLocationProvider =
        NavigationApi.getRoadSnappedLocationProvider(getApplication());
if (mRoadSnappedLocationProvider != null) {
    mRoadSnappedLocationProvider.addLocationListener(
            new RoadSnappedLocationProvider.LocationListener() {
                @Override
                public void onLocationChanged(Location location) {
                    displayMessage("onLocationUpdated: Navigation engine has provided a new"
                                    + " road-snapped location: "
                                    + location.toString(),
                            DISPLAY_LOG);
                }
            });
} else {
    displayMessage("ERROR: Failed to get a location provider", DISPLAY_LOG);
}

接收时间和距离动态

当剩余时间(秒)或距离(米)变化超过给定阈值时,调用 Navigator.addRemainingTimeOrDistanceChangedListener() 以注册回调。

当时间或距离的变化超过指定时长时,Navigation SDK 会触发 onRemainingTimeOrDistanceChanged() 回调。

如需查找剩余时间和距离,请调用 Navigator.getTimeAndDistanceList()。请注意,列表中的时间和距离是累计的:它们显示的是从当前位置到每个航点(而不是从一个航点到另一个航点)的时间和距离。TimeAndDistance 对象现在也会返回 delaySeverity。此枚举为 heavy、中等、轻、或未知。它对应于您在地图界面的 eta 上看到的颜色(厚重 = 红色,中 = 黄色,浅色 = 绿色)。如果您需要创建自己的 eta 页脚,这会很有用。

为避免内存泄漏,在不再需要监听器时必须调用 Navigator.removeRemainingTimeOrDistanceChangedListener(listener)

如果剩余时间变化超过 60 秒或剩余距离变化超过 100 米,以下示例会请求回调。

mNavigator.addRemainingTimeOrDistanceChangedListener(60, 100,
        new Navigator.RemainingTimeOrDistanceChangedListener() {
            @Override
            public void onRemainingTimeOrDistanceChanged() {
                displayMessage("onRemainingTimeOrDistanceChanged: Time or distance estimate"
                        + " has changed.",
                        DISPLAY_LOG);
            }
        });

您可以通过内置屏幕(使用 setEtaCardEnabled() 方法并传递值为 TRUE 的参数)显示剩余时间和距离信息。如需禁止显示时间/距离,请将此值设置为 FALSE

您还可以使用 getTimeAndDistanceList() 方法公开多个航点的预计到达时间。

接收路线更新

调用 Navigator.addRouteChangedListener(),以在路由发生更改时注册回调。

当路线发生更改时,Navigation SDK 会触发 onRouteChanged() 回调。您可以调用 Navigator.getRouteSegmentsNavigator.getCurrentRouteSegment() 来查找新路由。

为了避免内存泄漏,当您不再需要监听器时,必须调用 removeRouteChangedListener(listener)

mNavigator.addRouteChangedListener(new Navigator.RouteChangedListener() {
    @Override
    public void onRouteChanged() {
        displayMessage("onRouteChanged: The driver's route has changed. Current waypoint: "
                + mNavigator.getCurrentRouteSegment().getDestinationWaypoint().getTitle(),
                DISPLAY_LOG);
    }
});

检测夜间模式何时发生变化

调用 NavigationView.addOnNightModeChangedListenerSupportNavigationFragment.addOnNightModeChangedListener,以便在夜间模式发生变化时注册回调。

以下示例展示了如何在导航 fragment 上监听夜间模式更改。

mNavFragment.addOnNightModeChangedListener(new NavigationView.OnNightModeChangedListener() {
    @Override
    public void onNightModeChanged(NightModeChangedEvent nightModeChangedEvent) {
        displayMessage("Night mode is active: " + nightModeChangedEvent.inNightMode(),
        DISPLAY_LOG);
    }
});