גישות
כדי לקבל את הביצועים הטובים ביותר מ-Fleet Engine, צריך לספק לו עדכונים של מיקום הרכב לפחות פעם בדקה לכל היותר פעם ב-5 שניות. אפשר לשלוח את העדכונים האלה באחת מהדרכים הבאות:
- שימוש ב-Driver SDK: האפשרות הפשוטה ביותר.
- שימוש בקוד בהתאמה אישית: שימושי אם המיקומים מועברים דרך הקצה העורפי, או אם אתם משתמשים במכשירים שאינם Android או iOS. במסמך הזה נסביר על הגישה הזו.
לא משנה איך אתם מספקים עדכונים לגבי מיקום הרכב, הקצה העורפי שלכם אחראי לעדכן את Fleet Engine כשרכב מסירה בדרך לתחנה וכשהוא מגיע לתחנה. כולל המחסן עצמו. מערכת Fleet Engine לא מזהה את האירועים האלה באופן אוטומטי.
דוגמאות לעדכון מיקום הרכב
אפשר להשתמש בספריית Java gRPC כדי לעדכן את המיקום של רכב ב-Fleet Engine, או להשתמש ב-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
פרטי הבקשה
גוף הבקשה חייב לכלול ישות DeliveryVehicle
שמציינת את השדות הבאים:
שדות חובה:
שדה ערך lastLocation.supplementalLocation
המיקום של הרכב. lastLocation.supplementalLocationTime
חותמת הזמן האחרונה שידועה שבה הרכב היה במיקום הזה. lastLocation.supplementalLocationSensor
צריך לאכלס אותו ב- CUSTOMER_SUPPLIED_LOCATION
.שדות אופציונליים:
שדה ערך lastLocation.supplementalLocationAccuracy
הדיוק של המיקום שצוין, במטרים.
# 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