本文件說明如何建立多目的地行程,並設定正確的 欄位並指定車輛,然後指派給車輛完成本文假設您已設定機群 建立車輛、取得可正常運作的駕駛應用程式 也可以選擇購買消費者應用程式你應該也已經熟悉 以量計價行程可用的情境。請參閱下列相關指南:
- 設定 Fleet Engine
- 建立車輛
- 隨選行程總覽中的行程情境
行程建立基本資訊
本節將說明建立行程時必要的要求詳細資料 機群引擎您可以使用 gRPC 和 REST 發出建立要求。
,瞭解如何調查及移除這項存取權。行程欄位
請使用下列欄位在 Fleet Engine 中建立行程。不同的是 ] 欄位包含一或多個目的地 往返共乘或共享泳池行程。個人中心 可以在建立行程時提供選填欄位,你也可以自行設定 稍後更新行程時即可派上用場
名稱 | 必要/自選 | 說明 |
---|---|---|
父項 | 是 | 包含專案 ID 的字串。這個 ID 必須與整個 Fleet Engine 整合作業中使用的 ID 相同,且具有相同的服務帳戶角色。 |
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 設定行程,Fleet Engine 才能追蹤 車輛會沿著路線行駛如要進一步瞭解如何更新行程,請參閱 更新行程及管理狀態。
如果您在 建立行程,而且隨時可以進行
行程更新範例
以下示範如何更新行程,新增中途目的地清單並設定車輛 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
,您必須更新 Fleet Engine 中的行程狀態。行程
狀態一律會以 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;
}