このガイドでは、Consumer SDK を使用する代わりに、Fleet Engine から直接ルートデータを取得する方法について説明します。この方法を使用すると、Fleet Engine の正確なリアルタイムの車両位置情報、到着予定時刻、ルーティングを活用しながら、エンドユーザー エクスペリエンスをより細かく制御できます。
Consumer SDK の使用方法については、オンデマンド ルートのルートを共有するをご覧ください。
ルート情報を取得する
Fleet Engine からルート情報を直接取得するには、JOURNEY_SHARING_V1S
ビューを指定して GetTrip
メソッドを呼び出します。RPC または REST のリファレンスをご覧ください。
通常、乗客が車両の進行状況を積極的にモニタリングしている間、サーバーは各ルートのステータスについてルート サービスにポーリングします。車両の位置情報の更新は通常 10 秒ごとに行われるため、システムも同じレートでポーリングする必要があります。Trip.last_location.update_time
フィールドをモニタリングして、GetTrip
の前の呼び出し以降に更新が行われたかどうかを確認できます。
static final String PROJECT_ID = "my-rideshare-co-gcp-project";
static final String TRIP_ID = "trip-A";
String tripName = "providers/" + PROJECT_ID + "/trips/" + TRIP_ID;
GetTripRequest getTripRequest =
GetTripRequest.newBuilder()
.setName(tripName)
.setView(JOURNEY_SHARING_V1S)
.build();
Trip trip = tripService.getTrip(getTripRequest);
生成された Trip
オブジェクトには、ルートの最新情報が次のフィールドに入力されます。
name |
trip_status |
remaining_waypoints |
vehicle_id |
trip_type |
last_location |
number_of_passengers |
pickup_point |
view (== JOURNEY_SHARING_V1S) |
actual_pickup_point |
intermediate_destinations |
intermediate_destination_index |
pickup_time |
intermediate_destinations_version |
dropoff_point |
actual_dropoff_point |
dropoff_time |
|
残りのルートのウェイポイントを取得する
Trip エンティティには、TripWaypoint
タイプの繰り返しフィールドが含まれています。このフィールドには、このルートの最終的な乗車降車地点に到達する前に車両が移動する必要があるすべてのウェイポイントが順番に含まれます。ルート共有ビューを指定すると、更新された情報が remaining_waypoints[0] TripWaypoint
に格納されます。ルート共有以外のビューでは、通常、そのウェイポイントには割り当てられた車両の最新の位置は反映されません。RPC または REST のリファレンスをご覧ください。
詳しくは、ルートの概要ガイドのルートのステータスと車両の残りのルート ポイントをご覧ください。
ルート A の remaining_waypoints
フィールドの例を次に示します。
| |||||||||||||||||||||
|
連続したルートや共有プーリング ルートの場合、このリストには、このルートより前に通過する他のルートのウェイポイントが含まれていることがあります。たとえば、ルート B がルート A と同じ車両に割り当てられている場合を考えてみましょう。トリップ A の remaining_waypoints
フィールドは次のように入力されます。簡潔にするため、ほとんどのフィールドを省略していますが、これらのフィールドは、前の例と一致するように入力されます。
[0] | trip_id = "trip_A" |
---|---|
waypoint_type = PICKUP_WAYPOINT_TYPE | |
[1] | trip_id = "trip_B" |
waypoint_type = PICKUP_WAYPOINT_TYPE | |
[2] | trip_id = "trip_B" |
waypoint_type = DROP_OFF_WAYPOINT_TYPE | |
[3] | trip_id = "trip_A" |
waypoint_type = DROP_OFF_WAYPOINT_TYPE |
ルート B の remaining_waypoint
フィールドも同様に入力されますが、ルート A の降車地はルート B のルートには含まれないため、最初の 3 つのエントリのみが存在します。