As part of the Mobility on-demand trip service, you can find nearby vehicles
by using the SearchVehicles
method.
The SearchVehicles
method lets you find available nearby vehicles in your
consumer mobile app who are best suited to a specific ride or a delivery
request. The SearchVehicles
API returns a ranked list of vehicles whose
attributes match the requested trip attributes. Ranking is ordered by your
choice of either ETA, distance, or straight line distance from the pickup point.
Search Attributes | Vehicle Attributes |
---|---|
|
|
Use the SearchVehicles
method
To use SearchVehicles
, follow this general process:
- Construct a
SearchVehiclesRequest
based on the trip to be assigned. - Call the
SearchVehicles
API (vehicleService.searchVehicles
) with the constructed request. - Process the
SearchVehicleResponse
returned from the API.
SearchVehiclesRequest fields
Use the following required attribute fields to construct a
SearchVehiclesRequest
:
Field | Description |
---|---|
parent | Required. Must be in the format providers/{provider}. The provider must be the Project ID of the Google Cloud Project of which the service account making this call is a member. |
vehicle_types | Required. Types of vehicles requested, either AUTO, TWO_WHEELER, TAXI, TRUCK, BICYCLE, or PEDESTRIAN. |
trip_types | Required. Either EXCLUSIVE (one active trip at a time per driver) or SHARED (one or multiple trips at a time per driver). |
minimum_capacity | Required. The minimum remaining capacity of the vehicle for a new trip, either for passengers or deliveries. |
pickup_point | Required. The pickup location of the trip in lat/long coordinates. |
dropoff_point | Optional. The drop-off location of the trip in lat/long coordinates. The field is required if trip_types contains TripType.SHARED. |
pickup_radius_meters | Required. The radius in meters of the vehicle search area from the pickup point. |
order_by | Required. Order vehicles by one the following:
|
count | Required. The maximum number of vehicles to return from 1 to 50. |
filter | Optional. A filter query to apply when searching vehicles. |
maximum_staleness | Optional. Restricts the search to only those vehicles that have sent location updates to Fleet Engine within the specified duration. If this field is not set, the server uses five minutes as the default value. |
Refer to the Reference documentation to see the full set of SearchVehicleRequest fields.
SearchVehiclesRequest scenarios
This section shows examples of how to construct a SearchVehiclesRequest
.
For example, suppose a customer wants to be picked up at RestaurantX, and you have four vehicles:
- Vehicle 1: 3500m away from RestaurantX.
- Vehicle 2: 100m away from RestaurantX with an active trip with a pickup and drop off at locations A and B.
- Vehicle 3: 200m away from RestaurantX with one remaining drop off very far away.
- Vehicle 4: 1000m away from RestaurantX.
The following displays various requests by the vehicle they return.
Returns Vehicle 4
Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA
Returns Vehicle 3 and 4
Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA, is_back_to_back enabled
Returns Vehicle 2, 3, and 4
Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA, current_trips_present = ALL
SearchVehiclesResponse fields
A SearchVehiclesResponse
consists of a list of VehicleMatch
entities, ranked
by the specified order_by attribute in the SearchVehiclesRequest
. Each
VehicleMatch
entity has the following fields:
Field | Description |
---|---|
vehicle | The Vehicle object, including the vehicle_id and Vehicle attributes. |
vehicle_pickup_eta | The vehicle's ETA at the pickup location of the new trip. This is the driving ETA. |
vehicle_pickup_distance_meter | The distance in meters between the vehicle and the pickup location of the new trip. |
vehicle_pickup_straight_line_distance_meter | The straight-line distance in meters between the vehicle and the pickup location of the new trip. |
vehicle_dropoff_eta | The Timestamp of the vehicle ETA at the pickup location of the new trip. Note that the ETA is the driving ETA. |
vehicle_trips_waypoints | A list of remaining waypoints, including pickup and drop-off points, for the active trips currently assigned to the vehicle. |
vehicle_match_type | The vehicle's trip type, either EXCLUSIVE, BACK_TO_BACK, CARPOOL, or CARPOOL_BACK_TO_BACK. |
For a complete list of VehicleMatch
fields, see:
VehicleMatch message
(gRPC)VehicleMatch resource
(REST)
Use filter queries
SearchVehicles
and ListVehicles
support filtering on vehicle attributes
using a filter query.
Filter queries ONLY support filtering on custom attributes for vehicles, and
cannot be used for other fields. When used in a search that includes other field
criteria, such as minimum_capacity
or vehicle_types
, the filter query
functions as an AND
clause.
For example, if you search for a vehicle that has a minimum capacity of 6 and
filter an attributes
such as pet-friendly, your criteria would return only
those vehicles that are both pet-friendly and can carry at least 6 passengers.
For filter query syntax, see AIP-160 for examples. For details on creating vehicle attributes, see Vehicle attributes field in the Update vehicle fields guide.
SearchVehicles Example
The following example shows how to use the SearchVehicles
API using the
Java gRPC library.
static final String PROJECT_ID = "project-id";
VehicleServiceBlockingStub vehicleService =
VehicleService.newBlockingStub(channel);
String parent = "providers/" + PROJECT_ID;
SearchVehiclesRequest searchVehiclesRequest = SearchVehiclesRequest.newBuilder()
.setParent(parent)
.setPickupPoint( // Grand Indonesia East Mall
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder().setLatitude(-6.195139).setLongitude(106.820826)))
.setDropoffPoint( // Balai Sidang Jkt Convention Center
TerminalLocation.newBuilder().setPoint(
LatLng.newBuilder().setLatitude(-6.213796).setLongitude(106.807195)))
.setPickupRadiusMeters(2000)
.setCount(10)
.setMinimumCapacity(2)
.addTripTypes(TripType.EXCLUSIVE)
.addVehicleTypes(VehicleType.newBuilder().setCategory(Category.AUTO).build())
.setCurrentTripsPresent(CurrentTripsPresent.ANY)
.setFilter("attributes.on_trip=\"false\"")
.setOrderBy(VehicleMatchOrder.PICKUP_POINT_ETA)
.build();
try {
SearchVehiclesResponse searchVehiclesResponse =
vehicleService.searchVehicles(searchVehiclesRequest);
} catch (StatusRuntimeException e) {
Status s = e.getStatus();
switch (s.getCode()) {
case NOT_FOUND:
break;
case PERMISSION_DENIED:
break;
}
return;
}
List<VehicleMatch> vehicleMatches =
searchVehicleResponse.getMatchesList();
// Each VehicleMatch contains a Vehicle entity and information about the
// distance and ETA to the pickup point and drop-off point.