Z tego przewodnika dowiesz się, jak pobierać dane o przejazdach bezpośrednio z Fleet Engine, zamiast korzystać z pakietu Consumer SDK. Możesz użyć tego podejścia, aby mieć większą kontrolę nad wrażeniami użytkowników, a jednocześnie korzystać z dokładnych i aktualizowanych w czasie rzeczywistym informacji o lokalizacji pojazdu, szacowanym czasie przyjazdu i wyznaczaniu trasy w Fleet Engine.
Szczegółowe informacje o korzystaniu z pakietu SDK dla konsumentów znajdziesz w artykule Udostępnianie przejazdów na żądanie.
Pobieranie informacji o podróży
Aby pobrać informacje o podróży bezpośrednio z Fleet Engine, wywołaj metodę GetTrip, określając widok JOURNEY_SHARING_V1S. Zobacz dokumentację RPC lub REST.
Serwer zwykle odpytuje usługę dotyczącą przejazdów o stan każdego przejazdu, gdy pasażer aktywnie monitoruje postępy pojazdu. Aktualizacje lokalizacji pojazdu zwykle następują co 10 sekund, a system powinien odpytywać z tą samą częstotliwością. Pole Trip.last_location.update_time można monitorować, aby sprawdzić, czy od poprzedniego wywołania funkcji GetTrip wprowadzono jakieś zmiany.
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);
Obiekt Trip zawiera te pola wypełnione najnowszymi dostępnymi informacjami o przejazdzie:
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 |
|
Pobieranie pozostałych punktów trasy
Obiekt Trip zawiera pole powtarzane typu TripWaypoint. To pole zawiera wszystkie punkty pośrednie, przez które pojazd musi przejechać w kolejności przed ostatecznym miejscem docelowym tej podróży. Określenie widoku udostępniania trasy powoduje, że Fleet Engine umieszcza zaktualizowane informacje w polu remaining_waypoints[0]
TripWaypoint. W innych widokach, które nie są widokami udostępniania trasy, ten punkt pośredni zwykle nie odzwierciedla najnowszej pozycji przypisanego pojazdu. Więcej informacji znajdziesz w dokumentacji RPC lub REST.
Więcej informacji znajdziesz w sekcji Stan przejazdu i pozostałe punkty trasy pojazdu w przewodniku Wprowadzenie do przejazdów.
Oto przykład pola remaining_waypoints w przypadku wycieczki A:
| |||||||||||||||||||||
| |||||||||||||||||||||
W przypadku podróży z przesiadkami i wspólnych przejazdów lista może zawierać punkty pośrednie z innych podróży, które należy pokonać przed tą podróżą. Rozważmy na przykład sytuację, w której przejazd B jest przypisany do tego samego pojazdu co przejazd A. Pole
remaining_waypoints w przypadku przejazdu A zostanie wypełnione w ten sposób:
Większość pól została pominięta ze względu na zwięzłość, ale byłyby one wypełnione zgodnie z poprzednim przykładem.
| [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 |
Pole remaining_waypoint w przypadku przejazdu B zostanie wypełnione w podobny sposób, ale będą w nim tylko 3 pierwsze wpisy, ponieważ punkt docelowy przejazdu A nie jest częścią trasy przejazdu B.