Navigare lungo un percorso

Segui questa guida per tracciare un percorso all'interno della tua app verso una singola destinazione, utilizzando l'SDK Navigation per iOS.

Panoramica

  1. Integra l'SDK Navigation nella tua app, come descritto nella sezione Configurare il progetto.
  2. Configura un GMSMapView.
  3. Chiedi all'utente di accettare i termini e le condizioni e di autorizzare i servizi di localizzazione e le notifiche in background.
  4. Crea un array contenente una o più destinazioni.
  5. Definisci un GMSNavigator per controllare la navigazione passo passo.

Visualizza il codice

Chiedere all'utente le autorizzazioni necessarie

Prima di utilizzare l'SDK Navigation, l'utente deve accettare i termini e condizioni e autorizzare l'utilizzo dei servizi di localizzazione, che è obbligatorio 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, segui questi passaggi:

  1. Aggiungi la chiave NSLocationAlwaysUsageDescription a Info.plist.
  2. Per il valore, 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."

  3. Per visualizzare la finestra di dialogo di autorizzazione, chiama requestAlwaysAuthorization() dell'istanza di Location Manager.

Swift

self.locationManager.requestAlwaysAuthorization()

Objective-C

[_locationManager requestAlwaysAuthorization];

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 mostrare la finestra di dialogo dei termini e 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 (mostrate 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() di Navigator con un array contenente una o più destinazioni (GMSNavigationWaypoint) da visitare. Se il calcolo va a buon fine, il percorso viene mostrato sulla mappa. Per avviare la guida lungo il percorso, a partire dalla prima destinazione, imposta isGuidanceActive su true nel callback.

L'esempio seguente mostra:

  • Creazione di un nuovo percorso con due destinazioni.
  • Avvio della guida.
  • Attivazione delle notifiche di guida in background.
  • (Facoltativo) Simulare il viaggio lungo l'itinerario.
  • (Facoltativo) Impostare la modalità della videocamera su "Segui".

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 saperne di più sugli ID luogo, consulta la pagina ID luogo.

Impostare la 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: auto, bicicletta, a piedi e taxi. In modalità guida e taxi, il percorso dell'utente si basa sulla direzione di marcia; in modalità bici e a piedi, il percorso è rappresentato dalla direzione in cui è rivolto il dispositivo (verso la parte superiore del dispositivo in modalità orizzontale).

Imposta la proprietà travelMode 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à avoidsHighways e avoidsTolls BOOL per evitare autostrade e/o strade a pedaggio lungo un percorso.

Swift

self.mapView.navigator?.avoidsTolls = true

Objective-C

_mapView.navigator.avoidsTolls = YES;

Strumento di ricerca ID luogo

Puoi utilizzare lo strumento di ricerca degli ID luogo 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, a condizione che l'attribuzione a Google non sia coperta. L'SDK Navigation non supporta l'ancoraggio del testo a una latitudine/longitudine sulla mappa o a un'etichetta. Per ulteriori informazioni, vedi Finestre informative.