Uzyskiwanie informacji o trasie

Wykonaj czynności opisane w tym przewodniku, aby skonfigurować aplikację do pobierania czasów, odległości i odcinków trasy dla bieżącej trasy.

Przegląd

Aby uzyskać informacje o bieżącej trasie, pobierz odpowiednią właściwość z instancji navigator:

Wyświetlanie kodu

Uzyskiwanie czasu dotarcia do następnego miejsca docelowego

Aby uzyskać czas dotarcia do następnego miejsca docelowego, wywołaj funkcję timeToNextDestination(). Zwraca ona wartość NSTimeInterval. Poniższy przykład pokazuje rejestrowanie czasu dotarcia do następnego miejsca docelowego:

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

Uzyskiwanie odległości do następnego miejsca docelowego

Aby uzyskać odległość do następnego miejsca docelowego, wywołaj funkcję distanceToNextDestination(). Zwraca ona wartość CLLocationDistance. Jednostki są podawane w metrach.

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

Uzyskiwanie informacji o warunkach na drodze do następnego miejsca docelowego

Aby uzyskać wartość wskazującą natężenie ruchu do następnego miejsca docelowego, wywołaj funkcję delayCategoryToNextDestination. Ten parametr zwraca wartość GMSNavigationDelayCategory. Poniższy przykład pokazuje, jak ocenić wynik i zarejestrować komunikat o natężeniu ruchu:

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

Uzyskiwanie informacji o bieżącym odcinku

Aby uzyskać informacje o bieżącym odcinku trasy, wywołaj funkcję currentRouteLeg. Zwraca ona instancję GMSRouteLeg, z której możesz uzyskać:

  • miejsce docelowe odcinka;
  • współrzędne końcowe odcinka;
  • ścieżkę zawierającą współrzędne, które tworzą odcinek trasy.

Poniższy przykład pokazuje rejestrowanie tytułu i współrzędnych geograficznych następnego odcinka trasy:

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

Uzyskiwanie ostatnio przebytej trasy

Aby uzyskać ostatnio przebytą trasę, wywołaj funkcję traveledPath. Zwraca ona instancję GMSPath , która została uproszczona przez usunięcie zbędnych punktów (np. przez przekształcenie kolejnych współliniowych punktów w jeden odcinek). Ta ścieżka jest pusta, dopóki nie rozpocznie się nawigacja. Poniższy przykład pokazuje, jak uzyskać ostatnio przebytą trasę:

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