Bu belgede, görev oluşturma ve kullanma konusunda bilgi sahibi olduğunuz varsayılır. Aşağıdaki yöntemlerle kargo görevlerinin nasıl yapılandırılacağıyla ilgili belirli örnekler sunar:
Bir kargo görevi için hedef zaman aralığını ayarlama: Görevin tamamlanması için zaman aralığını ayarlayın.
Görev görünürlüğünü özelleştirme: Görev etkinliklerinin müşterilere veya filo operatörlerine gösterilme görünürlüğünü özelleştirin.
Kargo görevleriyle ilgili alanlar hakkında ayrıntılı bilgi için Kargo görevleri oluşturma başlıklı makaleyi inceleyin. Mevcut görevlerle ilgili ek bilgileri güncellerken görevler için güncellediğiniz alanların yanı sıra görevin ilgili tanımlayıcısını da eklemeniz gerekir.
Hedef zaman aralığını ayarlama
Hedef zaman aralığı, görevin tamamlanması gereken TimeWindow'dur. Örneğin, teslimat alıcılarına bir teslimat zaman aralığı bildirirseniz bu zaman aralığını yakalamak ve uyarılar oluşturmak için görev hedef zaman aralığını kullanabilir veya geçmiş yolculuk performansını analiz etmek için bu aralığı kullanabilirsiniz.
Hedef zaman aralığı, başlangıç ve bitiş zamanından oluşur ve herhangi bir görev türünde ayarlanabilir. Hedeflenen zaman aralığı, yönlendirme davranışını etkilemez.
Aşağıdaki örneklerde, Java gRPC kitaplığı kullanılarak zaman aralığının nasıl ayarlanacağı veya UpdateTask
için nasıl HTTP REST isteği gönderileceği gösterilmektedir. Bu alanı görev oluşturma sırasında da ayarlayabilirsiniz.
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 kullanarak görev zaman aralığı ayarlamak için PATCH
işlevini çağırın ve targetTimeWindow
parametresini güncellemek için updateMask
işlevini kullanın:
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/tasks/<id>?updateMask=targetTimeWindow
Burada <id>, görev için benzersiz bir tanımlayıcıdır. İstek başlığında, Authorization alanı Bearer <token> değeriyle birlikte bulunmalıdır. <token>, Hizmet hesabı rolleri ve JSON Web Jetonları'nda açıklanan yönergelere göre sunucunuz tarafından verilir.
# 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
Görevin görünürlüğünü özelleştirme
Fleet Engine, varsayılan olarak görev etkinlikleriyle ilgili görünürlük sağlar. Bu etkinlikler, kargo alan müşterilere ve kargoları takip eden filo operatörlerine gösterilebilir. Örneğin, müşteriye paket teslimat durumu hakkında bildirim göndermeden önce kaç durak olduğunu belirtmek bu kapsamdadır. İşletme modelinize daha iyi uyacak şekilde bu bilgileri görev bazında özelleştirebilirsiniz.
Bu bölümde, haritada izlenen nesnelerin görünürlük kuralları açıklanmaktadır. Bu kurallar iki nesne kategorisi için geçerlidir:
- Konum işaretçisi görünürlüğü
- Çoklu çizgiler ve tahmini varış zamanı gibi etkin araç görevleriyle ilgili görev verilerinin görünürlüğü
Konum işaretçisi görünürlük kuralları
Fleet Engine, teslimatın durumundan bağımsız olarak, haritada gösterilen kargo teslimat konumunun yer işaretçilerini görüntüler.
Görev verilerinin görünürlüğüyle ilgili kurallar
Bu bölümde, görev verileri için geçerli olan varsayılan görünürlük kuralları açıklanmaktadır. Yalnızca etkin araç görevlerini özelleştirebilirsiniz. Bu nedenle, yalnızca teslim alma ve bırakma görevleri için özelleştirilmiş görünürlük kuralları uygulanabilir.
Aşağıdaki görevler özelleştirilemez:
- Planlanmış duraklar
- Müsaitlik durumu görevleri
- Etkin olmayan araç görevleri
Kullanılamazlık görevlerinin görünürlük kuralları
Varsayılan olarak, izlenen göreve en az bir müsait olmama görevi atanmışsa araç haritada görünmez. Örneğin, sürücü mola veriyorsa veya araç, takip edilen gönderiye giderken yakıt ikmali yapıyorsa. Tahmini varış zamanı ve tahmini görev tamamlama süresi gösterilmeye devam eder. Bu kuralı özelleştiremezsiniz.
Etkin araç görevlerinin görünürlüğü
TaskTrackingInfo
nesnesi, Kargo Takibi Kitaplığı'nı kullanarak görünür hale getirebileceğiniz bir dizi veri öğesi sağlar. Varsayılan olarak, bu alanlar görev araca atandığında ve araç görevden 5 durak uzaktayken görünür. Görünürlük, görev tamamlandığında veya iptal edildiğinde sona erer.
Fleet Engine'de görevi oluştururken veya güncellerken bir görevde TaskTrackingViewConfig
simgesini ayarlayarak görünürlük yapılandırmasını görev bazında özelleştirebilirsiniz. Bu, tek tek veri öğelerinin kullanılabilir olması için kurallar oluşturur.
Aşağıdaki tabloda, görünürlük kurallarını uygulayabileceğiniz alanlar gösterilmektedir.
Görünürlük kuralları için araç görevi alanları |
---|
|
Bu tabloda, yukarıda listelenen alanlar için kullanılabilen görünürlük seçenekleri gösterilmektedir.
Görünürlük seçenekleri |
---|
|
Rota çoklu çizgileri ve araç konumu görünürlüğü kuralları
İzlenen bir rotada, rota çoklu çizgilerinin görünürlüğü aracın görünürlüğüne bağlıdır. Aracın görünmediği etkin bir rotada rota çoklu çizgi görünüyorsa araç konumu, görünür çoklu çizginin sonundan yine de tahmin edilebilir. Bu nedenle, rota çoklu çizgi görünürlüğü, araç görünürlüğü kadar kısıtlayıcı veya daha kısıtlayıcı olmalıdır.
Geçerli bir rota çoklu çizgileri / araç konumu görünürlüğü kombinasyonu sağlamak için aşağıdaki kurallara uyun.
Rota çoklu çizgileri ve araç konumu, aynı görünürlük seçeneklerini belirtir.
Bu senaryoda, hem çoklu çizgi hem de araç konumu aynı seçenekleri belirler. Bu seçenekler şunlardır:
- kalan durak sayısı
- tahmini varış zamanına kadar olan süre
- kalan sürüş mesafesi
Kurallara uymak için rota çoklu çizgi görünürlüğü değeri, araç görünürlüğü için ayarlanan değerden daha küçük veya bu değere eşit olmalıdır. Bu örnekte, çoklu çizgi için kalan durak eşiği, araca belirtilen 5 değerinden daha düşük olan 3 olarak ayarlanmıştır. Bu nedenle, izlenen yolculuk görev konumundan 5 durak uzaklaştığında araç görünür ancak yolculuk 3 durak uzaklaşana kadar bu aracın rotası görünmez.
```js
"taskTrackingViewConfig": {
"routePolylinePointsVisibility": {
"remainingStopCountThreshold": 3
},
"vehicleLocationVisibility": {
"remainingStopCountThreshold": 5
},
}
```
Rota çoklu çizgileri ve araç konumu, farklı görünürlük seçeneklerini belirtir.
Rota çoklu çizgileri ve araç konumu farklı görünürlük seçeneklerine sahip olduğunda araç konumu yalnızca görünürlük seçeneklerinin her ikisi de karşılandığında görünür. Çoklu çizgi görünürlüğü, aracın görünürlük kurallarına tabidir:
- Her zaman görünür: Bir rota çoklu çizgisi, araç konumu da aynı her zaman görünür görünürlük seçeneğini sağladığında her zaman görünür görünürlük seçeneğini kullanmalıdır.
- Asla görünür değil: Araç konumu asla görünür değil görünürlük seçeneğini kullandığında rota çoklu çizgisi asla görünür değil görünürlük seçeneğini kullanmalıdır.
Örnek:
"taskTrackingViewConfig": {
"routePolylinePointsVisibility": {
"remainingStopCountThreshold": 3
},
"vehicleLocationVisibility": {
"remainingDrivingDistanceMetersThreshold": 3000
},
}
Bu örnekte, araç konumu yalnızca kalan durak sayısı en az 3 VE kalan sürüş mesafesi en az 3.000 metre olduğunda görünür.
Örnek görev görünürlüğü özelleştirmesi
Aşağıdaki örneklerde, aşağıdaki görünürlük kurallarına sahip bir görevin nasıl ayarlanacağı gösterilmektedir:
- Araç 3 durak içindeyse rota çoklu çizgilerini göster.
- Kalan sürüş mesafesi 5.000 metreden kısaysa tahmini varış zamanını gösterin.
- Kalan durak sayısı hiçbir zaman gösterilmez.
- Diğer her alan, araç göreve 5 durak mesafede olduğunda gösterilme görünürlüğünü korur.
gRPC veya REST için TaskTrackingViewConfig
bölümüne bakın.
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
Görev izleme görünümü yapılandırma penceresini HTTP kullanarak ayarlamak için PATCH
işlevini çağırın ve taskTrackingViewConfig
parametresini güncellemek için updateMask
işlevini kullanın:
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/tasks/<id>?updateMask=taskTrackingViewConfig
Örneğin:
# 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