本文說明如何建立多目的地行程、設定正確的欄位,並將行程指派給車輛執行。本文假設您已設定機群 建立車輛、取得可正常運作的駕駛應用程式 也可以選擇購買消費者應用程式你應該也已經熟悉 以量計價行程可用的情境。請參閱下列相關指南:
- 設定 Fleet Engine
- 建立車輛
- 隨選行程總覽中的「行程情境」
行程建立基本資訊
本節說明在車隊引擎中建立行程所需的必要要求詳細資料。您可以使用 gRPC 和 REST 發出建立要求。
,瞭解如何調查及移除這項存取權。行程欄位
請使用下列欄位在 Fleet Engine 中建立行程。您可以為不同類型的行程使用不同的欄位:單一或多個目的地、接連行程或共乘行程。您可以在建立行程時提供選用欄位,也可以稍後在更新行程時設定。
名稱 | 必要/自選 | 說明 |
---|---|---|
父項 | 是 | 包含專案 ID 的字串。這組 ID 必須與使用的 ID 相同 以同一個服務帳戶,全面整合 Fleet Engine 服務 角色。 |
trip_id | 是 | 您建立的用於識別此行程的專屬字串。行程 ID 必須包含 相關限制。 |
trip_type | 是 | 針對您要建立的行程類型,將 TripType 設為下列值:
|
pickup_point | 是 | 行程的出發地。 |
中繼目的地 | 是 | 僅限多重目的地的行程:駕駛人在這兩個地點造訪的中繼目的地清單
上車和下車地點。和 |
vehicle_waypoints | 是 | 僅限共乘行程:這個欄位可支援交錯顯示多個行程的路線點。這項資料包含指派車輛的所有剩餘路線點,以及這趟行程的上下車路線點。您可以呼叫 |
number_of_passengers | 否 | 行程乘客人數。 |
dropoff_point | 否 | 行程的目的地。 |
vehicle_id | 否 | 指派給行程的車輛 ID。 |
範例:建立多目的地行程
以下示範如何建立專屬多目的地行程,其中包含上車地點、下車地點和一個中途目的地。
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// Trip initial settings.
String parent = "providers/" + PROJECT_ID;
Trip trip = Trip.newBuilder()
.setTripType(TripType.EXCLUSIVE)
.setPickupPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)))
.setNumberOfPassengers(1)
.setDropoffPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.1275).setLongitude(106.6537)))
// Add the list of intermediate destinations.
.addAllIntermediateDestinations(
ImmutableList.of(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)).build()))
.build();
// Create the Trip request.
CreateTripRequest createTripRequest = CreateTripRequest.newBuilder()
.setParent(parent)
.setTripId(TRIP_ID) // Trip ID assigned by the Provider server.
.setTrip(trip) // 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: // Trip already exists.
break;
case PERMISSION_DENIED:
break;
}
return;
}
更新多目的地行程
您必須使用車輛 ID 設定行程,讓車隊引擎沿著路線追蹤車輛。如要進一步瞭解如何更新行程,請參閱 更新行程及管理狀態。
如果你在建立行程時未指定下車地點或中途目的地,隨時都可以在這個階段指定。
行程更新範例
以下示範如何更新行程,新增中途目的地清單並設定車輛 ID。
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to be updated.
Trip trip = Trip.newBuilder()
// Add the list of intermediate destinations.
.addAllIntermediateDestinations(
ImmutableList.of(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)).build()))
.setVehicleId("8241890")
.build();
// The trip update request.
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(
FieldMask.newBuilder()
.addPaths("intermediate_destinations")
.addPaths("vehicle_id")
.build())
.build();
// Error handling.
try {
Trip updatedTrip =
tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case PERMISSION_DENIED:
break;
}
return;
}
管理多目的地行程的行程狀態
請使用其中一個 TripStatus
列舉來指定行程的狀態
輕鬆分配獎金當行程狀態發生變更時 (例如從 ENROUTE_TO_PICKUP
變更為 ARRIVED_AT_PICKUP
),您必須在車隊引擎中更新行程狀態。行程狀態一律會以 NEW
值開頭,並以 COMPLETE
或 CANCELED
值結尾。
如果是多目的地行程,且需要隨著您更新行程狀態, 如果是單一目的地行程,您也必須更新以下項目 每當車輛抵達中繼目的地時:
intermediateDestinationIndex
intermediateDestinationsVersion
如要執行這項操作,請使用 TripStatus
列舉中的下列值。
ENROUTE_TO_PICKUP
ARRIVED_AT_PICKUP
ENROUTE_TO_INTERMEDIATE_DESTINATION
ARRIVED_AT_INTERMEDIATE_DESTINATION
ENROUTE_TO_DROPOFF
COMPLETE
含有中繼目的地的行程範例
以下說明如何建立已經通過的多目的地行程 ,且正在轉送至第一個中繼目的地。
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "multi-destination-trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
// Get the trip object from either the Fleet Engine or storage.
Trip trip = …;
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// The trip settings to be updated.
Trip trip = Trip.newBuilder()
// Trip status cannot return to a previous state once it has passed.
.setTripStatus(TripStatus.ENROUTE_TO_INTERMEDIATE_DESTINATION)
// Enroute to the first intermediate destination.
.setIntermediateDestinationIndex(0)
// You must provide an intermediate_destinations_version to ensure that you
// have the same intermediate destinations list as the Fleet Engine.
.setIntermediateDestinationsVersion(
trip.getIntermediateDestinationsVersion())
.build();
// The trip update request.
UpdateTripRequest updateTripRequest = UpdateTripRequest.newBuilder()
.setName(tripName)
.setTrip(trip)
.setUpdateMask(
FieldMask.newBuilder()
.addPaths("trip_status")
.addPaths("intermediate_destination_index")
// intermediate_destinations_version must not be in the update mask.
.build())
.build();
// Error handling.
try {
Trip updatedTrip =
tripService.updateTrip(updateTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND: // The trip doesn't exist.
break;
case FAILED_PRECONDITION: // Either the trip status is invalid, or the
// intermediate_destinations_version doesn't
// match Fleet Engine's.
break;
case PERMISSION_DENIED:
break;
}
return;
}