Routenführung

Folgen Sie dieser Anleitung, um mit dem Navigation SDK for iOS eine Route zu einem einzelnen Ziel in Ihrer App zu planen.

Übersicht

  1. Integrieren Sie das Navigation SDK in Ihre App, wie im Abschnitt Projekt einrichten beschrieben.
  2. Konfigurieren Sie einen GMSMapView.
  3. Bitten Sie den Nutzer, die Nutzungsbedingungen zu akzeptieren und Standortdienste und Benachrichtigungen im Hintergrund zu autorisieren.
  4. Erstellen Sie ein Array mit einem oder mehreren Zielen.
  5. Definieren Sie eine GMSNavigator, um die Schritt-für-Schritt-Navigation zu steuern.

Code

Nutzer um die erforderlichen Autorisierungen bitten

Bevor der Nutzer das Navigations-SDK verwenden kann, muss er den Nutzungsbedingungen zustimmen und die Verwendung von Standortdiensten autorisieren, was für die Navigation erforderlich ist. Wenn Ihre App im Hintergrund ausgeführt wird, muss sie den Nutzer auch auffordern, Benachrichtigungen zu Wegbeschreibungen zu autorisieren. In diesem Abschnitt wird gezeigt, wie Sie die erforderlichen Autorisierungsaufforderungen anzeigen.

Standortdienste autorisieren

Das Navigations-SDK verwendet Standortdienste, für die eine Nutzerautorisierung erforderlich ist. So aktivieren Sie die Standortdienste und rufen Sie den Autorisierungsdialog auf:

  1. Fügen Sie den Schlüssel NSLocationAlwaysUsageDescription zu Info.plist hinzu.
  2. Geben Sie als Wert eine kurze Erklärung dazu an, warum Ihre App Standortdienste benötigt. Beispiel: „Diese App benötigt die Berechtigung, Standortdienste für die detaillierte Navigation zu verwenden.“

  3. Rufen Sie requestAlwaysAuthorization() der Standortmanagerinstanz auf, um das Autorisierungsdialogfeld anzuzeigen.

Swift

self.locationManager.requestAlwaysAuthorization()

Objective-C

[_locationManager requestAlwaysAuthorization];

Benachrichtigungen für Hintergrundinformationen autorisieren

Das Navigation SDK benötigt die Nutzerberechtigung, um Benachrichtigungen zu senden, wenn die App im Hintergrund ausgeführt wird. Fügen Sie den folgenden Code hinzu, um den Nutzer um Erlaubnis 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");
     }
   }];

Nutzungsbedingungen akzeptieren

Mit dem folgenden Code wird das Dialogfeld mit den Nutzungsbedingungen angezeigt und die Navigation aktiviert, wenn der Nutzer die Nutzungsbedingungen akzeptiert. Dieses Beispiel enthält den Code für Standortdienste und Benachrichtigungen zu Wegbeschreibungen (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

Wenn Sie eine Route planen möchten, rufen Sie die setDestinations()-Methode des Navigationssystems mit einem Array auf, das ein oder mehrere Ziele (GMSNavigationWaypoint) enthält, die Sie besuchen möchten. Wenn die Route erfolgreich berechnet wurde, wird sie auf der Karte angezeigt. Wenn Sie die Navigation entlang der Route starten möchten, beginnend mit dem ersten Ziel, legen Sie im Rückruf isGuidanceActive auf true fest.

Im folgenden Beispiel wird gezeigt:

  • Erstellen Sie eine neue Route mit zwei Zielen.
  • Startanleitung
  • Benachrichtigungen für die Hintergrundnavigation aktivieren
  • Fahrt entlang der Route simulieren (optional)
  • Kameramodus auf „Folgen“ stellen (optional)

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

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

Mobilitätsform?

Der Mobilitätsmodus bestimmt, welche Art von Route abgerufen wird und wie der Kurs des Nutzers bestimmt wird. Sie können für eine Route einen der vier Verkehrsmitteltypen festlegen: Auto, Fahrrad, Fußgänger und Taxi. Im Fahr- und Taximodus basiert der Kurs des Nutzers auf der Fahrtrichtung. Im Fahrrad- und Fußgängermodus wird der Kurs durch die Richtung dargestellt, in die das Gerät zeigt.

Legen Sie die Property travelMode für die Kartenansicht fest, wie im folgenden Beispiel gezeigt:

Swift

self.mapView.travelMode = .cycling

Objective-C

_mapView.travelMode = GMSNavigationTravelModeCycling;

Zu vermeidende Straßen festlegen

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

Swift

self.mapView.navigator?.avoidsTolls = true

Objective-C

_mapView.navigator.avoidsTolls = YES;

PlaceID-Finder

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

Schwebender Text

Sie können Text überall in Ihrer App einfügen, solange die Google-Attribution nicht verdeckt wird. Das Navigation SDK unterstützt nicht das Anpinnen von Text an einen Breiten-/Längengrad auf der Karte oder an ein Label. Weitere Informationen finden Sie unter Infofenster.