Pendekatan
Untuk performa terbaik dengan Fleet Engine, sediakan aliran data kendaraan pembaruan lokasi setidaknya sekali setiap menit dan paling banyak sekali setiap 5 detik. Gunakan salah satu cara berikut untuk memberikan pembaruan ini:
- Gunakan Driver SDK: Opsi paling sederhana.
- Gunakan kode kustom: berguna jika lokasi direlai melalui backend Anda, atau jika Anda menggunakan perangkat selain Android atau iOS. Dokumen ini membahas tentang pendekatan.
Terlepas dari cara Anda memberikan pembaruan lokasi kendaraan, backend Anda bertanggung jawab untuk memperbarui Fleet Engine saat kendaraan pengiriman sedang dalam perjalanan ke dan saat tiba di perhentian. Hal ini termasuk depot itu sendiri. Mesin Fleet tidak mendeteksi kejadian ini secara otomatis.
Memperbarui contoh lokasi kendaraan
Anda dapat menggunakan library gRPC Java untuk memperbarui lokasi kendaraan di Fleet Compute Engine, atau menggunakan REST.
Java
static final String PROJECT_ID = "my-delivery-co-gcp-project";
static final String VEHICLE_ID = "vehicle-8241890";
DeliveryServiceBlockingStub deliveryService =
DeliveryServiceGrpc.newBlockingStub(channel);
// Vehicle settings
String vehicleName = "providers/" + PROJECT_ID + "/deliveryVehicles/" + VEHICLE_ID;
DeliveryVehicle myDeliveryVehicle = DeliveryVehicle.newBuilder()
.setLastLocation(DeliveryVehicleLocation.newBuilder()
.setSupplementalLocation(LatLng.newBuilder()
.setLatitude(37.3382)
.setLongitude(121.8863))
.setSupplementalLocationTime(now())
.setSupplementalLocationSensor(DeliveryVehicleLocationSensor.CUSTOMER_SUPPLIED_LOCATION)
.setSupplementalLocationAccuracy(DoubleValue.of(15.0))) // Optional
.build();
// DeliveryVehicle request
UpdateDeliveryVehicleRequest updateDeliveryVehicleRequest =
UpdateDeliveryVehicleRequest.newBuilder() // No need for the header
.setName(vehicleName)
.setDeliveryVehicle(myDeliveryVehicle)
.setUpdateMask(FieldMask.newBuilder()
.addPaths("last_location"))
.build();
try {
DeliveryVehicle updatedDeliveryVehicle =
deliveryService.updateDeliveryVehicle(updateDeliveryVehicleRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND:
break;
case PERMISSION_DENIED:
break;
}
return;
}
REST
PATCH https://fleetengine.googleapis.com/v1/providers/<project_id>/deliveryVehicles/<id>?updateMask=last_location
Detail permintaan
Isi permintaan harus berisi entity DeliveryVehicle
yang menentukan
kolom sebagai berikut:
Kolom wajib diisi:
Kolom Nilai lastLocation.supplementalLocation
Lokasi kendaraan. lastLocation.supplementalLocationTime
Stempel waktu terakhir yang diketahui saat kendaraan berada di lokasi ini. lastLocation.supplementalLocationSensor
Harus diisi dengan CUSTOMER_SUPPLIED_LOCATION
.Kolom opsional:
Kolom Nilai lastLocation.supplementalLocationAccuracy
Akurasi lokasi yang diberikan, dalam meter.
# Set JWT, PROJECT_ID, VEHICLE_ID, TASK1_ID, and TASK2_ID in the local
# environment
curl -X PATCH "https://fleetengine.googleapis.com/v1/providers/${PROJECT_ID}/deliveryVehicles/${VEHICLE_ID}?updateMask=remainingVehicleJourneySegments" \
-H "Content-type: application/json" \
-H "Authorization: Bearer ${JWT}" \
--data-binary @- << EOM
{
"lastLocation": {
"supplementalLocation": {"latitude": 12.1, "longitude": 14.5},
"supplementalLocationTime": "$(date -u --iso-8601=seconds)",
"supplementalLocationSensor": "CUSTOMER_SUPPLIED_LOCATION",
"supplementalLocationAccuracy": 15
}
}
EOM