Segui questa guida per tracciare un percorso all'interno della tua app verso una singola destinazione utilizzando l'SDK di navigazione per iOS.
Panoramica
- Integra l'SDK di navigazione nella tua app, come descritto nella sezione Configurare il progetto.
- Configurare una
GMSMapView
. - Chiedi all'utente di accettare i Termini e condizioni e autorizza i servizi di geolocalizzazione e le notifiche in background.
- Crea un array contenente una o più destinazioni.
Definisci un valore
GMSNavigator
per controllare la navigazione passo passo.- Aggiungi destinazioni utilizzando
setDestinations
. - Imposta
isGuidanceActive
sutrue
per avviare la navigazione. - Utilizza
simulateLocationsAlongExistingRoute
per simulare l'avanzamento del veicolo lungo il percorso, per testare, eseguire il debug e dimostrare la tua app.
- Aggiungi destinazioni utilizzando
Visualizza il codice
Chiedi all'utente le autorizzazioni necessarie
Prima di utilizzare l'SDK di navigazione, l'utente deve accettare i termini e le condizioni e autorizzare l'utilizzo dei servizi di geolocalizzazione, necessari per la navigazione. Se l'app verrà eseguita in background, deve anche chiedere all'utente di autorizzare le notifiche di avviso di indicazione. Questa sezione mostra come visualizzare le richieste di autorizzazione richieste.
Autorizza servizi di geolocalizzazione
L'SDK di navigazione utilizza i servizi di geolocalizzazione, che richiedono l'autorizzazione dell'utente. Per attivare i servizi di geolocalizzazione e visualizzare la finestra di dialogo dell'autorizzazione, procedi nel seguente modo:
- Aggiungi la chiave
NSLocationAlwaysUsageDescription
aInfo.plist
. Per il valore, aggiungi una breve spiegazione del motivo per cui la tua app richiede i servizi di geolocalizzazione. Ad esempio: "Questa app richiede l'autorizzazione per usare i servizi di geolocalizzazione per la navigazione passo passo".
Per visualizzare la finestra di dialogo dell'autorizzazione, chiama
requestAlwaysAuthorization()
dell'istanza del gestore di località.
Swift
self.locationManager.requestAlwaysAuthorization()
Objective-C
[_locationManager requestAlwaysAuthorization];
Autorizza le notifiche di avviso per ricevere indicazioni in background
L'SDK di navigazione richiede l'autorizzazione dell'utente per fornire notifiche di avviso quando l'app è in esecuzione in background. Aggiungi il seguente codice per richiedere 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");
}
}];
Accetta i Termini e condizioni
Utilizza il seguente codice per visualizzare la finestra di dialogo Termini e condizioni e abilitare la navigazione quando l'utente accetta i termini. Tieni presente che questo esempio include il codice per i servizi di geolocalizzazione e le notifiche di avviso (mostrati in precedenza).
Swift
let companyName = "Ride Sharing Co."
GMSNavigationServices.showTermsAndConditionsDialogIfNeeded(
withCompanyName: companyName) { 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
NSString *companyName = @"Ride Sharing Co.";
[GMSNavigationServices
showTermsAndConditionsDialogIfNeededWithCompanyName:companyName
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.
}
}];
Crea un percorso e avvia le indicazioni stradali
Per tracciare un percorso, chiama il metodo setDestinations()
del navigatore con un array
contenente una o più destinazioni (GMSNavigationWaypoint
) da visitare. Se il calcolo viene eseguito correttamente, la route viene mostrata sulla mappa. Per avviare le indicazioni lungo il percorso,
partendo dalla prima destinazione, imposta isGuidanceActive
su true
nella callback.
Nell'esempio seguente:
- Creazione di un nuovo percorso con due destinazioni.
- Avvio della guida.
- Attivazione delle notifiche delle indicazioni in background.
- Simulazione di un viaggio lungo il percorso (facoltativo).
- Imposta la modalità della fotocamera su "Segui" (facoltativo).
Swift
func startNav() {
var destinations = [GMSNavigationWaypoint]()
destinations.append(GMSNavigationWaypoint.init(placeID: "ChIJnUYTpNASkFQR_gSty5kyoUk",
title: "PCC Natural Market")!)
destinations.append(GMSNavigationWaypoint.init(placeID:"ChIJJ326ROcSkFQRBfUzOL2DSbo",
title:"Marina Park")!)
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"],
[[GMSNavigationWaypoint alloc] initWithPlaceID:@"ChIJJ326ROcSkFQRBfUzOL2DSbo"
title:@"Marina Park"]];
[_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 l'articolo ID luogo.
Imposta modalità di viaggio
La modalità di viaggio determina il tipo di percorso che verrà recuperato e il modo in cui viene determinato il percorso dell'utente. Puoi impostare una delle quattro modalità di viaggio per un percorso: in auto, in bicicletta, a piedi e in taxi. In modalità auto e taxi, la rotta dell'utente si basa sulla direzione di marcia; nelle modalità a piedi e in bicicletta il percorso è rappresentato dalla direzione su cui il dispositivo è rivolto.
Imposta la proprietà travelMode
della visualizzazione mappa, come mostrato nell'esempio seguente:
Swift
self.mapView.travelMode = .cycling
Objective-C
_mapView.travelMode = GMSNavigationTravelModeCycling;
Imposta le strade da evitare
Utilizza le proprietà avoidsHighways
e avoidsTolls
BOOL
per evitare
strade e/o strade a pedaggio lungo un percorso.
Swift
self.mapView.navigator?.avoidsTolls = true
Objective-C
_mapView.navigator.avoidsTolls = YES;
Ricerca PlaceID
Puoi utilizzare PlaceID Finder per trovare gli ID luogo da utilizzare per le destinazioni dei percorsi.
Testo mobile
Puoi aggiungere testo mobile in qualsiasi punto dell'app, purché l'attribuzione Google non sia coperta. L'SDK di navigazione non supporta l'ancoraggio del testo a latitudine/longitudine sulla mappa o a un'etichetta. Per ulteriori informazioni, consulta la sezione Finestre informative.