Segui questa guida per tracciare un percorso all'interno della tua app verso una singola destinazione utilizzando l'SDK Navigation per iOS.
Panoramica
- Integra l'SDK Navigation nella tua app, come descritto nella sezione Configurare il progetto.
- Configura un
GMSMapView. - Chiedi all'utente di accettare i termini e le condizioni e di autorizzare i servizi di localizzazione e le notifiche in background.
- Crea un array contenente una o più destinazioni.
Definisci un
GMSNavigatorper controllare la navigazione passo passo.- Aggiungi le destinazioni utilizzando
setDestinations. - Imposta
isGuidanceActivesutrueper avviare la navigazione. - Utilizza
simulateLocationsAlongExistingRouteper simulare l'avanzamento del veicolo lungo il percorso per testare, eseguire il debug e mostrare la tua app.
- Aggiungi le destinazioni utilizzando
Visualizzare il codice
Chiedere all'utente le autorizzazioni necessarie
Prima di utilizzare l'SDK Navigation, l'utente deve accettare i termini e le condizioni e autorizzare l'utilizzo dei servizi di localizzazione, necessari per la navigazione. Se la tua app verrà eseguita in background, deve anche chiedere all'utente di autorizzare le notifiche di avviso di guida. Questa sezione mostra come visualizzare le richieste di autorizzazione necessarie.
Autorizzare i servizi di localizzazione
L'SDK Navigation utilizza i servizi di localizzazione, che richiedono l'autorizzazione dell'utente. Per attivare i servizi di localizzazione e visualizzare la finestra di dialogo di autorizzazione:
Attiva le funzionalità di localizzazione e background in Xcode:
- Apri la destinazione in Xcode e seleziona la scheda Signing &Capabilities (Firma e funzionalità). Per maggiori dettagli, consulta la guida di Apple su come aggiungere funzionalità alla tua app.
- Aggiungi le funzionalità Location (Always) (Localizzazione (sempre)) e Location (When In Use) (Localizzazione (quando in uso)). Nel campo di testo di ciascuna, aggiungi una breve spiegazione del motivo per cui la tua app richiede i servizi di localizzazione (ad esempio: "Questa app ha bisogno dell'autorizzazione per utilizzare i servizi di localizzazione per la navigazione passo passo").
- Aggiungi la funzionalità Background Modes (Modalità background), quindi seleziona la casella di controllo Location updates (Aggiornamenti della localizzazione). Senza questa funzionalità, l'app si arresta in modo anomalo all'avvio della navigazione. Per maggiori dettagli, consulta la guida di Apple su lla gestione degli aggiornamenti della localizzazione in background.
Per visualizzare la finestra di dialogo di autorizzazione, chiama il
requestAlwaysAuthorization()metodo dell'istanza del gestore della localizzazione.
Swift
self.locationManager.requestAlwaysAuthorization()
Objective-C
[_locationManager requestAlwaysAuthorization];
Consulta la documentazione completa di Apple per l'autorizzazione dei servizi di localizzazione.
Autorizzare le notifiche di avviso per la guida in background
L'SDK Navigation ha bisogno dell'autorizzazione dell'utente per fornire notifiche di avviso quando l'app è in esecuzione in background. Aggiungi il seguente codice per chiedere all'utente l'autorizzazione a visualizzare queste notifiche:
Swift
UNUserNotificationCenter.current().requestAuthorization(options: [.alert]) {
granted, error in
// Handle denied authorization to display notifications.
if !granted || error != nil {
print("User rejected request to display notifications.")
}
}
Objective-C
// Request authorization for alert notifications.
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
UNAuthorizationOptions options = UNAuthorizationOptionAlert;
[center requestAuthorizationWithOptions:options
completionHandler:
^(
BOOL granted,
NSError *_Nullable error) {
if (!error && granted) {
NSLog(@"iOS Notification Permission: newly Granted");
} else {
NSLog(@"iOS Notification Permission: Failed or Denied");
}
}];
Accettare i termini e le condizioni
Utilizza il seguente codice per visualizzare la finestra di dialogo dei termini e delle condizioni e attivare la navigazione quando l'utente accetta i termini. Tieni presente che questo esempio include il codice per i servizi di localizzazione e le notifiche di avviso di guida (mostrati in precedenza).
Swift
let termsAndConditionsOptions = GMSNavigationTermsAndConditionsOptions(companyName: "Ride Sharing Co.")
GMSNavigationServices.showTermsAndConditionsDialogIfNeeded(
with: termsAndConditionsOptions) { termsAccepted in
if termsAccepted {
// Enable navigation if the user accepts the terms.
self.mapView.isNavigationEnabled = true
self.mapView.settings.compassButton = true
// Request authorization to use location services.
self.locationManager.requestAlwaysAuthorization()
// Request authorization for alert notifications which deliver guidance instructions
// in the background.
UNUserNotificationCenter.current().requestAuthorization(options: [.alert]) {
granted, error in
// Handle rejection of notification authorization.
if !granted || error != nil {
print("Authorization to deliver notifications was rejected.")
}
}
} else {
// Handle rejection of terms and conditions.
}
}
Objective-C
GMSNavigationTermsAndConditionsOptions *termsAndConditionsOptions = [[GMSNavigationTermsAndConditionsOptions alloc] initWithCompanyName:@"Ride Sharing Co."];
[GMSNavigationServices
showTermsAndConditionsDialogIfNeededWithOptions:termsAndConditionsOptions
callback:^(BOOL termsAccepted) {
if (termsAccepted) {
// Enable navigation if the user accepts the terms.
_mapView.navigationEnabled = YES;
_mapView.settings.compassButton = YES;
// Request authorization to use the current device location.
[_locationManager requestAlwaysAuthorization];
// Request authorization for alert notifications which deliver guidance instructions
// in the background.
UNUserNotificationCenter *center = [UNUserNotificationCenter currentNotificationCenter];
UNAuthorizationOptions options = UNAuthorizationOptionAlert;
[center requestAuthorizationWithOptions:options
completionHandler:
^(
BOOL granted,
NSError *_Nullable error) {
if (!error && granted) {
NSLog(@"iOS Notification Permission: newly Granted");
} else {
NSLog(@"iOS Notification Permission: Failed or Denied");
}
}];
} else {
// Handle rejection of the terms and conditions.
}
}];
Creare un percorso e avviare la guida
Per tracciare un percorso, chiama il metodo setDestinations del navigatore con un array di
una o più
GMSNavigationWaypoint
destinazioni da visitare. Se il percorso viene calcolato correttamente, viene visualizzato sulla mappa. Per avviare la guida lungo il percorso, imposta isGuidanceActive su true nel callback.
L'esempio seguente mostra:
- Creazione di un nuovo percorso con una destinazione.
- Avvio della guida.
- Attivazione delle notifiche di guida in background.
- Simulazione del viaggio lungo il percorso (facoltativo).
- Impostazione della modalità della fotocamera su "segui" (facoltativo).
Swift
func startNav() {
var destinations = [GMSNavigationWaypoint]()
destinations.append(GMSNavigationWaypoint.init(placeID: "ChIJnUYTpNASkFQR_gSty5kyoUk",
title: "PCC Natural Market")!)
mapView.navigator?.setDestinations(destinations) { routeStatus in
self.mapView.navigator?.isGuidanceActive = true
self.mapView.locationSimulator?.simulateLocationsAlongExistingRoute()
self.mapView.cameraMode = .following
}
}
Objective-C
- (void)startNav {
NSArray<GMSNavigationWaypoint *> *destinations =
@[[[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJnUYTpNASkFQR_gSty5kyoUk"
title:@"PCC Natural Market"]];
[_mapView.navigator setDestinations:destinations
callback:^(GMSRouteStatus routeStatus){
[_mapView.locationSimulator simulateLocationsAlongExistingRoute];
_mapView.navigator.guidanceActive = YES;
_mapView.cameraMode = GMSNavigationCameraModeFollowing;
}];
}
Per scoprire di più sugli ID luogo, consulta la pagina ID luogo.
Scenari con più fermate
Puoi configurare un massimo di 25 waypoint.
Il metodo setDestinations non supporta i viaggi con più fermate. Utilizza
continueToNextDestinationWithCompletion()
per spostare il waypoint alla tappa successiva del viaggio.
Impostare la modalità di viaggio
La modalità di viaggio definisce sia il tipo di percorso da recuperare sia il modo in cui determinare la direzione dell'utente. Puoi impostare una delle quattro modalità di viaggio per un percorso: auto, bicicletta, a piedi e taxi. In modalità auto e taxi, la direzione dell'utente si basa sulla direzione di viaggio; in modalità bicicletta e a piedi, la direzione è rappresentata dalla direzione verso cui è rivolto il dispositivo (verso la parte superiore del dispositivo in modalità orizzontale).
Imposta la
travelMode
proprietà della visualizzazione della mappa, come mostrato nell'esempio seguente:
Swift
self.mapView.travelMode = .cycling
Objective-C
_mapView.travelMode = GMSNavigationTravelModeCycling;
Impostare le strade da evitare
Utilizza le proprietà BOOL avoidsHighways e avoidsTolls per evitare autostrade, strade a pedaggio o entrambe lungo un percorso.
Swift
self.mapView.navigator?.avoidsTolls = true
Objective-C
_mapView.navigator.avoidsTolls = YES;
Strumento per la ricerca degli ID luogo
Puoi utilizzare lo strumento per la ricerca degli ID luogo PlaceID Finder
per trovare gli ID luogo da utilizzare per le destinazioni del percorso. Aggiungi una destinazione da un
placeID con GMSNavigationWaypoint.
Testo mobile
Puoi aggiungere testo mobile ovunque nella tua app, purché l'attribuzione a Google non sia coperta. L'SDK Navigation non supporta l'ancoraggio del testo a coordinate specifiche (latitudine, longitudine) sulla mappa o a un'etichetta. Per maggiori informazioni, consulta la pagina Finestre informative.