Verwenden Sie den Endpunkt CreateVehicle
mit CreateVehicleRequest
, um ein Fahrzeug in Fleet Engine für On-Demand-Fahrten zu erstellen. Für diesen Endpunkt ist ein Konto mit der Rolle Fleet Engine On-demand Admin erforderlich.
Felder für On-Demand-Fahrzeuge
Wenn Sie Fahrzeuge für On-Demand-Fahrten erstellen, müssen Sie erforderliche Felder festlegen. Sie sollten auch wissen, wie sich bestimmte Fahrzeugfelder auf andere Funktionen in Fleet Engine auswirken. Weitere Informationen finden Sie unter Fahrzeugfelder aktualisieren.
Pflichtfelder für On-Demand-Fahrten
vehicle_state
: Standardmäßig auf „unknown“ gesetzt, sollte aber auf „ONLINE“ oder „OFFLINE“ gesetzt werden. Informationen zum Festlegen des Felds „vehicleState“ finden Sie unter Fahrzeugfelder aktualisieren.supported_trip_types
: Standardmäßig auf „unknown“ festgelegt, sollte aber auf „SHARED“, „EXCLUSIVE“ oder beides gesetzt werden. Weitere Informationen finden Sie im Leitfaden On-demand-Fahrten unter Fahrtentypen.maximum_capacity
: Die Anzahl der Personen, die das Fahrzeug befördern kann, ohne den Fahrer (per Definition).vehicle_type
: Die Werte sindAUTO
,TAXI
,TRUCK
,TWO_WHEELER
,BICYCLE
oderPEDESTRIAN
. Kann verwendet werden, um Fahrzeuge bei der Fahrzeugsuche zu filtern. Das wirkt sich auch auf die Berechnung der voraussichtlichen Ankunftszeit und der Route aus. Fleet Engine bietet Routen und Reiseberechnungen, die dem Verkehrsmittel entsprechen, basierend auf den folgenden Fahrzeugtypgruppen:AUTO
,TAXI
oderTRUCK
: z. B. Autobahnen.TWO_WHEELER
: So werden beispielsweise keine Routen zurückgegeben, auf denen Zweiräder nicht erlaubt sind.BICYCLE
: z. B. Radwege.PEDESTRIAN
: z. B. Brücken und Gehwege, die nur für Fußgänger bestimmt sind.
Andere Felder
Informationen zu anderen Feldern, die Sie beim Erstellen eines Fahrzeugs festlegen können, finden Sie unter Fahrzeugfelder aktualisieren.
Beispiel für die Erstellung eines Fahrzeugs
Der von CreateVehicle
zurückgegebene Wert ist die erstellte Vehicle
-Entität.
Java
static final String PROJECT_ID = "project-id";
VehicleServiceBlockingStub vehicleService =
VehicleService.newBlockingStub(channel);
String parent = "providers/" + PROJECT_ID;
Vehicle vehicle = Vehicle.newBuilder()
.setVehicleState(VehicleState.OFFLINE) // Initial state
.addSupportedTripTypes(TripType.EXCLUSIVE)
.setMaximumCapacity(4)
.setVehicleType(VehicleType.newBuilder().setCategory(VehicleType.Category.AUTO))
.addAttributes(VehicleAttribute.newBuilder()
.setKey("on_trip").setValue("false")) // Opaque to the Fleet Engine
// Add .setBackToBackEnabled(true) to make this vehicle eligible for trip
// matching while even if it is on a trip. By default this is disabled.
.build();
CreateVehicleRequest createVehicleRequest =
CreateVehicleRequest.newBuilder() // no need for the header
.setParent(parent)
.setVehicleId("vid-8241890") // Vehicle ID assigned by Rideshare or Delivery Provider
.setVehicle(vehicle) // Initial state
.build();
// In this case, the Vehicle is being created in the OFFLINE state and
// no initial position is being provided. When the Driver App checks
// in with the Rideshare or Delivery Provider, the state can be set to ONLINE and
// the Driver App will update the Vehicle Location.
try {
Vehicle createdVehicle =
vehicleService.createVehicle(createVehicleRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case ALREADY_EXISTS:
break;
case PERMISSION_DENIED:
break;
}
return;
}
// If no Exception, Vehicle created successfully.
REST
curl -X POST \
"https://fleetengine.googleapis.com/v1/providers/project-id/vehicles?vehicleId=vid-8241890" \
-H "Authorization: Bearer $JWT" \
-H "Content-Type: application/json" \
--data-binary @- << EOM
{
"vehicleState": "OFFLINE",
"supportedTripTypes": ["EXCLUSIVE"],
"maximumCapacity": 4,
"vehicleType": {"category": "AUTO"},
"attributes": [{"key": "on_trip", "value": "false"}]
}
EOM
Weitere Informationen finden Sie in der providers.vehicles.create.