建立單一目的地行程

本文說明如何建立單一目的地行程、設定正確的欄位,以及將行程指派給車輛以完成行程。本指南假設您已設定 Fleet Engine,並建立車輛、擁有可正常運作的駕駛人應用程式,以及 (選用) 消費者應用程式。如需相關資訊,請參閱下列指南:

建立行程基本概念

本節說明在 Fleet Engine 中建立行程時所需的請求詳細資料。您可以使用 gRPC 和 REST 發出建立要求。

  • CreateTrip() 方法:gRPCREST
  • CreateTripRequest 訊息:僅限 gRPC

行程欄位

使用下列欄位在 Fleet Engine 中建立行程。你可以針對不同類型的行程使用不同欄位,例如單一或多個目的地、連續行程或共乘行程。建立行程時,您可以提供選填欄位,也可以在稍後更新行程時設定這些欄位。

行程欄位
名稱 必要/自選 說明
parent 包含專案 ID 的字串。這個 ID 必須與整個 Fleet Engine 整合中使用的 ID 相同,且具有相同的服務帳戶角色。
trip_id 您建立的字串,用於專門識別這趟行程。如參考資料所示,行程 ID 有特定限制。
trip_type 為要建立的行程類型,將 TripType 設為下列值:
  • 單一目的地:設為 SHAREDEXCLUSIVE
  • 多目的地:設為 EXCLUSIVE
  • 背對背:設為 EXCLUSIVE
  • 共用集區:設為「SHARED」。
pickup_point 行程出發地。
中途目的地

僅限多目的地行程:司機在接送之間造訪的中途目的地清單。與 dropoff_point 相同,這個欄位也可以稍後透過呼叫 UpdateTrip 設定,但根據定義,多目的地行程包含中途目的地。

vehicle_waypoints

僅限共乘行程:這個欄位支援交錯處理多個行程的途經點。 其中包含指派車輛的所有剩餘途經點,以及這趟行程的取貨和送達途經點。您可以呼叫 CreateTripUpdateTrip 來設定這個欄位。您也可以透過 waypoints 欄位更新車輛航點,方法是呼叫 UpdateVehicle。基於隱私權考量,這項服務不會在 GetTrip 呼叫中傳回這項資訊。

number_of_passengers 行程的乘客人數。
dropoff_point 行程目的地。
vehicle_id 指派給行程的車輛 ID。

範例:單一目的地行程

以下範例說明如何建立前往 Grand Indonesia East Mall 的行程。這趟行程有兩位乘客,且為專屬行程,狀態為 NEW。行程的 provider_id 必須與 Google Cloud 專案 ID 相同。範例顯示專案 ID 為 my-rideshare-co-gcp-project 的 Google Cloud 專案。這個專案也必須包含服務帳戶,才能呼叫 Fleet Engine。詳情請參閱「服務帳戶角色」。

static final String PROJECT_ID = "my-rideshare-co-gcp-project";

TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);

// Trip initial settings.
String parent = "providers/" + PROJECT_ID;

Trip trip = Trip.newBuilder()
    .setTripType(TripType.EXCLUSIVE) // Use TripType.SHARED for carpooling.
    .setPickupPoint(                 // Grand Indonesia East Mall.
        TerminalLocation.newBuilder().setPoint(
            LatLng.newBuilder()
                .setLatitude(-6.195139).setLongitude(106.820826)))
    .setNumberOfPassengers(2)
    // Provide the drop-off point if available.
    .setDropoffPoint(
        TerminalLocation.newBuilder().setPoint(
            LatLng.newBuilder()
                .setLatitude(-6.1275).setLongitude(106.6537)))
    .build();

// Create trip request
CreateTripRequest createTripRequest = CreateTripRequest.newBuilder()
    .setParent(parent)
    .setTripId("trip-8241890")  // Trip ID assigned by the provider.
    .setTrip(trip)              // The initial state is NEW.
    .build();

// Error handling.
try {
  Trip createdTrip = tripService.createTrip(createTripRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
    case ALREADY_EXISTS:
      break;
    case PERMISSION_DENIED:
      break;
  }
  return;
}

後續步驟