Routenführung

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

Überblick

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

Code

Nutzer um die erforderlichen Autorisierungen bitten

Bevor der Nutzer das Navigation SDK verwenden kann, muss er den Nutzungsbedingungen zustimmen und die Nutzung der Standortdienste autorisieren, die für die Navigation erforderlich sind. Wenn Ihre App im Hintergrund ausgeführt wird, muss der Nutzer auch aufgefordert werden, Benachrichtigungen zu Routenführungswarnungen zu autorisieren. In diesem Abschnitt wird beschrieben, wie die erforderlichen Autorisierungsaufforderungen angezeigt werden.

Standortdienste autorisieren

Das Navigation SDK verwendet Standortdienste, für die eine Nutzerautorisierung erforderlich ist. So aktivieren Sie die Standortdienste und rufen das Dialogfeld für die Autorisierung auf:

  1. Fügen Sie Info.plist den Schlüssel NSLocationAlwaysUsageDescription hinzu.
  2. Erläutern Sie als Wert kurz, warum Ihre App Standortdienste benötigt. Beispiel: „Diese App benötigt die Berechtigung, Standortdienste für die detaillierte Routenführung zu verwenden.“

  3. Rufen Sie requestAlwaysAuthorization() der Standortmanager-Instanz auf, um das Dialogfeld für die Autorisierung aufzurufen.

Swift

self.locationManager.requestAlwaysAuthorization()

Objective-C

[_locationManager requestAlwaysAuthorization];

Benachrichtigungen zu Hintergrundinformationen autorisieren

Das Navigation SDK benötigt eine Nutzerberechtigung, um Warnmeldungen 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 aufzufordern:

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

Verwenden Sie den folgenden Code, um das Dialogfeld mit den Nutzungsbedingungen aufzurufen und die Navigation zu aktivieren, wenn der Nutzer die Nutzungsbedingungen akzeptiert. Dieses Beispiel enthält den Code für Standortdienste und Benachrichtigungen zu Routenführungsbenachrichtigungen (siehe oben).

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

Route erstellen und Navigation starten

Wenn Sie eine Route darstellen möchten, rufen Sie die setDestinations()-Methode des Navigators mit einem Array auf, das ein oder mehrere Ziele (GMSNavigationWaypoint) enthält. Wenn die Route erfolgreich berechnet wurde, wird sie auf der Karte angezeigt. Um die Routenführung zu starten, beginnen Sie mit dem ersten Ziel, indem Sie isGuidanceActive im Callback auf true setzen.

Im nachfolgenden Beispiel wird Folgendes dargestellt:

  • Erstellen einer neuen Route mit zwei Zielorten
  • Anleitung wird gestartet.
  • Benachrichtigungen zur Hintergrundführung werden aktiviert.
  • Fahrt entlang der Route simulieren (optional).
  • Kameramodus auf „Folgen“ einstellen (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?

Die Mobilitätsform bestimmt, welche Art von Route abgerufen wird und wie der Kurs des Nutzers bestimmt wird. Sie können eine von vier Mobilitätsformen für eine Route festlegen: Auto, Fahrrad, zu Fuß oder Taxi. Im Auto- und Taximodus richtet sich der Kurs des Nutzers nach der Fahrtrichtung. Im Fahrrad- und Fußgängermodus wird der Kurs durch die Richtung dargestellt, in die das Gerät zeigt.

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

Verwende die BOOL-Properties avoidsHighways und avoidsTolls, um Autobahnen und/oder Mautstraßen entlang einer Route zu vermeiden.

Swift

self.mapView.navigator?.avoidsTolls = true

Objective-C

_mapView.navigator.avoidsTolls = YES;

Orts-ID-Finder

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

Unverankerter Text

Sie können überall in Ihrer App unverankerten Text hinzufügen, sofern die Google-Attribution nicht abgedeckt ist. Das Navigation SDK unterstützt keine Verankerung des Texts an einem Breiten- und Längengrad auf der Karte oder mit einem Label. Weitere Informationen finden Sie unter Infofenster.