Domande frequenti

Dettagli del prodotto

Problemi

Rete

Dati

Personalizzazione dell'interfaccia utente

Routing

Simulatore

Workflows

Servizi di mobilità

Dettagli del prodotto

La tua app deve implementare una finestra di dialogo con la notifica dei Termini di servizio dell'SDK di navigazione che ogni conducente deve accettare. Questa finestra di dialogo offre al conducente l'opportunità di accettare i Termini di servizio. Un file di testo dei termini è fornito con l'SDK Navigation.
In Android, utilizza il metodo NavigationApi.showTermsAndConditionsDialog per visualizzare la finestra di dialogo contenente i termini.
In iOS, chiama GMSNavigationServices.showTermsAndConditionsDialogIfNeededWithCompanyName.
Tutte le lingue supportate da Google Maps Mobile sono automaticamente disponibili per l'SDK Navigation. Un dispositivo ha una lingua di sistema predefinita e un'app non può modificare questa impostazione. Tuttavia, l'app ha accesso a oltre 70 lingue.

Sì. In Android, una volta avviato, LocationListener continua a eseguire in background. L'app continua a scattare foto della strada e mantiene la rotta.

In iOS, per continuare a ricevere aggiornamenti sulla posizione e sull'orientamento in background, implementa l'aggancio alla strada e imposta allowsBackgroundLocationUpdates su YES.

Sì. Quando un percorso viene creato o modificato, RouteChangeListener fornisce polilinee.

No, l'SDK Navigation non richiede l'installazione di Google Maps Mobile sul dispositivo.
No, al momento l'SDK Navigation non fornisce questa funzionalità.
Sì. La direzione del traffico è disponibile e visualizzata per impostazione predefinita.

Problemi

In Xcode 12, le app non vengono compilate correttamente per il simulatore. Come faccio a risolvere il problema?

Per risolvere il problema, apri le impostazioni di compilazione del progetto Xcode e aggiungi arm64 a Excluded Architectures solo per le build "Simulatore iOS".

Per ulteriori informazioni, consulta il seguente thread di StackOverflow.

GMSMapView non si carica.

Se GMSMapView non si carica:

  • Verifica che NavSDK sia abilitato nella console Cloud.
  • Se l'SDK Nav è installato, ma il tuo progetto non utilizza le API SDK Nav, rimuovilo dal file binario.

Rete

In che modo l'SDK Navigation gestisce la scarsa connettività?
L'SDK Navigation memorizza in cache in anticipo il percorso per ogni tragitto. Le informazioni memorizzate nella cache includono informazioni sui percorsi per 15-20 minuti e alternative al percorso nel caso in cui il conducente scostasse dal percorso. L'SDK Navigation approssima la posizione utilizzando il GPS e i sensori del dispositivo.
È disponibile una modalità offline?
No, al momento l'SDK Navigation non offre una modalità offline. Tuttavia, l'SDK fornisce informazioni pre-memorizzate nella cache per un viaggio.

Dati

Posso recuperare tutte le fermate/destinazioni di un viaggio prima di iniziare il percorso?

Sì. In Android, per recuperare le indicazioni stradali per un percorso, chiama Navigator.getRouteSegments().

Su iOS, chiama GMSNavigator.routeLegs(read).

Le indicazioni stradali passo passo sono disponibili all'inizio di un percorso?
Sì. L'SDK Navigation fornisce un elenco di segmenti di percorso. Inoltre, il conducente può scorrere la scheda delle indicazioni stradali nell'intestazione per visualizzare ogni manovra.
In che modo l'orario di arrivo stimato viene comunicato agli utenti dell'app?

In Android, segui questi passaggi per fornire informazioni sull'orario di arrivo stimato agli utenti dell'app:

  1. Recupera il tempo e la distanza per tutti i waypoint utilizzando Navigator.getTimeAndDistanceList().
  2. Inoltra queste informazioni all'applicazione client come accade attualmente per l'orario di arrivo stimato del conducente.

Su iOS, segui questi passaggi per fornire informazioni sull'orario di arrivo stimato agli utenti dell'app:

  1. Recupera le tratte del percorso utilizzando Navigator.getRouteSegments().
  2. Chiama GMSNavigator.timeToNextDestination per ogni tratta del viaggio.
  3. Inoltra le informazioni sull'ora all'applicazione client come attualmente fai per l'orario di arrivo stimato del conducente.
L'RoadSnappedLocationProvider può essere utilizzato per ottenere la posizione acquisita corrente del conducente se la navigazione non è in primo piano?

Sì. In Android, RoadSnappedLocationProvider viene eseguito in background per impostazione predefinita.

In iOS, per mantenere la navigazione in esecuzione in background, implementa l'ascoltatore per GMSRoadSnappedLocationProviderListener e imposta la proprietà allowsBackgroundLocationUpdates su TRUE.

L'SDK Navigation supporta il geofencing?

No. Nel contesto della navigazione, remainingTimeOrdistanceChangeListener ha un vantaggio rispetto a un semplice recinto virtuale. Il recinto virtuale potrebbe non tenere conto della geometria stradale e potrebbe non essere centrato sul punto esatto verso cui il conducente sta navigando.

Puoi approssimare questa funzionalità utilizzando remainingTimeOrdistanceChangeListener.

  1. Imposta la soglia per determinare la frequenza dei richiami.
  2. Controlla la distanza rimanente per raggiungere la destinazione.

Ad esempio, se imposti la soglia su 100 m, ricevi un callback quando la distanza dalla destinazione cambia di 100 m. Man mano che la distanza diminuisce, puoi aggiornare questa soglia impostando un valore inferiore e ricevere chiamate di ritorno più frequenti. Poi, controlla la distanza rimanente per determinare se sei abbastanza vicino alla stazione di ritiro/consegna.

In iOS, implementa l'ascoltatore GMSNavigatorListener.didUpdateRemainingDistance per gestire la distanza tra le notifiche.

Posso disattivare le notifiche quando l'app Navigazione è in background?

Sì. Su Android, usa Navigator.setHeadsUpNotificationEnabled per controllare le notifiche. Questo metodo ha un argomento booleano. FALSE disattiva le notifiche; TRUE attiva le notifiche.

In iOS, disattiva la notifica in background per le posizioni acquisite con fotocamera stradale impostando GMSRoadSnappedLocationProvider.allowsBackgroundLocationUpdates su NO.

Per disattivare l'elaborazione in background per altre notifiche sulla posizione, chiama GMSNavigator.sendsBackgroundNotifications(NO).

Personalizzazione dell'interfaccia utente

Posso assegnare un codice colore all'opzione di percorso migliore?
No. Al momento non è supportata la codifica a colori di un'opzione di percorso specifica.
L'SDK di navigazione può mostrare l'orario di arrivo stimato per la destinazione finale?

Sì. In Android, utilizza i seguenti metodi:

  1. Recupera il tempo e la distanza per tutti i waypoint utilizzando Navigator.getTimeAndDistanceList().
  2. Nascondi l'orario di arrivo stimato del waypoint corrente utilizzando NavigationFragment.setEtaCardEnabled(false).
  3. Mostra l'orario di arrivo stimato alla destinazione finale.

In iOS, utilizza quanto segue:

  1. Chiama il numero GMSNavigator.routeLegs(read).
  2. Per l'ultimo tratto, chiama GMSNavigator.timeToNextDestination.
  3. Nascondi l'orario di arrivo stimato del waypoint corrente impostando MSMapView.settings.navigationFooterEnabled=NO su FALSE.
  4. Mostra l'orario di arrivo stimato alla destinazione finale.
Come faccio a nascondere gli aggiornamenti sull'orario di arrivo?

Puoi disattivare le schede di orario di arrivo stimato con i seguenti metodi:

  • Su Android, utilizza navigationView.setEtaCardEnabled(false).
  • Su iOS, utilizza GMSMapView.settings.navigationFooterEnabled=NO.
Quali personalizzazioni dell'interfaccia utente sono disponibili per le schede intestazione e piè di pagina?

In Android, utilizzi StylingOptions per impostare lo stile del colore di sfondo. Per nascondere o mostrare l'intestazione e il piè di pagina, utilizza le funzioni membro setHeaderEnabled e setFooterEnabled di NavigationFragment.

In iOS, utilizza GMSMapView.settings.navigationHeaderPrimaryBackgroundColor per impostare lo stile del colore di sfondo. Per nascondere o mostrare l'intestazione e il piè di pagina, utilizza le proprietà navigationFooterEnabled e navigationHeaderEnabled di GMSUISettings.

Routing

Posso fornire un percorso specifico a un conducente o rimuovere percorsi alternativi?
No. Per impostazione predefinita, vengono forniti più percorsi e quello più veloce ha la priorità. Puoi modificare il percorso predefinito aggiungendo preferenze alla tua richiesta, ad esempio "Evita superstrade e pedaggi". L'aggiunta di waypoint influisce anche sul percorso.
Posso mostrare all'utente dell'app un'etichetta diversa per la destinazione rispetto alla località di destinazione predefinita?

Sì. In Android, crea un Marker con un titolo personalizzato per la destinazione e la latitudine/longitudine. L'SDK Navigation mostra il titolo personalizzato e le coordinate sul NavigationMap.

In iOS, crei e mostri un GMSMarker per la destinazione.

Posso utilizzare l'SDK Navigation per monitorare le deviazioni da un percorso definito?

Sì. Su Android, usa Navigator.setRouteChangedListener per ricevere notifiche quando un itinerario cambia o quando ne viene consigliato uno nuovo:

  1. Registra un ascoltatore che controlla la posizione del dispositivo lungo il percorso utilizzando il metodo Navigator.setRouteChangedListener.
  2. Aggiungi il codice al gestore dell'evento di callback onRouteChanged:
    • Invia un messaggio all'utente dell'app con informazioni aggiornate sull'orario di arrivo stimato e sulla distanza.
    • Monitorare la posizione del dispositivo.
    • [Facoltativo] Aggiungi altre funzionalità richieste dalla tua app per gestire quando il conducente non è sul percorso prescritto.

In iOS, utilizza GMSNavigator e i relativi ascoltatori per ricevere notifiche quando un itinerario cambia o viene consigliato un nuovo itinerario:

  1. Nel viewController della mappa, implementa il protocollo GMSNavigatorListener e il protocollo GMSRoadSnappedLocationProviderListener.
  2. Implementa GMSNavigatorListener.navigatorDidChangeRoute.
  3. Accedi al nuovo percorso utilizzando le proprietà routeLegs e currentRouteLeg di GMSNavigator.
Il conducente può uscire dalla navigazione senza completare il percorso?

Sì. In Android, chiama il metodo Navigator.stopGuidance() per interrompere la navigazione.

Su iOS, chiama GMSNavigator.clearDestinations.

Simulatore

Il simulatore supporta le modifiche al percorso?

Sì. Su Android, chiama simulateLocationsAlongNewRoute per simulare un viaggio che include una modifica del percorso. Il metodo simulateLocationsAlongExistingRoute ignora le modifiche al percorso esistente.

Su iOS, utilizza GMSLocationSimulator.simulateAlongNewRouteToDestinations per simulare un viaggio che include una modifica del percorso. Se non prevedi modifiche al percorso, puoi utilizzare GMSLocationSimulator.simulateLocationsAlongExistingRoute o GMSLocationSimulator.simulateAlongNewRouteToDestinations.

Workflows

Come faccio a ignorare la notifica dopo aver chiuso un'attività che contiene un frammento di navigazione?

La notifica di navigazione rimane visibile durante la navigazione, quando l'attività è chiusa. Quando il veicolo arriva alla destinazione, la navigazione si interrompe e la notifica scompare.

Per gestire i clic sulla notifica, utilizza Navigator.startGuidance(intent resumeIntent). L'evento resume intent viene attivato quando l'utente dell'app fa clic sulla notifica. In genere, Navigator.startguidance(getIntent()) viene chiamato dalla attività principale, che richiama l'attività quando l'utente dell'app fa clic sulla notifica.

Servizi di mobilità

In che modo l'utilizzo dell'SDK Navigation è diverso per i clienti di Mobility Services?

I servizi di mobilità di Google Maps Platform offrono una raccolta di API e SDK per soddisfare le esigenze delle aziende di trasporto e logistica. Per i clienti di Mobility Services, l'SDK di navigazione viene in genere utilizzato in combinazione con servizi correlati per l'ottimizzazione dei percorsi, l'invio, il monitoraggio delle attività, l'analisi del parco veicoli e altro ancora. Inoltre, l'SDK di navigazione viene fatturato in modo diverso per i clienti di Mobility Services. Per ulteriori informazioni, consulta la documentazione di Mobility Services.

I prodotti per la mobilità sono attualmente disponibili solo per alcuni clienti. Per ulteriori informazioni, contatta il tuo rappresentante di vendita.

Come faccio a sapere se sono un cliente di Mobility Services?
Se non sai con certezza se stai attualmente implementando l'SDK Navigation come cliente di Mobility Services, cerca una chiamata ReportBillableEvent nel codice. Solo i clienti di Mobility Services devono chiamare il metodo ReportBillableEvent.

Come viene fatturato l'SDK Navigation per i clienti di Mobility Services?
Per i clienti di Mobility Services, la fatturazione e i prezzi dell'SDK Navigation dipendono dal contratto di servizio stipulato con Google Maps Platform. Per informazioni su come assicurarti che l'implementazione di Mobility Services venga fatturata correttamente, consulta la sezione Convalida della fatturazione. Per ulteriori informazioni sulla fatturazione di Mobility Services, contatta il tuo rappresentante di vendita.

Quali API SDK di navigazione devono essere utilizzate solo dai clienti di Mobility Services?

Nell'SDK Navigation sono presenti diverse API destinate esclusivamente all'utilizzo da parte dei clienti di Mobility Services, a cui Google fattura su base transazionale. Se non sei un cliente di Mobility Services, i seguenti metodi non sono disponibili:

Se sono un cliente di Mobility Services, posso utilizzare anche un'implementazione dell'SDK di navigazione non Mobility Services?

Sì, i clienti di Mobility Services possono utilizzare sia le implementazioni di Mobility Services sia quelle non di Mobility Services dell'SDK Navigation. Tuttavia, puoi utilizzare un solo tipo di implementazione in un'app alla volta. Devi anche creare un nuovo progetto Google Cloud, un account di fatturazione e una chiave API separati da quelli che utilizzi con l'implementazione di Mobility Services. Per ulteriori informazioni, consulta la panoramica della configurazione dell'SDK Navigation.

Per ulteriori informazioni sull'utilizzo di un'implementazione dell'SDK Navigation non di Mobility Services, inclusa la migrazione di un'app da un tipo di implementazione all'altro, contatta il rappresentante del tuo Account Google.

Nota: se al momento non sei cliente di Mobility Services e vuoi saperne di più sulla raccolta di API e SDK di Mobility Services, contatta il team di vendita di Google Maps Platform.