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 (interfejs API na poziomie 23, 24 i 25).
Wersje pakietu Consumer SDK na Androida wydane od czwartego 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 w przypadku nowych wersji aplikacji.
4.0.0 (3 października 2025 r.)
- Ulepszenia wewnętrzne.
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ą przejść na Kotlin 2.1.
Poprawki błędów
- Do 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 język Kotlin 2.0. Zapoznaj się z przewodnikiem migracji do pakietu Android Consumer SDK 3.0.
- Wartość targetSdk w przypadku pakietu Consumer SDK 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
ConsumerApi.cleanUp()trwa zbyt długo. Po zintegrowaniu wersji wdrożymy tę funkcję stopniowo (zaczynając od 0%). - Rozwiązaliśmy problem, który powodował, że kierowcy otrzymywali błędy gRPC z kodem „INTERNAL” i komunikatem „Panic! To błąd!”. Po zintegrowaniu wersji wdrożymy tę funkcję 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 Stylizowanie mapy za pomocą definiowania 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 handlowym.
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
GoogleMaputworzonej przez pakiet SDK (ConsumerGoogleMap.getGoogleMap()). - Wprowadza interfejs API do pobierania instancji
Markerutworzonych 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 przejazdu (
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 poziomie na dopełnienie. Występuje to tylko w przypadku najnowszego renderera map.
Rozwiązanie problemu polegającego na tym, że pierwszy odcinek podróży w obie strony jest skracany, 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ł zaktualizowany z 21 na 23.
Aktualizuje wymagania dotyczące wersji pakietu Maps SDK z 17.0.0 do 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 minimalną wymaganą wersją ustawioną na v2.5.2.
Zaktualizuj wersje tych zależności:
Minimalna wymagana wersja biblioteki android-maps-utils została zaktualizowana 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 wersji 3.0.1 do wersji 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,TripModelManageriTripModelOptions.Aplikacje korzystające z pakietu Consumer SDK muszą teraz mieć
targetSdkVersioninterfejs API w wersji 31 lub nowszejcompileSdkVersionalbo interfejs API w wersji 33 lub nowszej.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 używają 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.Taskzwró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.TripStatusiTrip.TripType, a w ich miejsce dodaje klasy adnotacjiTripInfo.TripStatusiTripInfo.TripType.W ramach tej zmiany wycofujemy
TripModelCallback#onTripStatusUpdated(TripInfo tripInfo, @Trip.TripStatus int status)i dodajemyTripModelCallback#onTripStatusUpdate(TripInfo tripInfo, @TripInfo.TripStatus int status)w zamian.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. Szczegółowe informacje znajdziesz w artykule Nowy mechanizm renderowania map.
Obsługuje zakres pakietu Maps SDK 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 wielolinii 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.
Poprawki migotania 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 ruch” jest już ogólnie dostępna.
1.1.2 (27 października 2022 r.)
Poprawki błędów
- Naprawiliśmy błąd, który powodował znikanie polilinii trasy po rozpoczęciu
JourneySharingSessionwię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 na poziomie API 21, jak 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 interfejsu 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
ConsumerTripiConsumerTripManager.- Zmieniliśmy nazwy niektórych metod, aby były bardziej zrozumiałe i zgodne z platformą iOS.
Zmiany w usługach
ConsumerTripCallback,ConsumerTripiTripInfo.Zmieniliśmy niektóre nazwy klas, aby były zgodne z iOS. Wprowadzono interfejsy
TripModel,TirpModelManageriTripModelOptions, aby wycofać interfejsyConsumerTrip,ConsumerTripManageriConsumerTripOptions.Uproszczono niektóre nazwy metod. Poprawione lub dodane komentarze JavaDoc do metod, aby przekazywać jaśniejsze znaczenia.
Ulepszona obsługa błędów.
Dostosowywanie stylu
Wycofane starsze kody
MarkerStyleOptionsiPolylineStyleOptionszostały wycofane i zastąpione przezMarkerOptionsiPolylineOptions, 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
v0.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, czyConsumerTripjest aktywnie aktualizowany o najnowsze informacje o przejazdach z Fleet Engine. - Dodano:
ConsumerTripCallback.onTripRemainingRouteDistanceUpdated(). - Dodano:
ConsumerTripCallback.onTripRemainingRouteUpdated(). - Zastąp typy zwracane przez Guavę (
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ą, zanim był gotowy.
- 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 wielolinie uwzględniające ruch.
– Dodano
TripInfo.getActiveRouteTraffic()iTripInfo.getRemainingRouteTraffic().- Dodano ikony
ConsumerTripCallback.onTripActiveRouteTrafficUpdated()iConsumerTripCallback.onTripRemainingRouteTrafficUpdated(), aby wskazywać, kiedy zmieniło się natężenie ruchu. - Dodano
PolylineStyleOptionsdo 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 ikony
wersja 0.9.9 (15 lipca 2020 r.)
Zmiany w interfejsie API
- Jest to duża 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 modułowej architektury. – ObiektConsumerTripjest teraz pobierany zConsumerTripManager.getTrip().- Nazwa
ConsumerTrip.unregisterCallbackzostała zmieniona naConsumerTrip.unregisterTripCallback. - Nazwa
ConsumerTrip.isCallbackRegisteredzostał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_POINTiSELECTED_DROPOFF_POINT.
- Zmieniono
OnConsumerMarkerClickCallbackiConsumerMapReadyCallbackz interfejsów na klasy abstrakcyjne. - Dodano
ConsumerController.getCameraUpdate(),ConsumerController.isAutoCameraEnabled()iConsumerController.enableAutoCamera(). - Usunęliśmy niestandardowy przycisk FAB i powiązane z nim metody (
ConsumerController.isMyLocationFabEnablediConsumerController.setMyLocationFabEnabled).
Zmiany w implementacji
ConsumerTripCallback, niezależnie od tego, czy jest zarejestrowany zLifecycleOwner, czy bez niego, nie jest już automatycznie wyrejestrowywany wTripStatus.COMPLETEaniTripStatus.CANCELED.- Funkcja AutoCamera jest teraz domyślnie włączona i nigdy nie włącza ani nie wyłącza się sama.
Wcześniej funkcja AutoCamera automatycznie włączała się ponownie po
TripStatus.ARRIVED_AT_PICKUPi wyłączała, 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 trasy 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_LOCATIONnie są już wymagane.
Inne zmiany
- Zaktualizowano wersje tych 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 użytkowników
TripInfo.getVehicleId(),TripInfo.getNumberOfPassengers(),TripInfo.getIntermediateDestinationIndex(),TripInfo.getTripActiveRoute()iTripInfo.getTripRemainingRoute(). - Dodano klasę
optionsużywaną podczas inicjowaniaConsumerApi, która umożliwia dynamiczne ustawianie adresuFleetEngine. Jeśli wywołanie interfejsu API nie zawiera wartościFleetEngine, próbuje on pobrać ją z pliku manifestu Androida lub użyć wartości domyślnej.
Ulepszenia
- Linia trasy nie jest wyświetlana, gdy stan podróży to
ARRIVED_AT_PICKUP. - Ulepszone ś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().ConsumerMapViewnie 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 pozwala uzyskać 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. ZmienionoAuthTokenFactoryz interfejsu na klasę abstrakcyjną, aby umożliwić zgodność wsteczną w języku Java 7. Ta zmiana jest wstecznie kompatybilna, ale stare metody generowania pojedynczego tokena 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.
setStatenaJOURNEY_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 funkcji 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.TripInfomożesz uzyskać w przypadku aktywnej podróży za pomocąConsumerTripManager.getActiveTripInfo().
Dodano:
WaypointType.INTERMEDIATE_DESTINATION.Dodano:
MarkerType.TRIP_INTERMEDIATE_DESTINATION.Utworzono
ConsumerMapState.JOURNEY_SHARINGz połączonych plikówConsumerMapStatesENROUTE_TO_PICKUP,ARRIVED_AT_PICKUP,ENROUTE_TO_DROPOFFiCOMPLETE.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).
Rozwiązaliś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 noga 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.onTripRemainingWaypointsUpdatediTripInfo.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 automatyczne ustawianie kamery było resetowane i włączane 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 nowy aktywny przejazd zostanie ustawiony 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 terazConsumerMapStylezamiastTask<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ł podróż na początku trasy, a nie w najnowszej 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
Statusz 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 przypadku opisów punktów odbioru).
Ulepszenia
- Stan wyboru miejsca odbioru ma teraz przesuwny pinezkę.
- Usunięto animację kamery w stanie
INITIALIZE. - Tekst
ManagedChannelBuilderzostał zastąpiony tekstemAndroidChannelBuilder.