Modifier la position d'un véhicule

Pour obtenir les meilleures performances avec Fleet Engine, fournissez-lui un flux de mises à jour de la position des véhicules. Pour fournir ces informations, vous pouvez procéder de l'une des deux manières suivantes :

  1. Utilisez le Driver SDK : il s'agit de l'option la plus simple. Consultez la documentation du Driver SDK pour Android ou iOS.
  2. Utiliser un code personnalisé : utile si les positions sont relayées par votre backend ou si vous utilisez des appareils autres qu'Android ou iOS. Ce guide décrit cette approche.

Si vous n'utilisez pas le Driver SDK pour mettre à jour la position du véhicule, vous pouvez appeler directement Fleet Engine avec la position du véhicule. Pour tout véhicule actif, Fleet Engine s'attend à recevoir une mise à jour de la position au moins une fois par minute et au maximum une fois toutes les cinq secondes. Ces mises à jour ne nécessitent que les droits d'utilisateur du SDK pilote Fleet Engine.

Exemple de mise à jour de la position du véhicule

Java

static final String PROJECT_ID = "project-id";
static final String VEHICLE_ID = "vid-8241890";

VehicleServiceBlockingStub vehicleService = VehicleService.newBlockingStub(channel);

String vehicleName = "providers/" + PROJECT_ID + "/vehicles/" + VEHICLE_ID;
Vehicle updatedVehicle = Vehicle.newBuilder()
    .setLastLocation(VehicleLocation.newBuilder()
        .setSupplementalLocation(LatLng.newBuilder()
            .setLatitude(37.3382)
            .setLongitude(121.8863))
        .setSupplementalLocationTime(now())
        .setSupplementalLocationSensor(LocationSensor.CUSTOMER_SUPPLIED_LOCATION)
        .setSupplementalLocationAccuracy(DoubleValue.of(15.0)))  // Optional
    .build();

UpdateVehicleRequest updateVehicleRequest = UpdateVehicleRequest.newBuilder()
    .setName(vehicleName)
    .setVehicle(updatedVehicle)
    .setUpdateMask(FieldMask.newBuilder()
        .addPaths("last_location"))
    .build();

try {
  Vehicle updatedVehicle =
      vehicleService.updateVehicle(updateVehicleRequest);
} catch (StatusRuntimeException e) {
  Status s = e.getStatus();
  switch (s.getCode()) {
    case NOT_FOUND:
      // Most implementations will call CreateVehicle in this case
      break;
    case PERMISSION_DENIED:
      break;
  }
  return;
}
// If no Exception, Vehicle updated successfully.

REST

curl -X PUT \
  "https://fleetengine.googleapis.com/v1/providers/project-id/vehicles/vid-8241890?updateMask=last_location" \
  -H "Authorization: Bearer $JWT" \
  -H "Content-Type: application/json" \
  --data-binary @- << EOM
{
    "supplementalLocation": {"latitude": 12.1, "longitude": 14.5},
    "supplementalLocationTime": "$(date -u --iso-8601=seconds)",
    "supplementalLocationSensor": "CUSTOMER_SUPPLIED_LOCATION",
    "supplementalLocationAccuracy": 15
}
EOM

Consultez la référence providers.vehicles.update.

Étape suivante