准备好车辆

本部分介绍了如何准备好车辆以便出行。您必须先完成以下每个步骤,然后后端才能将车辆与行程匹配。

设置监听器

由于驱动程序 SDK 会在后台执行操作,因此请使用 DriverStatusListener 在发生特定事件(例如错误、警告或调试消息)时触发通知。错误可能是暂时性的(例如 BACKEND_CONNECTIVITY_ERROR),也可能会导致位置信息更新永久停止。例如,如果您收到 VEHICLE_NOT_FOUND 错误,则表示存在配置错误。

以下示例展示了 DriverStatusListener 实现:

class MyStatusListener implements DriverStatusListener {
  /** Called when background status is updated, during actions such as location reporting. */
  @Override
  public void updateStatus(
      StatusLevel statusLevel, StatusCode statusCode, String statusMsg, @Nullable Throwable cause) {
    // Existing implementation

    if (cause != null && cause instanceof StatusRuntimeException) {
      if (Status.NOT_FOUND.getCode().equals(cause.getStatus().getCode())) {
        // NOT_FOUND gRPC exception thrown by Fleet Engine.
      }
    }
  }
}

DriverContextBuilder.setDriverStatusListener(new MyStatusListener());

启用位置信息更新

设置监听器后,请按如下方式启用位置信息更新:

Java

RidesharingVehicleReporter reporter = ...;

reporter.enableLocationTracking();

Kotlin

val reporter = ...

reporter.enableLocationTracking()

设置更新间隔

默认情况下,当车辆状态为 ONLINE 时,Driver SDK 会以 10 秒为间隔发送位置信息更新。您可以使用 reporter.setLocationReportingInterval(long, TimeUnit) 更改此间隔。支持的最短更新间隔为 5 秒。更新频率越高,请求速度越慢,错误也越多。

将车辆状态设为在线

开启位置信息更新后,您可以将车辆状态设置为 ONLINE,以便在车队引擎中对车辆执行 SearchVehicles 查询。驱动程序 SDK 会发送更新后的车辆状态和位置信息更新。

您可以直接在 Driver SDK 或 Fleet Engine 服务器中设置车辆状态。如需了解详情,请参阅更新车辆

以下示例展示了如何在 Driver SDK 中将车辆状态设为“在线”:

Java

RidesharingVehicleReporter reporter = ...;

reporter.enableLocationTracking();
reporter.setVehicleState(VehicleState.ONLINE);

Kotlin

val reporter = ...

reporter.enableLocationTracking()
reporter.setVehicleState(VehicleState.ONLINE)

StatusListener 还会报告更新车辆状态时发生的所有错误。

后续步骤

设置行程详细信息