本文假設您已瞭解如何建立及使用工作。並提供以下具體範例,說明如何透過下列方式設定運送工作:
設定出貨作業的目標時間範圍:設定作業的完成時間範圍。
自訂工作可見度:自訂工作活動的可見度,以便向客戶或車隊操作員顯示。
如要進一步瞭解出貨工作欄位,請參閱「建立出貨工作」。更新現有工作相關的其他資訊時,除了要更新的工作欄位外,還必須提供工作相關的 ID。
設定目標時間範圍
目標時間範圍是指應完成工作時的 TimeWindow。舉例來說,如果您向運送收件者提供運送時間範圍,可以使用工作目標時間範圍擷取這個時間範圍並產生快訊,也可以用來分析過去的行程表現。
目標時間範圍包含開始時間和結束時間,可用於任何任務類型。目標時間範圍不會影響路由行為。
以下範例說明如何使用 Java gRPC 程式庫設定時間視窗,或如何向 UpdateTask
提出 HTTP REST 要求。您也可以在建立工作時設定這個欄位。
gRPC
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String TASK_ID = "task-8241890";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Task settings
String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;
Task task = Task.newBuilder()
.setName(taskName)
.setTargetTimeWindow(
TimeWindow.newBuilder()
.setStartTime(Timestamp.newBuilder().setSeconds(1680123600))
.setEndTime(Timestamp.newBuilder().setSeconds(1680130800)))
.build();
// Task request
UpdateTaskRequest updateTaskRequest =
UpdateTaskRequest.newBuilder() // No need for the header
.setTask(task)
.setUpdateMask(FieldMask.newBuilder().addPaths("targetTimeWindow"))
.build();
try {
Task updatedTask = deliveryService.updateTask(updateTaskRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND:
break;
case PERMISSION_DENIED:
break;
}
return;
}
REST
如要使用 HTTP 設定工作時間窗格,請呼叫 PATCH
,並使用 updateMask
更新 targetTimeWindow
參數:
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/tasks/<id>?updateMask=targetTimeWindow
其中 <id> 是工作的專屬 ID。要求標頭必須包含「Authorization」欄位,其值為「Bearer <token>」,其中 <token> 是由伺服器根據「服務帳戶角色」和「JSON Web 權杖」一文所述的規範所發出。
# Set JWT, PROJECT_ID, and TASK_ID in the local environment
curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/tasks/${TASK_ID}?updateMask=targetTimeWindow" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}" \
--data-binary @- << EOM
{
"targetTimeWindow": {
"startTime": "2023-03-29T21:00:00Z",
"endTime": "2023-03-29T23:00:00Z"
}
}
EOM
自訂工作可見度
根據預設,Fleet Engine 會提供工作活動資訊,以便向接收貨物的客戶和追蹤貨物的車隊運作人員顯示。這包括指出要傳送包裹運送狀態通知給客戶前,要先經過幾個停靠站點等資訊。您可以根據每項工作自訂這項資訊,以便更符合您的業務模式。
本節說明地圖上追蹤物件的顯示規則。這些規則適用於兩類物件:
- 地點標記可見度
- 有效車輛任務的任務資料可見度,例如多邊形線和預估到達時間
位置標記顯示規則
無論運送狀態為何,Fleet Engine 都會在地圖上顯示運送地點的標記。
任務資料瀏覽權限規則
本節說明適用於工作資料的預設瀏覽權限規則。您只能自訂運行中的車輛任務,也就是說,只有接送和下車任務可以套用自訂的瀏覽權限規則。
您無法自訂下列工作:
- 已排定的停靠點
- 不提供服務的工作
- 閒置車輛工作
無法使用的工作瀏覽權限規則
根據預設,如果已追蹤的工作指派至少一項無法提供服務的工作,車輛就不會顯示在地圖上。例如,如果駕駛人正在休息,或是車輛在前往追蹤貨物的路線上加油,系統仍會顯示預計到達時間和預估任務完成時間。請注意,您無法自訂這項規則。
進行中的車輛工作可見度
TaskTrackingInfo
物件提供多個資料元素,您可以使用「Shipment Tracking Library」程式庫將這些元素顯示出來。根據預設,當工作指派給車輛,且車輛距離工作地點 5 個站內時,系統就會顯示這些欄位。工作完成或取消後,就會停止顯示。
您可以在 Fleet Engine 中建立或更新工作時,在工作上設定 TaskTrackingViewConfig
,即可根據每項工作自訂瀏覽權限設定。這會為個別資料元素建立可用規則。
下表列出可套用瀏覽權限規則的欄位。
顯示規則的車輛工作欄位 |
---|
|
下表列出上述欄位的可見度選項。
瀏覽權限選項 |
---|
|
路線折線和車輛位置顯示規則
對於已追蹤路線,路線折線的顯示與否取決於車輛的顯示狀態。如果在有效路線上顯示路線多邊形,而車輛未顯示,系統仍可透過可見多邊形的結尾推斷車輛位置。因此,路線多邊形的能見度必須與車輛能見度相同或更嚴格。
請遵循下列規則,提供有效的路線多邊形 / 車輛位置可見度組合。
路線折線和車輛位置指定「相同」顯示選項
在這種情況下,多邊形和車輛位置都會設定相同的選項,包括:
- 剩餘停靠站數量
- 到達時間
- 剩餘行駛距離
為遵守規則,路線多邊形可見度的值必須小於或等於車輛可見度設定的值。在這個範例中,多邊形的剩餘停靠站門檻設為 3,低於車輛指定的 5 值。也就是說,當追蹤的路線距離任務位置 5 個站時,車輛就會顯示,但該車輛的路線會在路線距離 3 個站時才顯示。
```js
"taskTrackingViewConfig": {
"routePolylinePointsVisibility": {
"remainingStopCountThreshold": 3
},
"vehicleLocationVisibility": {
"remainingStopCountThreshold": 5
},
}
```
路線折線和車輛位置指定不同的顯示選項
如果路線多邊形和車輛位置有不同的顯示選項,只有在兩者的顯示選項都符合時,車輛位置才會顯示。再次提醒,多邊形可見度取決於車輛的可見度規則:
- 一律可見:如果車輛位置也提供「一律可見」顯示選項,路線多邊形必須使用「一律可見」顯示選項。
- 永不顯示:如果車輛位置使用「永不顯示」顯示選項,路線多邊形必須使用「永不顯示」顯示選項。
以下提供範例:
"taskTrackingViewConfig": {
"routePolylinePointsVisibility": {
"remainingStopCountThreshold": 3
},
"vehicleLocationVisibility": {
"remainingDrivingDistanceMetersThreshold": 3000
},
}
在這個範例中,只有在剩餘停靠站數至少為 3 個且剩餘行駛距離至少為 3000 公尺時,系統才會顯示車輛位置。
工作瀏覽權限自訂範例
以下範例說明如何設定具有下列可見度規則的工作:
- 如果車輛距離 3 個停靠站,請顯示路線折線。
- 如果剩餘行駛距離短於 5000 公尺,就會顯示預估到達時間。
- 請勿顯示剩餘的停靠站數。
- 其他所有欄位都會保留預設的瀏覽權限,也就是在車輛距離任務 5 個停靠站範圍內時顯示。
如要瞭解 gRPC 或 REST,請參閱 TaskTrackingViewConfig
。
gRPC
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String TASK_ID = "task-8241890";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Task settings
String taskName = "providers/" + PROJECT_ID + "/tasks/" + TASK_ID;
Task task = Task.newBuilder()
.setName(taskName)
.setTaskTrackingViewConfig(
TaskTrackingViewConfig.newBuilder()
.setRoutePolylinePointsVisibility(
VisibilityOption.newBuilder().setRemainingStopCountThreshold(3))
.setEstimatedArrivalTimeVisibility(
VisibilityOption.newBuilder().remainingDrivingDistanceMetersThreshold(5000))
.setRemainingStopCountVisibility(
VisibilityOption.newBuilder().setNever(true)))
.build();
// Task request
UpdateTaskRequest updateTaskRequest =
UpdateTaskRequest.newBuilder() // No need for the header
.setTask(task)
.setUpdateMask(FieldMask.newBuilder().addPaths("taskTrackingViewConfig"))
.build();
try {
Task updatedTask = deliveryService.updateTask(updateTaskRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND:
break;
case PERMISSION_DENIED:
break;
}
return;
}
REST
如要使用 HTTP 設定工作追蹤檢視畫面的設定視窗,請呼叫 PATCH
,然後使用 updateMask
更新 taskTrackingViewConfig
參數:
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/tasks/<id>?updateMask=taskTrackingViewConfig
例如:
# Set JWT, PROJECT_ID, and TASK_ID in the local environment
curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/tasks/${TASK_ID}?updateMask=taskTrackingViewConfig" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}" \
--data-binary @- << EOM
{
"taskTrackingViewConfig": {
"routePolylinePointsVisibility": {
"remainingStopCountThreshold": 3
},
"estimatedArrivalTimeVisibility": {
"remainingDrivingDistanceMetersThreshold": 5000
},
"remainingStopCountVisibility": {
"never": true
}
}
}
EOM