监听导航事件

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

概览

使用以下接口监听导航事件:

查看代码

检测到达目的地的时间

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

到达目的地后,Android 版 Navigation SDK 会触发 onArrival()回调,然后可以使用该回调通过 Navigator.stopGuidance()停止 逐向导航,或 使用 Navigator.continueToNextDestination()前往下一个途经点。如果导航会话仅包含一个目的地,或者目的地列表中没有剩余目的地,则调用 Navigator.continueToNextDestination() 会自动停止导航。

调用 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、meduim、light 或 unknown。这与您在地图界面中看到的预计到达时间 (ETA) 的颜色相对应(heavy = 红色,medium = 黄色,light = 绿色)。如果您需要创建自己的 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() 方法显示多个途经点的 ETA。

接收路线更新

调用 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);
    }
});

您还可以通过编程方式设置夜间模式。如需了解详情,请参阅设置 夜间模式