监听导航事件

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

概览

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

查看代码

检测到达目的地

在这里,“目的地”是指最终目的地或航路点。如需检测到达情况,请调用 Navigator.addArrivalListener(),该函数会在设备到达目的地时注册回调。

到达目的地后,Android 导航 SDK 会触发 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”“medium”“light”或“unknown”。这与您在 Google 地图界面中看到的预计到达时间颜色相对应(严重 = 红色、中等 = 黄色、轻微 = 绿色)。如果您需要创建自己的 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);
    }
});

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