Najczęstsze pytania
Szczegóły usługi
- Jak należy wyświetlać informację o Warunkach korzystania z pakietu Navigation SDK?
- W jakich językach dostępne są wskazówki głosowe?
- Czy kierunek jest zachowywany, gdy kierowca wyjdzie z trybu nawigacji?
- Czy podczas rozpoczynania lub zmiany trasy dostępne są polilinie?
- Czy użytkownicy aplikacji muszą mieć zainstalowaną aplikację mobilną Mapy Google?
- Czy pakiet Navigation SDK może identyfikować parkingi w pobliżu restauracji i innych miejsc docelowych?
- Czy pakiet Navigation SDK wyświetla kierunek ruchu na pasach podczas zbliżania się do punktu skrętu?
Problemy
- W Xcode 12 aplikacje nie są prawidłowo kompilowane na potrzeby symulatora. Jak mogę to naprawić?
GMSMapView
nie wczytuje się.
Sieć
Dane
- Czy przed rozpoczęciem trasy mogę pobrać wszystkie przystanki/miejsca docelowe w podróży?
- Czy na początku trasy dostępna jest szczegółowa nawigacja?
- W jaki sposób szacowany czas dotarcia (ETA) jest przekazywany użytkownikom aplikacji?
- Czy element
RoadSnappedLocationProvider
może służyć do uzyskiwania bieżącej przyciągniętej lokalizacji kierowcy, jeśli nawigacja nie jest na pierwszym planie? - Czy pakiet Navigation SDK obsługuje geofencing?
- Czy mogę wyłączyć powiadomienia, gdy aplikacja Nawigacja działa w tle?
Dostosowywanie interfejsu
- Czy mogę oznaczyć kolorami najlepszą opcję trasy?
- Czy pakiet SDK do nawigacji może wyświetlać szacowany czas dotarcia do miejsca docelowego?
- Jak ukryć aktualizacje szacowanego czasu przyjazdu?
- Jakie opcje dostosowywania interfejsu są dostępne w przypadku kart nagłówka i stopki?
Routing
- Czy mogę podać kierowcy konkretną trasę lub usunąć trasy alternatywne?
- Czy mogę wyświetlać kierowcy inne oznaczenie miejsca docelowego niż domyślna lokalizacja?
- Czy mogę używać Navigation SDK do śledzenia odchyleń od wyznaczonej trasy?
- Czy kierowca może wyłączyć nawigację bez ukończenia trasy?
Symulator
Przepływy pracy
- Jak odrzucić powiadomienie po zamknięciu aktywności zawierającej fragment nawigacji? (tylko Android)
Usługi mobilne
- Czym różni się korzystanie z pakietu Navigation SDK w przypadku klientów korzystających z usług mobilności?
- Jak sprawdzić, czy jestem klientem usług mobilnych?
- Jak rozliczany jest pakiet Navigation SDK w przypadku klientów korzystających z usług mobilności?
- Z których interfejsów API pakietu Navigation SDK powinni korzystać tylko klienci usług mobilności?
- Czy jeśli jestem klientem usług mobilnych, mogę też używać implementacji pakietu Navigation SDK, która nie jest związana z usługami mobilnymi?
Szczegóły usługi
- W aplikacji musi być zaimplementowane okno z informacją o Warunkach korzystania z pakietu Navigation SDK, które każdy kierowca musi zaakceptować. W tym oknie kierowca może zaakceptować Warunki korzystania z usługi. Plik tekstowy z warunkami jest dostarczany z pakietem Navigation SDK.
- Na Androidzie użyj metody
NavigationApi.showTermsAndConditionsDialog
, aby wyświetlić okno z warunkami. - W iOS zadzwoń
GMSNavigationServices.showTermsAndConditionsDialogIfNeededWithCompanyName
. - Wszystkie języki obsługiwane przez Mapy Google na urządzenia mobilne są automatycznie dostępne w pakiecie SDK do nawigacji. Urządzenie ma domyślny język systemu, którego aplikacja nie może zmienić. Aplikacja ma jednak dostęp do ponad 70 języków.
-
Tak. W Androidzie po uruchomieniu
LocationListener
nadal działa w tle. Aplikacja nadal będzie przyciągać pozycję do drogi i utrzymywać kierunek.Aby nadal otrzymywać aktualizacje lokalizacji dotyczące pozycji i kierunku w tle w iOS, zaimplementuj przyciąganie do drogi i ustaw wartość
allowsBackgroundLocationUpdates
naYES
. -
Tak. Gdy trasa zostanie utworzona lub zmieniona, interfejs
RouteChangeListener
udostępnia polilinie. - Nie, pakiet Navigation SDK nie wymaga zainstalowania na urządzeniu aplikacji Mapy Google na urządzenia mobilne.
- Nie, Navigation SDK nie udostępnia obecnie tej funkcji.
- Tak. Kierunek ruchu jest dostępny i wyświetlany domyślnie.
Problemy
- W Xcode 12 aplikacje nie są prawidłowo kompilowane na potrzeby symulatora. Jak rozwiązać ten problem?
-
Aby rozwiązać ten problem, otwórz ustawienia kompilacji projektu Xcode i dodaj
arm64
doExcluded Architectures
tylko w przypadku kompilacji „iOS Simulator”.Więcej informacji znajdziesz w tym wątku na StackOverflow.
- GMSMapView się nie wczytuje.
-
Jeśli GMSMapView się nie wczytuje:
- Sprawdź, czy pakiet NavSDK jest włączony w Cloud Console.
- Jeśli pakiet Nav SDK jest zainstalowany, ale Twój projekt nie korzysta z interfejsów API Nav SDK, usuń go z pliku binarnego.
Sieć
- Jak pakiet Navigation SDK radzi sobie ze słabym połączeniem?
- Pakiet SDK do nawigacji wstępnie zapisuje w pamięci podręcznej trasę każdej podróży. Wstępnie zapisane informacje obejmują dane dotyczące trasy na 15–20 minut oraz alternatywne trasy na wypadek, gdyby kierowca zboczył z trasy. Pakiet Navigation SDK określa przybliżoną pozycję za pomocą GPS i czujników urządzenia.
- Czy jest dostępny tryb offline?
- Nie, pakiet Navigation SDK nie oferuje obecnie trybu offline. Zapewnia jednak wstępnie zapisane w pamięci podręcznej informacje o podróży.
Dane
- Czy przed rozpoczęciem trasy mogę pobrać wszystkie przystanki/miejsca docelowe w podróży?
-
Tak. Aby pobrać wskazówki dojazdu na trasie w Androidzie, wywołaj funkcję
Navigator.getRouteSegments()
.W systemie iOS wywołaj funkcję
GMSNavigator.routeLegs(read)
. - Czy szczegółowe wskazówki dojazdu są dostępne na początku trasy?
- Tak. Navigation SDK udostępnia listę segmentów trasy. Kierowca może też przesuwać palcem po karcie wskazówek w nagłówku, aby zobaczyć każdy manewr.
- Jak szacowany czas dotarcia jest przekazywany użytkownikom aplikacji?
-
Aby przekazywać użytkownikom aplikacji informacje o szacowanym czasie dotarcia na urządzeniach z Androidem:
- Pobierz czas i odległość dla wszystkich punktów pośrednich za pomocą funkcji
Navigator.getTimeAndDistanceList()
. - Przekaż te informacje do aplikacji klienta, tak jak w przypadku szacowanego czasu dotarcia kierowcy.
Aby przekazywać użytkownikom aplikacji informacje o szacowanym czasie dotarcia na urządzeniach z iOS, wykonaj te czynności:
- Pobierz etapy podróży za pomocą funkcji
Navigator.getRouteSegments()
. - Zadzwoń pod numer
GMSNavigator.timeToNextDestination
na każdym etapie podróży. - Przekaż informacje o czasie do aplikacji klienta, tak jak w przypadku szacowanego czasu przyjazdu kierowcy.
- Pobierz czas i odległość dla wszystkich punktów pośrednich za pomocą funkcji
-
Czy za pomocą
RoadSnappedLocationProvider
można uzyskać aktualną przyciągniętą lokalizację kierowcy, jeśli nawigacja nie jest na pierwszym planie? -
Tak. Na Androidzie
RoadSnappedLocationProvider
domyślnie działa w tle.Aby w iOS nawigacja działała w tle, zaimplementuj odbiornik dla
GMSRoadSnappedLocationProviderListener
i ustaw właściwośćallowsBackgroundLocationUpdates
naTRUE
. - Czy pakiet Navigation SDK obsługuje geofencing?
-
Nie. W kontekście nawigacji
remainingTimeOrdistanceChangeListener
ma przewagę nad geofencingiem. Geofence może nie uwzględniać geometrii drogi i może nie być wyśrodkowany w dokładnym punkcie, do którego kierowca nawiguje.Możesz przybliżyć tę funkcję za pomocą
remainingTimeOrdistanceChangeListener
.- Ustaw próg, aby określić częstotliwość wywołań zwrotnych.
- Sprawdź pozostałą odległość do celu.
Jeśli na przykład ustawisz próg na 100 m, wywołanie zwrotne nastąpi, gdy odległość od miejsca docelowego zmieni się o 100 m. W miarę zmniejszania się odległości możesz zmniejszać ten próg, aby częściej otrzymywać wywołania zwrotne. Następnie sprawdź pozostałą odległość, aby określić, czy jesteś wystarczająco blisko miejsca odbioru lub dostawy.
W przypadku iOS zaimplementuj odbiornik
GMSNavigatorListener.didUpdateRemainingDistance
, aby zarządzać odległością między powiadomieniami. - Czy mogę wyłączyć powiadomienia, gdy aplikacja Nawigacja działa w tle?
-
Tak. Na Androidzie używaj
Navigator.setHeadsUpNotificationEnabled
, aby zarządzać powiadomieniami. Ta metoda ma argument logiczny.FALSE
– wyłącza powiadomienia;TRUE
– włącza powiadomienia.W systemie iOS wyłącz powiadomienia w tle dotyczące lokalizacji przyciąganych do dróg, ustawiając wartość
GMSRoadSnappedLocationProvider.allowsBackgroundLocationUpdates
na NO.Aby wyłączyć przetwarzanie w tle w przypadku innych powiadomień o lokalizacji, zadzwoń pod numer
GMSNavigator.sendsBackgroundNotifications(NO)
.
Dostosowywanie interfejsu
- Czy mogę oznaczyć kolorami najlepszą opcję trasy?
- Nie. Kodowanie kolorami konkretnej opcji trasy nie jest obecnie obsługiwane.
- Czy pakiet Navigation SDK może wyświetlać szacowany czas dotarcia do miejsca docelowego?
-
Tak. Na urządzeniach z Androidem użyj tych metod:
- Pobierz czas i odległość dla wszystkich punktów pośrednich za pomocą funkcji
Navigator.getTimeAndDistanceList()
. - Ukryj szacowany czas dotarcia do bieżącego punktu trasy za pomocą ikony
NavigationFragment.setEtaCardEnabled(false)
. - Wyświetl szacowany czas dotarcia do miejsca docelowego.
W iOS użyj tych ustawień:
- Zadzwoń do firmy
GMSNavigator.routeLegs(read)
. - Na ostatnim etapie wywołaj funkcję
GMSNavigator.timeToNextDestination
. - Ukryj szacowany czas dotarcia do bieżącego punktu trasy, ustawiając wartość
MSMapView.settings.navigationFooterEnabled=NO
na FALSE. - Wyświetl szacowany czas dotarcia do miejsca docelowego.
- Pobierz czas i odległość dla wszystkich punktów pośrednich za pomocą funkcji
- Jak ukryć aktualizacje szacowanego czasu przyjazdu?
-
Karty z szacowanym czasem przyjazdu możesz wyłączyć w ten sposób:
- Na Androidzie użyj
navigationView.setEtaCardEnabled(false)
. - Na urządzeniach z iOS używaj
GMSMapView.settings.navigationFooterEnabled=NO
.
- Na Androidzie użyj
-
W Androidzie używasz
StylingOptions
, aby ustawić styl koloru tła. Aby ukryć lub wyświetlić nagłówek i stopkę, użyj funkcji członkowskichsetHeaderEnabled
isetFooterEnabled
elementuNavigationFragment
.W iOS użyj
GMSMapView.settings.navigationHeaderPrimaryBackgroundColor
, aby ustawić styl koloru tła. Aby ukryć lub wyświetlić nagłówek i stopkę, użyj właściwościnavigationFooterEnabled
inavigationHeaderEnabled
elementuGMSUISettings
.
Routing
- Czy mogę podać kierowcy konkretną trasę lub usunąć trasy alternatywne?
- Nie. Domyślnie podawanych jest kilka tras, a najszybsza z nich ma priorytet. Na trasę domyślną możesz wpływać, dodając do żądania preferencje, np. „unikaj autostrad i dróg płatnych”. Dodanie punktów pośrednich również wpływa na trasę.
- Czy mogę wyświetlać użytkownikowi aplikacji inną etykietę miejsca docelowego niż domyślna lokalizacja docelowa?
-
Tak. Na urządzeniu z Androidem utwórz
Marker
z niestandardowym tytułem miejsca docelowego oraz szerokością i długością geograficzną. Pakiet SDK Navigation wyświetla niestandardowy tytuł i współrzędne naNavigationMap
.W iOS tworzysz i wyświetlasz
GMSMarker
dla miejsca docelowego. - Czy mogę używać pakietu Navigation SDK do śledzenia odchyleń od wyznaczonej trasy?
-
Tak. Na urządzeniach z Androidem możesz włączyć
Navigator.setRouteChangedListener
, aby otrzymywać powiadomienia o zmianach trasy lub rekomendacjach nowych tras:- Zarejestruj odbiornik, który sprawdza położenie urządzenia na trasie za pomocą metody
Navigator.setRouteChangedListener
. - Dodaj kod do funkcji obsługi zdarzenia wywołania zwrotnego:
onRouteChanged
:- Wysyłanie do użytkownika aplikacji wiadomości z aktualnymi informacjami o szacowanym czasie dotarcia i odległości.
- śledzić lokalizację urządzenia,
- [opcjonalnie] Dodaj inne funkcje wymagane przez aplikację, aby obsługiwać sytuacje, gdy kierowca zjedzie z wyznaczonej trasy.
W iOS użyj
GMSNavigator
i jego odbiorników, aby otrzymywać powiadomienia o zmianie trasy lub rekomendacji nowej trasy:- W kontrolerze widoku mapy zaimplementuj protokoły
GMSNavigatorListener
iGMSRoadSnappedLocationProviderListener
. - Wdrożenie
GMSNavigatorListener.navigatorDidChangeRoute
- Dostęp do nowej trasy uzyskasz za pomocą właściwości
routeLegs
icurrentRouteLeg
obiektuGMSNavigator
.
- Zarejestruj odbiornik, który sprawdza położenie urządzenia na trasie za pomocą metody
-
Tak. Na Androidzie wywołaj metodę
Navigator.stopGuidance()
, aby zatrzymać nawigację.W systemie iOS wywołaj funkcję
GMSNavigator.clearDestinations
.
Symulator
- Czy symulator obsługuje zmiany trasy?
-
Tak. Na Androidzie wywołaj
simulateLocationsAlongNewRoute
, aby zasymulować podróż ze zmianą trasy. MetodasimulateLocationsAlongExistingRoute
ignoruje zmiany w dotychczasowej trasie.W systemie iOS użyj
GMSLocationSimulator.simulateAlongNewRouteToDestinations
, aby zasymulować podróż, która obejmuje zmianę trasy. Jeśli nie przewidujesz żadnych zmian trasy, możesz użyćGMSLocationSimulator.simulateLocationsAlongExistingRoute
lubGMSLocationSimulator.simulateAlongNewRouteToDestinations
.
Przepływy pracy
- Jak odrzucić powiadomienie po zamknięciu aktywności zawierającej fragment nawigacji?
-
Powiadomienie o nawigacji pozostaje widoczne podczas nawigacji, gdy aktywność jest zamknięta. Gdy pojazd dotrze do celu, nawigacja zostanie zatrzymana, a powiadomienie zniknie.
Aby obsługiwać kliknięcia powiadomienia, użyj
Navigator.startGuidance(intent resumeIntent)
.resume intent
jest uruchamiane, gdy użytkownik aplikacji kliknie powiadomienie. Zazwyczaj funkcjaNavigator.startguidance(getIntent())
jest wywoływana z głównego działania, które jest ponownie wywoływane, gdy użytkownik aplikacji kliknie powiadomienie.
Usługi mobilne
Usługi mobilne Google Maps Platform to zbiór interfejsów API i pakietów SDK, które pomagają zaspokajać potrzeby firm transportowych i logistycznych. Klienci korzystający z usług mobilnych używają zwykle pakietu Navigation SDK w połączeniu z powiązanymi usługami do optymalizacji tras, wysyłania zleceń, śledzenia zadań, analizowania floty i innych celów. W przypadku klientów korzystających z usług mobilności pakiet SDK do nawigacji jest też rozliczany inaczej. Więcej informacji znajdziesz w dokumentacji usług mobilnych.
Usługi mobilności są dostępne tylko dla wybranych klientów. Aby uzyskać więcej informacji, skontaktuj się z przedstawicielem handlowym.
ReportBillableEvent
. Tylko klienci korzystający z usług mobilnych powinni dzwonić za pomocą ReportBillableEvent
.
W pakiecie Navigation SDK jest kilka interfejsów API, które są przeznaczone wyłącznie dla klientów usług mobilności, którzy są rozliczani przez Google za każdą transakcję. Jeśli nie jesteś klientem usług mobilnych, te metody nie działają:
Tak, klienci Mobility Services mogą korzystać zarówno z implementacji pakietu Navigation SDK w ramach Mobility Services, jak i z implementacji niezwiązanych z tymi usługami. W aplikacji możesz jednak używać tylko jednego typu implementacji naraz. Musisz też utworzyć nowy projekt Google Cloud, konto rozliczeniowe i klucz interfejsu API, które będą oddzielone od tych, których używasz w implementacji usług mobilnych. Więcej informacji znajdziesz w omówieniu konfiguracji pakietu Navigation SDK.
Aby dowiedzieć się więcej o korzystaniu z implementacji pakietu Navigation SDK innej niż Usługi mobilne, w tym o migrowaniu aplikacji z jednego typu implementacji na inny, skontaktuj się z przedstawicielem, który zajmuje się Twoim kontem Google.
Uwaga: jeśli nie jesteś klientem usług mobilnych i chcesz dowiedzieć się więcej o kolekcji interfejsów API i pakietów SDK usług mobilnych, skontaktuj się z zespołem sprzedaży Google Maps Platform.