Routenführung

In diesem Leitfaden erfahren Sie, wie Sie mit dem Navigation SDK for iOS eine Route in Ihrer App zu einem einzelnen Ziel planen.

Übersicht

  1. Binden Sie das Navigation SDK in Ihre App ein, wie im Abschnitt Projekt einrichten beschrieben.
  2. Konfigurieren Sie eine GMSMapView.
  3. Fordern Sie den Nutzer auf, die Nutzungsbedingungen zu akzeptieren und Standortdienste und Hintergrundbenachrichtigungen zu autorisieren.
  4. Erstellen Sie ein Array mit einem oder mehreren Zielen.
  5. Definieren Sie ein GMSNavigator, um die detaillierte Routenführung zu steuern.

Code

Nutzer nach den erforderlichen Autorisierungen fragen

Bevor der Nutzer das Navigation SDK verwenden kann, muss er den Nutzungsbedingungen zustimmen und die Verwendung von Standortdiensten autorisieren, die für die Navigation erforderlich sind. Wenn Ihre App im Hintergrund ausgeführt wird, muss der Nutzer auch aufgefordert werden, Benachrichtigungen für Navigationshinweise zu autorisieren. In diesem Abschnitt wird beschrieben, wie Sie die erforderlichen Autorisierungsaufforderungen anzeigen.

Standortdienste autorisieren

Das Navigation SDK verwendet Standortdienste, für die eine Nutzerautorisierung erforderlich ist. So aktivieren Sie die Standortdienste und zeigen das Autorisierungsdialogfeld an:

  1. Fügen Sie den NSLocationAlwaysUsageDescription-Schlüssel zu Info.plist hinzu.
  2. Fügen Sie für den Wert eine kurze Erklärung hinzu, warum Ihre App Standortdienste benötigt. Beispiel: „Diese App benötigt die Berechtigung zur Verwendung von Standortdiensten für die Turn-by-Turn-Navigation.“

  3. Rufen Sie requestAlwaysAuthorization() der Standortmanager-Instanz auf, um das Autorisierungsdialogfeld anzuzeigen.

Swift

self.locationManager.requestAlwaysAuthorization()

Objective-C

[_locationManager requestAlwaysAuthorization];

Benachrichtigungen für Hintergrundanleitung autorisieren

Das Navigation SDK benötigt die Nutzerberechtigung, um Warnbenachrichtigungen zu senden, wenn die App im Hintergrund ausgeführt wird. Fügen Sie den folgenden Code hinzu, um den Nutzer um die Berechtigung zum Anzeigen dieser Benachrichtigungen zu bitten:

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");
     }
   }];

Akzeptieren Sie die Nutzungsbedingungen.

Mit dem folgenden Code wird das Dialogfeld mit den Nutzungsbedingungen angezeigt und die Navigation aktiviert, wenn der Nutzer die Bedingungen akzeptiert. Dieses Beispiel enthält den Code für Standortdienste und Benachrichtigungen für Navigationshinweise (siehe oben).

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.
   }
 }];

Route erstellen und Navigation starten

Rufen Sie zum Planen einer Route die setDestinations()-Methode des Navigators mit einem Array mit einem oder mehreren zu besuchenden Zielen (GMSNavigationWaypoint) auf. Wenn die Berechnung erfolgreich war, wird die Route auf der Karte angezeigt. Wenn Sie die Führung entlang der Route starten möchten, legen Sie im Callback isGuidanceActive auf true fest.

Im folgenden Beispiel wird gezeigt:

  • Eine neue Route mit einem Ziel erstellen
  • Anleitung starten
  • Benachrichtigungen für die Hintergrundanleitung aktivieren
  • Reise entlang der Route simulieren (optional)
  • Optional: Kameramodus auf „Folgen“ einstellen.

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;
                             }];
}

Weitere Informationen zu Orts-IDs finden Sie unter Orts-IDs.

Szenarien mit mehreren Zwischenstopps

Sie können maximal 25 Wegpunkte konfigurieren.

Die setDestinations-Methode unterstützt keine Routen mit mehreren Zwischenstopps. Verwenden Sie continueToNextDestination(), um den Wegpunkt zum nächsten Abschnitt der Reise zu verschieben.

Mobilitätsform?

Der Fortbewegungsmodus bestimmt, welcher Routentyp abgerufen wird und wie der Kurs des Nutzers ermittelt wird. Sie können für eine Route eine von vier Mobilitätsformen festlegen: Auto, Fahrrad, Fußweg und Taxi. Im Fahr- und Taximodus wird der Kurs des Nutzers anhand der Fahrtrichtung bestimmt. Im Fahrrad- und Laufmodus wird der Kurs durch die Richtung dargestellt, in die das Gerät zeigt (im Querformat nach oben).

Legen Sie die Eigenschaft travelMode der Kartenansicht fest, wie im folgenden Beispiel gezeigt:

Swift

self.mapView.travelMode = .cycling

Objective-C

_mapView.travelMode = GMSNavigationTravelModeCycling;

Zu vermeidende Straßen festlegen

Mit den Attributen avoidsHighways und avoidsTolls BOOL können Sie Autobahnen und/oder Mautstraßen auf einer Route vermeiden.

Swift

self.mapView.navigator?.avoidsTolls = true

Objective-C

_mapView.navigator.avoidsTolls = YES;

Orts-ID-Suche

Mit dem PlaceID Finder können Sie Orts-IDs für Routenziele finden. Fügen Sie mit GMSNavigationWaypoint ein Ziel aus einem placeID hinzu.

Unverankerte Texte

Sie können schwebenden Text an beliebiger Stelle in Ihrer App einfügen, solange die Google-Quellenangabe nicht verdeckt wird. Das Navigation SDK unterstützt nicht das Verankern des Texts an einem Breiten-/Längengrad auf der Karte oder an einem Label. Weitere Informationen finden Sie unter Infofenster.