Ta sekcja zawiera informacje o wersjach pakietu Consumer SDK na Androida.
Ogłoszenie: wstrzymanie obsługi poziomów API 23, 24 i 25
Zgodnie z zasadami dotyczącymi obsługi wersji mobilnego systemu operacyjnego w przypadku nadchodzących głównych wersji pakietu Consumer SDK na Androida przestaniemy obsługiwać Androida 6 i 7 (poziom interfejsu API 23, 24 i 25).
Wersje pakietu Consumer SDK na Androida wydawane od IV kwartału 2025 r. będą obsługiwać co najmniej Androida 8 (poziom API 26). Starsze wersje pakietu SDK nadal będą obsługiwać Androida 6 i 7.
Jeśli zależności nie określają numeru wersji, IDE wczyta najnowszą wersję pakietu SDK, a nowe kompilacje aplikacji nie będą obsługiwać Androida 6 i 7.
Określ wersję pakietu Consumer SDK na Androida w zależnościach kompilacji aplikacji, aby kontrolować, kiedy podnosisz minimalną obsługiwaną wersję systemu operacyjnego dla nowych wersji aplikacji.
3.2.0 (26 czerwca 2025 r.)
- Wewnętrzne ulepszenia logowania.
Zmiany zależności i konfiguracji
- Od wersji 3.2.0 pakietu Consumer SDK na Androida aplikacje muszą być uaktualnione do Kotlin 2.1.
Poprawki błędów
- W przypadku wewnętrznych decyzji dotyczących animacji używaj długości polilinii zamiast odległości w linii prostej.
3.1.0 (10 marca 2025 r.)
- Wewnętrzne ulepszenia logowania.
3.0.0 (6 grudnia 2024 r.)
Zmiany zależności i konfiguracji
- Od wersji 3.0.0 pakietu Consumer SDK na Androida aplikacje muszą przejść na Kotlin 2.0. Zapoznaj się z przewodnikiem migracji do pakietu Android Consumer SDK w wersji 3.0.
- Wartość targetSdk w przypadku pakietu SDK dla konsumentów to teraz Android 14 (interfejs API na poziomie 34). Jest to wymagane w przypadku wszystkich aplikacji wdrażanych w Sklepie Google Play od sierpnia 2024 r. Zobacz Wymagania Google Play dotyczące docelowego poziomu interfejsu API.
2.99.0 (25 listopada 2024 r.)
Poprawki błędów
- Naprawia błąd ANR, który występuje, gdy wykonanie funkcji
ConsumerApi.cleanUp()
trwa zbyt długo. Po zintegrowaniu wersji będziemy ją wdrażać stopniowo (zaczynając od 0%). - Rozwiązuje problem, w którym kierowcy otrzymywali błędy gRPC z kodem „INTERNAL” i komunikatem „Panic! To błąd!”. Po zintegrowaniu wersji będziemy ją wdrażać stopniowo (zaczynając od 0%).
2.3.0 (2 sierpnia 2024 r.)
Zmiany w interfejsie API
Dodaj obsługę definiowania stylów map w Google Cloud, która umożliwia tworzenie niestandardowych map drogowych dla użytkowników bez konieczności modyfikowania kodu aplikacji za każdym razem, gdy wprowadzasz zmianę stylu mapy. Więcej informacji znajdziesz w artykule Definiowanie stylów map w Google Cloud.
Dodaj metodę
getServerTimeMillis()
doVehicleLocation
, aby określić czas, w którym Fleet Engine otrzymał aktualizację lokalizacji.
2.2.0 (7 maja 2024 r.)
Zmiany w interfejsie API
- Dodano interfejs API obsługujący integrację z Jetpack Compose. To funkcja eksperymentalna. Aby dowiedzieć się więcej o integracji z Jetpack Compose, skontaktuj się z przedstawicielem.
2.1.0 (17 stycznia 2024 r.)
Poprawki błędów
- Naprawia błąd, który występuje, gdy pakiet SDK jest inicjowany więcej niż raz w cyklu życia aplikacji.
Zmiany w interfejsie API
- Wprowadza metodę pobierania instancji
GoogleMap
utworzonej przez pakiet SDK (ConsumerGoogleMap.getGoogleMap()
). - Wprowadza interfejs API do pobierania instancji
Marker
utworzonych przez pakiet SDK w celu reprezentowania pojazdu (ConsumerController.getConsumerMarker()
). - Wprowadzamy interfejs API do otrzymywania prognozowanych aktualizacji klienta dotyczących czasu i odległości podczas udostępniania podróży (
ProjectedRouteEta
).
1.99.2 (3 listopada 2023 r.)
Naprawiono błąd powodujący awarię, gdy pakiet SDK jest inicjowany z procesu zdalnego, oddzielonego od aplikacji.
Rozwiązaliśmy problem z awarią, która występuje podczas wykonywania animacji kamery, gdy nie ma wystarczającej ilości miejsca w pionie lub w poziomie na dopełnienie. Występuje to tylko w przypadku najnowszego renderowania map.
Rozwiązanie problemu polegającego na tym, że pierwszy odcinek podróży w obie strony jest przycinany, gdy drugi odcinek przebiega tą samą drogą.
Problemy
- Metoda
ConsumerApi.initialize()
zgłasza wyjątek, jeśli zostanie wywołana, gdy instancja interfejsu API już istnieje. Aby obejść ten problem, najpierw wywołaj funkcjęConsumerApi.getInstance()
i oceń zwróconą wartośćTask
, aby sprawdzić, czy instancja interfejsu API już istnieje.
2.0.0 (15 września 2023 r.)
Ogłoszenie: zmiany powodujące niezgodność
Wymagany minimalny poziom interfejsu API został zmieniony z 21 na 23.
Aktualizuje wymagania dotyczące wersji pakietu Maps SDK z 17.0.0 na 18.1.0.
Minimalna wymagana wersja biblioteki standardowej Kotlin została zaktualizowana z 1.6.10 na 1.9.0.
Aktualizowanie wersji zależności Usług Google Play
Minimalna wymagana wersja biblioteki play-services-base została zaktualizowana z 18.0.1 do 18.2.0.
Zaktualizowano minimalną wymaganą wersję biblioteki play-services-basement z 18.0.0 do 18.2.0
Zaktualizowano minimalną wymaganą wersję biblioteki play-services-location z 17.0.0 do 21.0.1
Minimalna wymagana wersja biblioteki play-services-tasks została zaktualizowana z v18.0.1 do v18.0.2
Dodaje bibliotekę androidx.room:room-runtime z ustawionym minimalnym wymaganiem dotyczącym wersji na v2.5.2
Zaktualizuj wersje tych zależności:
Wymagania dotyczące minimalnej wersji biblioteki android-maps-utils zostały zaktualizowane z v0.4.2 do v3.5.2.
Minimalna wersja com.google.android.datatransport:transport-backend-cct została zmieniona z 3.0.0 na 3.1.9
Wymagania dotyczące minimalnej wersji com.google.android.datatransport:transport-runtime zostały zaktualizowane z 3.0.1 do 3.1.9
Minimalna wymagana wersja androidx.lifecycle:lifecycle-extensions została zaktualizowana z 2.0.0 do 2.2.0
Minimalna wymagana wersja androidx.lifecycle:lifecycle-common-java8 została zaktualizowana z 2.0.0 do 2.6.1
Minimalna wymagana wersja androidx.appcompat:appcompat została zaktualizowana z v1.0.0 do v1.6.1.
Minimalna wymagana wersja androidx.fragment:fragment została zaktualizowana z v1.0.0 do v1.6.1
Usuwa te wcześniej wycofane interfejsy API:
ConsumerTrip
,ConsumerTripCallback
,ConsumerTripManager
,ConsumerTripOptions
. Zostały one zastąpione przezTripModel
,TripModelCallback
,TripModelManager
iTripModelOptions
.Aplikacje korzystające z pakietu Consumer SDK muszą teraz mieć
targetSdkVersion
interfejs API w wersji 31 lub nowszejcompileSdkVersion
albotargetSdkVersion
interfejs API w wersji 33 lub nowszejcompileSdkVersion
.Aplikacje korzystające z pakietu Consumer SDK muszą teraz włączyć obsługę biblioteki Java 8. Instrukcje aktualizacji znajdziesz na stronie https://developer.android.com/studio/write/java8-support.
Aplikacje, które korzystają z narzędzi Proguard lub Dexguard, muszą przejść na R8. Więcej informacji znajdziesz na stronie https://developer.android.com/build/shrink-code.
Aplikacje korzystające z pakietu Consumer SDK muszą włączyć desugaring. Instrukcje znajdziesz na stronie https://developer.android.com/studio/write/java8-support#library-desugaring.
Metoda
ConsumerApi.initialize()
zgłasza teraz wyjątek, jeśli jest wywoływana, gdy instancja interfejsu API została już utworzona.Task
zwrócony przezConsumerApi.getInstance()
musi być użyty do określenia, czy wcześniej utworzono instancję interfejsu API.
Ogłoszenie: wycofanie interfejsów API
Wycofuje klasy adnotacji
Trip.TripStatus
iTrip.TripType
, a w ich miejsce dodaje klasy adnotacjiTripInfo.TripStatus
iTripInfo.TripType
.W ramach tej zmiany wycofujemy
TripModelCallback#onTripStatusUpdated(TripInfo tripInfo, @Trip.TripStatus int status)
i dodajemyTripModelCallback#onTripStatusUpdate(TripInfo tripInfo, @TripInfo.TripStatus int status)
, aby go zastąpić.W ramach tej zmiany wycofujemy
TripInfo#getTripStatus()
i dodajemyTripInfo#getCurrentTripStatus()
jako jego zamiennik.W ramach tej zmiany wycofujemy
TripInfo#getTripType()
i dodajemyTripInfo#getCurrentTripType()
jako jego zamiennik.
Wycofuje klasę
Trip
.
Inne zmiany i poprawki błędów
Obsługuje żądanie najnowszego mechanizmu renderowania pakietu Maps SDK. Więcej informacji znajdziesz w sekcji Nowy moduł renderowania map.
Obsługuje zakres pakietu SDK Map Google od wersji 18.1.0(włącznie) do 19.0.0(wyłącznie).
Naprawia błąd „przekroczono termin” w przypadku wewnętrznej komunikacji między pakietem SDK a backendem Google.
Rozwiązuje problem z renderowaniem na małych ekranach i w trybie obrazu w obrazie.
Przewodnik po migracji
1.99.1 (31 sierpnia 2023 r.)
Poprawki błędów
Rozwiązuje problem z awarią, która występuje, gdy aktywność lub fragment hosta pakietu SDK zostaną zniszczone.
Naprawiono błąd powodujący awarię, gdy wymiary elementu MapView wynoszą 0 (wysokość lub szerokość).
Naprawiono awarię, która występuje podczas wyświetlania lokalizacji pojazdu na polilinii trasy.
Ulepszenia
- Zapobiega awarii pakietu SDK, gdy aplikacja hosta jest wczytywana z zewnątrz i nie ma domyślnych zasobów wizualnych.
1.99.0 (22 czerwca 2023 r.)
Poprawki błędów
Rozwiązuje problem z renderowaniem na małych ekranach i w trybie obrazu w obrazie.
Rozwiązuje problem z migotaniem pojazdu podczas udostępniania podróży.
1.2.1 (7 czerwca 2023 r.)
Poprawki błędów
- Naprawiliśmy błąd, który powodował migotanie pojazdu podczas udostępniania podróży.
1.2.0 (21 listopada 2022 r.)
Poprawki błędów
- Naprawiono błąd, który powodował zgłaszanie pustego ruchu w wywołaniu zwrotnym
onTripActiveRouteTrafficUpdated
.
Nowe funkcje
- Funkcja „Linie łamane uwzględniające natężenie ruchu” jest już ogólnie dostępna.
1.1.2 (27 października 2022 r.)
Poprawki błędów
- Rozwiązuje problem, który powodował znikanie linii trasy po rozpoczęciu
JourneySharingSession
więcej niż raz w przypadkuTripModel
.
Ogłoszenie: wstrzymanie obsługi Androida 5 (25 lipca 2022 r.)
W przypadku pakietu SDK w wersji 1.1.1 zapewniamy dodatkowy rok obsługi aplikacji działających na Androidzie 5, zarówno w przypadku interfejsów API na poziomach 21 i 22.
Co to oznacza:
Pakiet SDK dla konsumentów działający w aplikacjach na Androida będzie obsługiwał co najmniej Androida 5 (poziom API 21) do 30 czerwca 2023 r.
Po 30 czerwca 2023 roku będziemy obsługiwać tylko poziomy interfejsu API Androida 23 i nowsze. Innymi słowy, po tej dacie przestaniemy obsługiwać poziomy API Androida 21 i 22 we wszystkich wersjach pakietu SDK. Oznacza to, że błędy związane z Androidem 21 lub 22 w dowolnej wersji pakietu SDK (w tym w wersji 4.x) nie zostaną naprawione i nie gwarantujemy, że pakiety SDK będą działać prawidłowo.
wersja 1.1.1 (25 lipca 2022 r.)
Zmiana zależności
- Obniża minimalny obsługiwany poziom interfejsu Android API do 21.
Wersja 1.1.0 (28 kwietnia 2022 r.)
- Ulepszenia wewnętrzne.
wersja 1.0.19 (17 marca 2022 r.)
Poprawki błędów
- Naprawiliśmy wyciek pamięci w klasie
ConsumerApi
.
wersja 1.0.14 (30 listopada 2021 r.)
Minimalny obsługiwany poziom interfejsu Android API to teraz 23.
Zmiany w interfejsie API
Zmiany w klasach
ConsumerTrip
iConsumerTripManager
.- Zmieniliśmy nazwy niektórych metod, aby były bardziej zrozumiałe i zgodne z platformą iOS.
Zmiany w usługach
ConsumerTripCallback
,ConsumerTrip
iTripInfo
.Zmieniliśmy niektóre nazwy klas, aby były zgodne z iOS. Wprowadzono interfejsy
TripModel
,TirpModelManager
iTripModelOptions
, aby wycofać interfejsyConsumerTrip
,ConsumerTripManager
iConsumerTripOptions
.Uporządkowano nazwy niektórych metod. Poprawiono lub dodano komentarze JavaDoc do metod, aby przekazywać bardziej zrozumiałe znaczenia.
Ulepszona obsługa błędów.
Dostosowywanie stylu
Wycofane starsze kody
MarkerStyleOptions
iPolylineStyleOptions
zostały wycofane i zastąpione przezMarkerOptions
iPolylineOptions
, które są udostępniane w pakiecie Maps SDK.
Monitorowanie awarii
Dodaliśmy wykrywanie awarii i rejestrowanie.
- Dodaliśmy możliwość wyłączenia tej funkcji. Zostało to zrobione w ramach szerszych działań obejmujących cały świat i mających na celu monitorowanie awarii.
Zmiany uwierzytelniania
- Usuń niepotrzebne metody z interfejsów uwierzytelniania.
- Usunięto parametr
ServiceType
.
- Usunięto parametr
wersja 0.9.28 (18 maja 2021 r.)
Zmiany w interfejsie API
- Zaktualizowano wszystkie metody
ConsumerTripCallback
, aby używały parametruTripInfo
. - Dodano parametr
ConsumerTrip.isRefreshing()
, który wskazuje, czyConsumerTrip
aktywnie aktualizuje się o najnowsze informacje o przejazdach z Fleet Engine. - Dodano:
ConsumerTripCallback.onTripRemainingRouteDistanceUpdated()
. - Dodano:
ConsumerTripCallback.onTripRemainingRouteUpdated()
. - Zastąp typy zwracane Guavy (
ImmutableSet
,ImmutableList
) odpowiednikami klasjava.util
. Zmiany nazwy pakietu:
- com.google.android.libraries.ridesharing.common.AuthTokenContext -> com.google.android.libraries.ridesharing.consumer.auth.AuthTokenContext
- com.google.android.libraries.ridesharing.common.AuthTokenFactory -> com.google.android.libraries.ridesharing.consumer.auth.AuthTokenFactory
com.google.android.libraries.ridesharing.common.FleetEngineServiceType -> com.google.android.libraries.ridesharing.consumer.auth.FleetEngineServiceType - com.google.android.libraries.ridesharing.common.model.Trip
-> com.google.android.libraries.ridesharing.consumer.model.Trip - com.google.android.libraries.ridesharing.common.model.Vehicle -> com.google.android.libraries.ridesharing.consumer.model.Vehicle
Zmiany w implementacji
- Naprawiono sytuację wyścigu, w której pakiet SDK mógł ulec awarii w wyniku interakcji z mapą przed jej przygotowaniem.
- Pakiet SDK nie zawiera już niezaszyfrowanej kopii
io.grpc
. - Naprawiliśmy błąd związany z migotaniem linii łamanych przedstawiających natężenie ruchu na niektórych urządzeniach. Segmenty ruchu będą teraz miały zaokrąglone końce.
wersja 0.9.15 (7 października 2020 r.)
Zmiany w interfejsie API
- W tej wersji wprowadziliśmy linie łamane uwzględniające ruch.
– Dodano
TripInfo.getActiveRouteTraffic()
iTripInfo.getRemainingRouteTraffic()
.- Dodano symbole
ConsumerTripCallback.onTripActiveRouteTrafficUpdated()
iConsumerTripCallback.onTripRemainingRouteTrafficUpdated()
, aby wskazywać, kiedy zmieniło się natężenie ruchu. - Dodano
PolylineStyleOptions
do dostosowywania ruchu (setTrafficEnabled()
,setTrafficColorNoData()
,setTrafficColorNormal()
,setTrafficColorSlow()
,setTrafficColorTrafficJam()
). - Wyświetlono:
PolylineStyleOptions.TRAFFIC_Z_INDEX_ADDITION
. - Dodano:
TripWaypoint.getTrafficData()
. - Dodano typ danych
TrafficData
. - Dodano:
ConsumerController.hideAllSessions()
. FunkcjaConsumerController.showSession()
nie akceptuje już wartości null jako argumentu.
- Dodano symbole
wersja 0.9.9 (15 lipca 2020 r.)
Zmiany w interfejsie API
- Jest to istotna zmiana, która wprowadza architekturę modułową z wyraźniejszą relacją między warstwą tylko z danymi (np.
ConsumerTripManager
) a warstwą interfejsu użytkownika (np.JourneySharingSession
). Informacje o migracji do nowej architektury znajdziesz w przewodniku po migracji do architektury modułowej. – ObiektConsumerTrip
jest teraz pobierany zConsumerTripManager.getTrip()
.- Nazwa
ConsumerTrip.unregisterCallback
została zmieniona naConsumerTrip.unregisterTripCallback
. - Nazwa
ConsumerTrip.isCallbackRegistered
została zmieniona naConsumerTrip.isTripCallbackRegistered
. - Dodano:
ConsumerTrip.setConsumerTripOptions()
iConsumerTrip.getConsumerTripOptions()
. - Użytkownik
ConsumerTrip.setAutoRefreshInterval()
został usunięty.
- Nazwa
- Usunięto interfejsy API do udostępniania niepowiązane z podróżami.
- Usunięto mapę gęstości pojazdów.
- Usunięto stan podglądu podróży.
- Usunięto stan wyboru odbioru.
- Usunięto stan wyboru miejsca odbioru.
- Usunęliśmy te typy znaczników:
SELECTED_PICKUP_POINT
,SUGGESTED_PICKUP_POINT
,HIGHLIGHTED_PICKUP_POINT
iSELECTED_DROPOFF_POINT
.
- Zmieniono interfejsy
OnConsumerMarkerClickCallback
iConsumerMapReadyCallback
na klasy abstrakcyjne. - Dodano
ConsumerController.getCameraUpdate()
,ConsumerController.isAutoCameraEnabled()
iConsumerController.enableAutoCamera()
. - Usunięto niestandardowy przycisk FAB i powiązane z nim metody (
ConsumerController.isMyLocationFabEnabled
iConsumerController.setMyLocationFabEnabled
).
Zmiany w implementacji
ConsumerTripCallback
, niezależnie od tego, czy jest zarejestrowany wLifecycleOwner
, czy nie, nie jest już automatycznie wyrejestrowywanyTripStatus.COMPLETE
aniTripStatus.CANCELED
.- Funkcja AutoCamera jest teraz domyślnie włączona i nigdy nie włącza ani nie wyłącza się sama.
Wcześniej funkcja AutoCamera była automatycznie włączana na
TripStatus.ARRIVED_AT_PICKUP
i wyłączana, gdy użytkownik wchodził w interakcję z mapą podczas udostępniania trasy. - Wprowadziliśmy te ulepszenia animacji pojazdu podczas udostępniania trasy:
- Animacja udostępniania podróży uwzględnia teraz sytuację, w której pojazd może legalnie cofnąć się na już przejechaną trasę.
- Pojazd będzie teraz animowany w linii prostej zamiast interpolacji trasy między punktami, gdy algorytm uzna to za odpowiednie.
- Uprawnienia
FINE_LOCATION
nie są już wymagane.
Inne zmiany
- Zaktualizowano te wersje zależności:
- com.google.android.datatransport:transport-api:2.2.0
- com.google.android.datatransport:transport-backend-cct:2.2.0
- com.google.android.datatransport:transport-runtime:2.2.0
wersja 0.9.1 (23 marca 2020 r.)
Zmiany w interfejsie API
- Dodano
TripInfo.getVehicleId()
,TripInfo.getNumberOfPassengers()
,TripInfo.getIntermediateDestinationIndex()
,TripInfo.getTripActiveRoute()
iTripInfo.getTripRemainingRoute()
. - Dodano klasę
options
używaną podczas inicjowaniaConsumerApi
, która umożliwia dynamiczne ustawianie adresuFleetEngine
. Jeśli interfejs API nie zostanie wywołany z wartościąFleetEngine
, spróbuje pobrać ją z pliku manifestu Androida lub użyć wartości domyślnej.
Ulepszenia
- Linia trasy nie jest wyświetlana, gdy stan przejazdu to
ARRIVED_AT_PICKUP
. - Ulepszono śledzenie pojazdów poza trasą (wymaga pakietu DriverSDK w wersji 1.15):
- Śledzenie pojazdu nie przyciąga go do trasy, gdy przejeżdża on obok miejsca odbioru.
- Śledzenie pojazdu umożliwia wyświetlanie go poza drogą, np. na nieoznaczonych parkingach.
- Ikona pojazdu jest teraz aktualizowana, gdy miejsce docelowe kierowcy nie jest zgodne z miejscem docelowym w Fleet Engine.
wersja 0.8.6 (16 grudnia 2019 r.)
Zmiany w interfejsie API
Dodano:
TripInfo.getVehicleLocation()
.ConsumerMapView
nie jest już ostateczna.
Zmiany w implementacji
- Pozostała odległość aktywnego odcinka jest teraz obliczana na podstawie odległości serwera (zgłoszonej przez kierowcę + statycznej trasy, w stosownych przypadkach) zamiast lokalnego przyciągania. Ta zmiana zapewnia dokładniejsze wartości pozostałej odległości.
Inne zmiany
Wymagane są nowe zależności. Szczegóły znajdziesz w pliku .pom.
- com.google.android.datatransport:transport-api:2.0.0
- com.google.android.datatransport:transport-backend-cct:2.0.2
- com.google.android.datatransport:transport-runtime:2.0.0
Dodano logi dotyczące czasu oczekiwania na prośbę o przejazd.
Dodano logi błędów odpowiedzi dotyczących podróży.
Uwagi
- Od wersji 0.8.1 pakiet Consumer SDK na Androida jest dostarczany jako spakowane archiwum w formacie Jetified ZIP. Informacje o tym, jak to zrobić, znajdziesz w artykule Jetifier: tryb odwrotny.
Wersja 0.8.1 (13 września 2019 r.)
Nowe funkcje
Obsługa ConsumerMapView.
Artefakty ODRD są teraz dostarczane w repozytorium Maven zamiast w pliku ZIP w formacie .aar. Więcej informacji znajdziesz w artykule Dodawanie pakietu Consumer SDK do aplikacji.
Zmiany w interfejsie API
Dodano funkcję
ConsumerController.disableAutoCamera()
jako przeciwieństwo funkcjicenterMapForState()
.VehicleLocation.getUpdateTime()
zwraca teraz wartość typu Long, która reprezentuje sygnaturę czasową (w milisekundach).Uprościliśmy interfejs
AuthTokenFactory
, aby udostępnić jedną metodę generowania tokenów. ZmienionoAuthTokenFactory
z interfejsu na klasę abstrakcyjną, aby umożliwić zgodność wsteczną w Java7. Ta zmiana jest wstecznie kompatybilna, ale stare metody generowania pojedynczych tokenów usługi zostały wycofane i zostaną ostatecznie usunięte.
Zmiany w implementacji
Zasoby są teraz wyśrodkowane względem środka ikony, co eliminuje przesunięcie cienia.
setState
naJOURNEY_SHARING onStartTripMonitoring()
zamiast czekać na stan monitorowanej podróży.Zawsze zwraca dane dotyczące pierwszej aktualizacji danych o podróży, nawet jeśli dane o podróży są niesynchronizowane.
Dodano Android Map Utils jako dostarczoną zależność.
Poprawki błędów
- Naprawiono nieprawidłową składnię eksportu ProGuard dla grpc keep.
Wersja 0.7.0 (7 sierpnia 2019 r.)
Nowe funkcje
- Obsługa wielu miejsc docelowych w przypadku udostępniania trasy.
Zmiany w interfejsie API
Nowe metody dla
ConsumerTripCallback
.onTripIntermediateDestinationsUpdated()
.onTripETAToNextTripWaypointUpdated()
.
Nowe metody
ConsumerController
.getIntermediateDestinations()
.setIntermediateDestinations(List<TerminalLocation> intermediateDestinations)
.
Nowy
TripStatuses
TripStatus.ENROUTE_TO_INTERMEDIATE_DESTINATION
.TripStatus.ARRIVED_AT_INTERMEDIATE_DESTINATION
.
Nowe metody pobierania
TripWaypoint
.getETAMillis()
.getDistanceMeters()
.
Dodano klasę
TripInfo
.TripInfo
możesz uzyskać w przypadku aktywnej podróży za pomocąConsumerTripManager.getActiveTripInfo()
.
Dodano:
WaypointType.INTERMEDIATE_DESTINATION
.Dodano:
MarkerType.TRIP_INTERMEDIATE_DESTINATION
.Utworzono
ConsumerMapState.JOURNEY_SHARING
z połączonychConsumerMapStates
ENROUTE_TO_PICKUP
,ARRIVED_AT_PICKUP
,ENROUTE_TO_DROPOFF
iCOMPLETE
.Zaktualizowano tabelę
StateChangeCallbacks
.Dodano:
onStateJourneySharing()
.Usunięto:
onStateWaitingForPickup()
,onStateDriverArrived()
,onStateEnroute()
ionStateEndofTrip()
.
Poprawki błędów
Naprawiliśmy błąd, który powodował, że trasa nie była przycinana do lokalizacji pojazdu, gdy monitorowanie podróży rozpoczynało się w trakcie aktywnej podróży (nie na początku trasy).
Naprawiliśmy błąd, który powodował, że wywołania zwrotne dotyczące przejazdu nie były wywoływane w przypadku odbiorców zarejestrowanych w usłudze TripManager po tym, jak usługa TripManager pobrała już dane przejazdu.
Powiększenie kamery obejmuje teraz tylko aktywną trasę i następny punkt na trasie podróży (punkt na trasie należący do podróży). Nawet jeśli pozostała część jest widoczna, powiększenie nigdy jej nie obejmie. Wcześniej punkt odbioru był uwzględniany w powiększeniu, gdy pojazd był w drodze do miejsca odbioru lub dotarł do niego. To już nie jest prawdą.
Ulepszenia
Wypełnij zerowy pozostały punkt trasy danymi kierowcy (lista pozostałych punktów trasy jest zwracana przez
ConsumerTripCallback.onTripRemainingWaypointsUpdated
iTripInfo.getRemainingWaypoints()
).Aktualizuj wszystkie pozostałe szacowane czasy dotarcia do punktów pośrednich, gdy zmieni się szacowany czas dotarcia do pierwszego punktu pośredniego na liście.
Wymuś ponowne włączenie automatycznego aparatu tylko wtedy, gdy kierowca dotrze na miejsce odbioru. Wcześniej funkcja automatycznego kadrowania resetowała się i była włączana przy każdej zmianie stanu podróży. Automatyczne ustawianie kamery jest nadal domyślnie włączone. Automatyczne włączanie kamery nie zostanie ponownie włączone, jeśli nowa aktywna podróż zostanie ustawiona bez nowego wywołania funkcji
startTripMonitoring()
.
wersja 0.6.1 (26 czerwca 2019 r.)
Nowe funkcje
- Obsługa wspólnych przejazdów w przypadku udostępniania podróży.
Zmiany w interfejsie API
ConsumerController.getConsumerMapStyle()
zwraca terazConsumerMapStyle
zamiastTask<ConsumerMapStyle>
.Dodano:
PolylineStyle.setZIndex()
.
Poprawki błędów
Animacja trasy jest teraz wyświetlana tylko wtedy, gdy segment trasy jest zsynchronizowany, co poprawia wygodę użytkownika.
Rozwiązaliśmy problem z „migotaniem” pojazdu podczas interpolacji animacji, gdy aktualizacje lokalizacji kierowcy są blisko siebie.
Naprawiono błąd, który powodował, że pojazd rozpoczynał trasę od jej początku, a nie od najbardziej aktualnej lokalizacji, gdy monitorowanie podróży rozpoczynało się w trakcie aktywnej podróży.
Wyświetlaj linię łamaną aktywnej trasy nad pozostałą częścią trasy, gdy się pokrywają.
Ulepszenia
- Teraz udostępniamy klasę gRPC
Status
z niezaciemnionymi metodami.
wersja 0.5.1.01 (17 maja 2019 r.)
Nowe funkcje
- Obsługa udostępniania trasy.
Zmiany w interfejsie API
- Nowe zajęcia
ConsumerController
.
PolylineType
Stara wartość | Nowa wartość |
---|---|
TRIP_PREVIEW_AUTO_ROUTE |
PREVIEW_AUTO_ROUTE |
TRIP_PREVIEW_TAXI_ROUTE |
PREVIEW_TAXI_ROUTE |
TRIP_PREVIEW_TRUCK_ROUTE |
PREVIEW_TRUCK_ROUTE |
TRIP_PREVIEW_TWO_WHEELER_ROUTE |
PREVIEW_TWO_WHEELER_ROUTE |
TRIP_ROUTE |
ACTIVE_ROUTE |
REMAINING_ROUTE |
ConsumerTripCallback
Stara wartość | Nowa wartość |
---|---|
onTripRouteUpdated |
onTripActiveRouteUpdated |
onTripRemainingDistanceUpdated |
onTripActiveRouteRemainingDistanceUpdated |
onTripRemainingWaypointsUpdated() |
ConsumerController
- Teraz możesz ustawiać wywołania zwrotne dla stanów bez wpisywania stanu.
Metoda | Oddzwanianie |
---|---|
startPickupSelection |
setPickupSelectionCallback |
startDropoffSelection |
setDropoffSelectionCallback |
startTripPreview |
setTripPreviewSelectionCallback |
ConsumerController.setLanguage(String languageCode)
umożliwia ustawienie języka używanego w wywołaniach FleetEngine (np. w opisach punktów odbioru).
Ulepszenia
- Stan wyboru miejsca docelowego ma teraz przesuwny pinezkę.
- Usunięto animację kamery w stanie
INITIALIZE
. - Tekst
ManagedChannelBuilder
został zamieniony naAndroidChannelBuilder
.