常见问题解答

产品详情

网络和连接

数据

界面自定义

路由

模拟器

Workflows

移动服务

产品详情

您的应用必须实现一个对话框,其中包含 Navigation SDK 服务条款声明,每位用户都必须接受该声明。此对话框让用户有机会同意服务条款。Navigation SDK 随附一份包含相关条款的文本文件。 使用 NavigationApi.showTermsAndConditionsDialog 方法显示包含条款的对话框。
Google 地图移动版支持的任何语言都可自动用于 Navigation SDK。 设备具有默认系统语言,应用无法更改该设置;不过,应用可支持 70 多种语言。

可以。启动后,LocationListener 会继续在后台运行。应用会继续进行道路贴合,并保持方位角。

可以。创建或更改路线时,RouteChangeListener 会提供多段线。

不需要,Navigation SDK 不需要在设备上安装 Google Maps Mobile。
否,Navigation SDK 目前不提供此功能。
可以。流量方向默认处于可用状态并显示。
Navigation SDK 支持哪些版本的 JDK?
Navigation SDK 支持 Oracle 积极支持的 Java SE LTS 版本。Oracle Java SE 支持路线图中列出了这些版本,并显示它们具有高级支持

网络和连接

Navigation SDK 如何处理网络连接不佳的情况?
Navigation SDK 会预先缓存每次行程的路线。 预缓存的信息包括 15-20 分钟的路线信息,以及用户偏离路线时的替代路线。Navigation SDK 使用设备 GPS 和传感器来估算位置。
Navigation SDK 如何处理 GPS 信号弱或丢失的情况?

导航开始后,如果 Navigation SDK 至少收到一次 GPS 信号,则会在以下情况下显示“正在搜索 GPS...”消息:

  • 自上次收到 GPS 信号以来已过去 10 秒以上。
  • 如果自上次收到 GPS 信号以来,路线位置已移动超过 500 米。

如果 SDK 长时间未收到 GPS 信号,应用中以人字形箭头位置表示的路线进度可能会减慢,直至完全停止。在这种情况下,地图上的人字形标记将停留在上次 GPS 信号指示的位置。如果未收到 GPS 信号,SDK 不会自动退出导航模式。不过,在重新接收到信号之前,它可能无法提供指导。

是否有离线模式?
否,Navigation SDK 目前不提供离线模式;不过,该 SDK 会为行程提供预缓存的信息。

数据

我可以在开始路线之前检索行程中的所有经停点/目的地吗?

可以。如需检索路线的分段路线,请调用 Navigator.getRouteSegments()

在路线开始时是否提供精细的路线引导?
可以。Navigation SDK 提供了一系列路线段。 此外,用户还可以滑动标题中的路线卡片,查看每个操作。
如何向应用用户传达 ETA?

请按照以下步骤向应用用户提供 ETA 信息:

  1. 使用 Navigator.getTimeAndDistanceList() 检索所有途经点的行程时间和距离。
  2. 像处理司机预计到达时间一样,将此信息转发给客户端应用。
如果导航不在前台运行,是否可以使用 RoadSnappedLocationProvider 获取用户当前贴合的位置?

可以。默认情况下,RoadSnappedLocationProvider 在后台运行。

Navigation SDK 是否支持地理围栏?

否。在导航方面,remainingTimeOrdistanceChangeListener 比地理围栏更具优势。地理围栏可能无法考虑道路几何形状,也可能未以用户导航到的确切点为中心。

您可以使用 remainingTimeOrdistanceChangeListener 来近似实现此功能。

  1. 设置用于确定回调频率的阈值。
  2. 查看到达目的地的剩余距离。

例如,如果您将阈值设置为 100 米,则当到达目的地的距离变化 100 米时,您会收到回调。随着距离的减小,您可以将此阈值更新为较小的值,并接收更频繁的回调。然后,检查剩余距离,以确定您是否足够接近上车/下车地点。

当导航应用在后台运行时,我可以停用通知吗?

可以。使用 Navigator.setHeadsUpNotificationEnabled 控制通知。此方法有一个布尔值实参。FALSE 停用通知;TRUE 启用通知。

交易记录器会使用唯一 ID 跟踪取件和送达情况,Google 会记录这些信息以用于产品分析。如果您是出行服务客户,Google 建议您实现 NavigationTransactionRecorder 以记录您的交易。

界面自定义

我可以为最佳路线选项添加颜色代码吗?
否。目前不支持为特定路线选项添加颜色编码。
导航 SDK 是否可以显示最终目的地的预计到达时间?

可以。请使用以下方法:

  1. 使用 Navigator.getTimeAndDistanceList() 检索所有途经点的行程时间和距离。
  2. 使用 NavigationFragment.setEtaCardEnabled(false) 隐藏当前途经点的预计到达时间。
  3. 渲染最终目的地预计到达时间。
如何隐藏预计到达时间更新?

您可以通过调用 navigationView.setEtaCardEnabled(false) 停用到达时间卡片。

哪些界面自定义设置可用于标题和页脚卡片?

使用 StylingOptions 设置背景颜色样式。如需隐藏或显示页眉和页脚,请使用 NavigationFragmentsetHeaderEnabledsetFooterEnabled 成员函数。

路由

我可以向用户提供特定路线或移除替代路线吗?
否。默认情况下,系统会提供多条路线,其中最快的路线具有优先权。 您可以在请求中添加偏好设置(例如“避开高速公路和收费站”),从而影响默认路线。添加途经点也会影响路线。
我可以向应用用户显示与默认目的地位置不同的目的地标签吗?

可以。使用目的地的自定义标题和纬度/经度创建 Marker。导航 SDK 会在 NavigationMap 上显示自定义标题和坐标。

我可以使用 Navigation SDK 来跟踪偏离已定义路径的情况吗?

可以。使用 Navigator.setRouteChangedListener 可在路线发生变化或系统推荐新路线时接收通知:

  1. 使用 Navigator.setRouteChangedListener 方法注册一个监听器,用于检查设备在路线上的位置。
  2. 向回调事件处理脚本 onRouteChanged 添加代码:
    • 向应用用户发送包含更新后的预计到达时间和距离信息的消息。
    • 跟踪设备的位置。
    • [可选] 添加应用所需的其他功能,以处理用户偏离预定路线的情况。
用户能否在未完成路线的情况下退出导航?

可以。调用 Navigator.stopGuidance() 方法以停止导航。

模拟器

模拟器是否支持路线变更?

可以。调用 simulateLocationsAlongNewRoute 以模拟包含路线变更的行程。simulateLocationsAlongExistingRoute 方法会忽略对现有路线所做的更改。

Workflows

如何关闭包含导航 fragment 的 activity 关闭后的通知?

在导航期间,即使关闭 activity,导航通知仍会保持显示。当车辆到达目的地时,导航会停止,通知也会消失。

如需处理对通知的点击,请使用 Navigator.startGuidance(intent resumeIntent)。 当应用用户点击通知时,系统会触发 resume intent。 通常,Navigator.startguidance(getIntent()) 是从主 Activity 调用的,当应用用户点击通知时,主 Activity 会重新调用该 Activity。

移动服务

对于出行服务客户,使用 Navigation SDK 有何不同?

Google Maps Platform Mobility Services 提供了一系列 API 和 SDK,可帮助满足运输和物流企业的需求。对于移动服务客户,Navigation SDK 通常与相关服务结合使用,以实现路线优化、调度、任务跟踪、车队分析等功能。对于移动服务客户,Navigation SDK 的结算方式也不同。如需了解详情,请参阅移动服务文档。

移动产品目前仅向部分客户提供。如需了解详情,请与您的销售代表联系。

如何判断我是否是 Mobility Services 客户?
如果您不确定自己目前是否以移动服务客户的身份实现 Navigation SDK,请在代码中查找 ReportBillableEvent 调用。只有 Mobility Services 客户应调用 ReportBillableEvent 方法。

对于出行服务客户,Navigation SDK 的结算方式是怎样的?
对于出行服务客户,Navigation SDK 的结算和定价取决于您与 Google Maps Platform 签订的服务协议。如需了解如何验证移动服务实现是否正确结算,请参阅结算验证。如需详细了解移动服务结算,请联系您的销售代表。

哪些 Navigation SDK API 只能由 Mobility Services 客户使用?

Navigation SDK 中有多个 API 仅供 Mobility Services 客户使用,这些客户按交易量向 Google 付费。如果您不是移动服务客户,则以下方法为 no-op:

如果我是 Mobility Services 客户,是否也可以使用非 Mobility Services 版的 Navigation SDK?

可以。Mobility 服务客户可以使用 Navigation SDK 的 Mobility 服务实现和非 Mobility 服务实现。不过,您一次只能在一个应用中使用一种实现类型。您还需要创建新的 Google Cloud 项目、结算账号和 API 密钥,这些项目、账号和密钥应与您在实施出行服务时使用的项目、账号和密钥分开。如需了解详情,请参阅Navigation SDK 设置概览

如需详细了解如何使用非 Mobility Services 实现的 Navigation SDK,包括如何将应用从一种实现类型迁移到另一种实现类型,请与您的 Google 客户代表联系。

注意:如果您目前不是移动服务客户,但有兴趣详细了解移动服务 API 和 SDK,请与 Google Maps Platform 销售团队联系