En este documento, se describe cómo crear un viaje de destino único, establecer la campos y asignarlos a un vehículo para completar. Se da por sentado que configuraste Fleet Engine y que creaste vehículos, tienes una app para conductores que funciona y, de manera opcional, una app para consumidores. Consulta las siguientes guías relacionadas para ello:
Conceptos básicos sobre la creación de viajes
En esta sección, se describen los detalles de la solicitud necesarios para crear un viaje en Fleet Engine. Se emite una solicitud de creación con gRPC y REST.
Campos de viaje
Usa los siguientes campos para crear un viaje en Fleet Engine. Puedes usar diferentes campos para los diferentes tipos de viajes: uno o varios destinos, consecutivos o de reducción compartida. Tú puedes proporcionar los campos opcionales cuando crees el viaje o puedes configurarlos más adelante cuando actualices el viaje.
Nombre | ¿Obligatorio? | Descripción |
---|---|---|
elemento superior | Sí | Es una cadena que incluye el ID del proyecto. Este ID debe ser el mismo que se usa en toda la integración de Fleet Engine, con los mismos roles de cuenta de servicio. |
trip_id | Sí | Es una cadena que creas para identificar este viaje de forma exclusiva. Los IDs de viaje tienen ciertas restricciones, como se indica en la referencia. |
trip_type | Sí | Establece los siguientes valores de TripType para el tipo de viaje que crearás:
|
pickup_point | Sí | El punto de origen del viaje. |
Destinos intermedios | Sí | Solo viajes con varios destinos: Es la lista de destinos intermedios que el conductor visita.
partida y destino. Al igual que con |
vehicle_waypoints | Sí | Solo viajes de reducción compartida: Este campo admite la intercalación de los puntos de referencia desde varios viajes.
Contiene todos los puntos de referencia restantes para el vehículo asignado, además de
como puntos de referencia de partida y llegada para este viaje. Puedes configurar este campo
llamando a |
number_of_passengers | No | La cantidad de pasajeros en el viaje. |
dropoff_point | No | El destino del viaje. |
vehicle_id | No | El ID del vehículo asignado al viaje. |
Ejemplo: viaje con un solo destino
En el siguiente ejemplo, se muestra cómo crear un viaje a la Gran Indonesia
East Mall. El viaje incluye dos pasajeros, es exclusivo y su estado es
NEW
El provider_id
del viaje debe ser el mismo que el de Google Cloud.
el ID del proyecto. En los ejemplos, se muestra un proyecto de Google Cloud con el ID del proyecto
my-rideshare-co-gcp-project
Este proyecto también debe incluir una cuenta de servicio para llamar a Fleet Engine. Consulta Funciones de cuentas de servicio para obtener más detalles.
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
TripServiceBlockingStub tripService = TripService.newBlockingStub(channel);
// Trip initial settings.
String parent = "providers/" + PROJECT_ID;
Trip trip = Trip.newBuilder()
.setTripType(TripType.EXCLUSIVE) // Use TripType.SHARED for carpooling.
.setPickupPoint( // Grand Indonesia East Mall.
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.195139).setLongitude(106.820826)))
.setNumberOfPassengers(2)
// Provide the drop-off point if available.
.setDropoffPoint(
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder()
.setLatitude(-6.1275).setLongitude(106.6537)))
.build();
// Create trip request
CreateTripRequest createTripRequest = CreateTripRequest.newBuilder()
.setParent(parent)
.setTripId("trip-8241890") // Trip ID assigned by the provider.
.setTrip(trip) // The initial state is NEW.
.build();
// Error handling.
try {
Trip createdTrip = tripService.createTrip(createTripRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case ALREADY_EXISTS:
break;
case PERMISSION_DENIED:
break;
}
return;
}