モビリティ オンデマンド ルート サービスの一環として、SearchVehicles
メソッドを使用して近くの車両を見つけることができます。
SearchVehicles
メソッドを使用すると、特定の乗車リクエストや配達リクエストに最適な、近くで利用可能な車両を消費者向けモバイルアプリで見つけることができます。SearchVehicles
API は、リクエストされたルートの属性と一致する車両のランク付けされたリストを返します。順位は、指定した順序(到着予定時刻、距離、集荷場所からの直線距離)で並べ替えられます。
検索属性 | 車両属性 |
---|---|
|
|
SearchVehicles
メソッドを使用する
SearchVehicles
を使用する一般的な手順は次のとおりです。
- 割り当てるルートに基づいて
SearchVehiclesRequest
を作成します。 - 作成したリクエストを使用して
SearchVehicles
API(vehicleService.searchVehicles
)を呼び出します。 - API から返された
SearchVehicleResponse
を処理します。
SearchVehiclesRequest フィールド
SearchVehiclesRequest
を作成するには、次の必須属性フィールドを使用します。
フィールド | 説明 |
---|---|
親 | 必須。providers/{provider} の形式にする必要があります。プロバイダは、この呼び出しを行うサービス アカウントがメンバーである Google Cloud プロジェクトのプロジェクト ID にする必要があります。 |
vehicle_types | 必須。リクエストされた車両の種類(AUTO、TWO_WHEELER、TAXI、TRUCK、BICYCLE、PEDESTRIAN)。 |
trip_types | 必須。排他的(ドライバーごとに一度に 1 件のアクティブなルート)または共有(ドライバーごとに一度に 1 件以上のルート)のいずれかです。 |
minimum_capacity | 必須。新しいルート(乗客または配達)で車両に残されている最低限の容量。 |
pickup_point | 必須。乗車場所の緯度/経度の座標。 |
dropoff_point | 省略可。ルートの降車地点の緯度/経度の座標。trip_types に TripType.SHARED が含まれている場合、このフィールドは必須です。 |
pickup_radius_meters | 必須。集荷地点から車両の検索範囲の半径(メートル単位)。 |
order_by | 必須。次のいずれかの方法で車両を注文します。
|
count | 必須。返される車両の最大数(1 ~ 50)。 |
フィルタ | (省略可)車両の検索時に適用するフィルタクエリ。 |
maximum_staleness | (省略可)指定した期間内に Fleet Engine に位置情報の更新を送信した車両のみを検索対象にします。このフィールドが設定されていない場合、サーバーはデフォルト値として 5 分を指定します。 |
SearchVehicleRequest フィールドの完全なセットについては、リファレンス ドキュメントをご覧ください。
SearchVehiclesRequest のシナリオ
このセクションでは、SearchVehiclesRequest
の作成方法の例を示します。
たとえば、レストラン X で乗車を希望するお客様がいて、4 台の車両があるとします。
- 車両 1: レストラン X から 3,500 m 離れている。
- 車両 2: レストラン X から 100 m 離れた場所にあり、A と B の場所での乗車と下車を含むアクティブなルートです。
- 車両 3: レストラン X から 200 m 離れており、残りの 1 件の配送先が非常に遠い。
- 車両 4: レストラン X から 1,000 m 離れた場所。
次に、返された車両によるさまざまなリクエストを示します。
車両 4 を返します
Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA
車両 3 と 4 を返します
Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA, is_back_to_back enabled
車両 2、3、4 を返します。
Pickup at RestaurantX, radius = 1200m, order by PICKUP_POINT_ETA, current_trips_present = ALL
SearchVehiclesResponse フィールド
SearchVehiclesResponse
は、SearchVehiclesRequest
で指定された order_by 属性でランク付けされた VehicleMatch
エンティティのリストで構成されます。各 VehicleMatch
エンティティには次のフィールドがあります。
フィールド | 説明 |
---|---|
車両 | Vehicle オブジェクト(vehicle_id 属性と Vehicle 属性を含む)。 |
vehicle_pickup_eta | 新しい乗車の乗車地点における車両の到着予定時刻。これは運転での所要時間です。 |
vehicle_pickup_distance_meter | 車両と新しい乗車地点との間の距離(メートル単位)。 |
vehicle_pickup_straight_line_distance_meter | 車両と新しい乗車の乗車地点との直線距離(メートル単位)。 |
vehicle_dropoff_eta | 新しい乗車の集合場所での車両の到着予定時間のタイムスタンプ。なお、この ETA は運転時の ETA です。 |
vehicle_trips_waypoints | 現在車両に割り当てられているアクティブなルートの残りのウェイポイントのリスト(乗車地と降車地を含む)。 |
vehicle_match_type | 車両のルートタイプ(EXCLUSIVE、BACK_TO_BACK、CARPOOL、CARPOOL_BACK_TO_BACK)。 |
VehicleMatch
フィールドの一覧については、以下をご覧ください。
VehicleMatch message
(gRPC)VehicleMatch resource
(REST)
フィルタクエリを使用する
SearchVehicles
と ListVehicles
は、フィルタクエリを使用して車両属性のフィルタリングをサポートしています。
フィルタクエリは、車両のカスタム属性のフィルタリングのみをサポートし、他のフィールドには使用できません。minimum_capacity
や vehicle_types
などの他のフィールド条件を含む検索で使用する場合、フィルタクエリは AND
句として機能します。
たとえば、最低乗車人数が 6 人の車を検索し、ペット可などの attributes
をフィルタすると、ペット可で 6 人以上の乗車が可能な車のみが条件に一致して返されます。
フィルタクエリの構文については、AIP-160 の例をご覧ください。車両属性の作成について詳しくは、車両フィールドを更新するガイドの車両属性フィールドをご覧ください。
SearchVehicles の例
次の例は、Java gRPC ライブラリを使用して SearchVehicles
API を使用する方法を示しています。
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.