准备好车辆

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

由于 Driver 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());

启用位置信息更新

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

RidesharingVehicleReporter reporter = ...;

reporter.enableLocationTracking();
val reporter = ...

reporter.enableLocationTracking()

设置更新间隔

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

将车辆状态设为“在线”

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

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

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

RidesharingVehicleReporter reporter = ...;

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

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

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

后续步骤

设置行程详细信息