Routeninformationen abrufen

Folgen Sie dieser Anleitung, um Ihre App einzurichten, um Zeiten, Entfernungen und Streckenabschnitte für die aktuelle Route abzurufen.

Überblick

Um Informationen zur aktuellen Route zu erhalten, rufen Sie das entsprechende Attribut aus der navigator-Instanz ab:

Code

Fahrzeit bis zum nächsten Ziel

Wenn Sie die Fahrzeit bis zum nächsten Ziel wissen lassen möchten, rufen Sie timeToNextDestination() auf. Dies gibt einen NSTimeInterval-Wert zurück. Im folgenden Beispiel wird die Zeit bis zum nächsten Ziel protokolliert:

Swift

if let navigator = mapView.navigator {
  let time = navigator.timeToNextDestination
  let minutes = floor(time/60)
  let seconds = round(time - minutes * 60)
  NSLog("Time to next destination: %.0f:%.0f", minutes, seconds)
}

Objective-C

NSTimeInterval time = _mapView.navigator.timeToNextDestination;
int minutes = floor(time/60);
int seconds = round(time - minutes * 60);
NSLog(@"%@", [NSString stringWithFormat:@"Time to next destination: %i:%i.", minutes, seconds]);

Entfernung zum nächsten Ziel wird abgerufen

Um die Entfernung zum nächsten Ziel zu erfahren, rufen Sie distanceToNextDestination() auf. Dies gibt einen CLLocationDistance-Wert zurück. Die Einheiten werden in Metern angegeben.

Swift

if let navigator = mapView.navigator {
  let distance = navigator.distanceToNextDestination
  let miles = distance * 0.00062137
  NSLog("Distance to next destination: %.2f miles.", miles)
}

Objective-C

CLLocationDistance distance = _mapView.navigator.distanceToNextDestination;
double miles = distance * 0.00062137;
NSLog(@"%@", [NSString stringWithFormat:@"Distance to next destination: %.2f.", miles]);

Die Verkehrslage zum nächsten Ziel wird abgerufen

Rufen Sie delayCategoryToNextDestination auf, um einen Wert zu erhalten, der den Trafficfluss zum nächsten Ziel angibt. Dieser Parameter gibt GMSNavigationDelayCategory zurück. Das folgende Beispiel zeigt, wie das Ergebnis ausgewertet und eine Verkehrsmeldung protokolliert wird:

Swift

if let navigator = mapView.navigator {
  // insert sample for evaluating traffic value
  let delay = navigator.delayCategoryToNextDestination
  let traffic = "unavailable"
  switch delay {
    case .noData:
      traffic = "unavailable"
    case .heavy:
      traffic = "heavy"
    case .medium:
      traffic = "moderate"
    case .light:
      traffic = "light"
    default:
      traffic = "unavailable"
  }
  print("Traffic is \(traffic).")
}

Objective-C

GMSNavigationDelayCategory delay = mapView.navigator.delayCategoryToNextDestination;
NSString *traffic = @"";

switch (delayCategory) {
    case GMSNavigationDelayCategoryNoData:
      traffic = @"No Data";
      break;
    case GMSNavigationDelayCategoryHeavy:
      traffic = @"Heavy";
      break;
    case GMSNavigationDelayCategoryMedium:
      traffic = @"Medium";
      break;
    case GMSNavigationDelayCategoryLight:
      traffic = @"Light";
      break;
    default:
      NSLog(@"Invalid delay category: %zd", delayCategory);
 }

NSLog(@"%@", [NSString stringWithFormat:@"Traffic is %@.", traffic]);

Informationen zum aktuellen Streckenabschnitt abrufen

Rufen Sie currentRouteLeg auf, um Informationen zum aktuellen Streckenabschnitt zu erhalten. Dadurch wird eine GMSRouteLeg-Instanz zurückgegeben, mit der Sie Folgendes abrufen können:

  • Das Ziel für den Streckenabschnitt.
  • Die endgültige Koordinate im Streckenabschnitt.
  • Pfad mit den Koordinaten des Streckenabschnitts.

Im folgenden Beispiel werden Titel sowie Breiten- und Längengrade für den nächsten Streckenabschnitt protokolliert:

Swift

if let navigator = mapView.navigator {
  let currentLeg = navigator.currentRouteLeg
  let nextDestination = currentLeg?.destinationWaypoint?.title
  let lat = currentLeg?.destinationCoordinate.latitude.description
  let lng = currentLeg?.destinationCoordinate.longitude.description
  NSLog(nextDestination! + ", " + lat! + "/" + lng!)
}

Objective-C

GMSRouteLeg *currentSegment = _mapView.navigator.currentRouteLeg;
NSString *nextDestination = currentSegment.destinationWaypoint.title;
CLLocationDegrees lat = currentSegment.destinationCoordinate.latitude;
CLLocationDegrees lng = currentSegment.destinationCoordinate.longitude;
NSLog(@"%@", [NSString stringWithFormat:@"%@, %f/%f", nextDestination, lat, lng]);

Zuletzt zurückgelegten Weg abrufen

Wenn Sie den zuletzt zurückgelegten Weg abrufen möchten, rufen Sie traveledPath auf. Dadurch wird eine GMSPath-Instanz zurückgegeben, die vereinfacht wurde, um redundante Punkte zu entfernen (z. B. Umwandlung aufeinanderfolgender kolinearer Punkte in ein einzelnes Liniensegment). Dieser Pfad ist leer, bis die Anleitung gestartet wird. Das folgende Beispiel zeigt, wie Sie den zuletzt zurückgelegten Pfad abrufen:

Swift

if let navigator = mapView.navigator {
  let latestPath = navigator.traveledPath
  if latestPath.count() > 0 {
    let begin: CLLocationCoordinate2D = latestPath.coordinate(at: 0)
    let current: CLLocationCoordinate2D = latestPath.coordinate(at: latestPath.count() - 1)
    print("Path from (\(begin.latitude),\(begin.longitude)) to (\(current.latitude),\(current.longitude))")
  }
}

Objective-C

GMSPath *latestPath = mapView.navigator.traveledPath;
if (latestPath.count > 0) {
  CLLocationCoordinate2D begin = [latestPath coordinateAtIndex:0];
  CLLocationCoordinate2D current = [latestPath coordinateAtIndex:latestPath.count - 1];
  NSLog(@"Path from %f/%f to %f/%f",
        begin.latitude,
        begin.longitude,
        current.latitude,
        current.longitude);
}