Uzyskiwanie informacji o trasie

Aby skonfigurować aplikację tak, aby pobierała czasy, odległości i odcinki trasy dla bieżącej trasy, postępuj zgodnie z tym przewodnikiem.

Omówienie

Aby uzyskać informacje o bieżącej trasie, pobierz odpowiednią usługę z instancji navigator:

Wyświetlanie kodu

Czas dojazdu do następnego miejsca docelowego

Aby uzyskać czas do następnego miejsca docelowego, zadzwoń pod numer timeToNextDestination(). Zwraca wartość NSTimeInterval. Ten przykład pokazuje rejestrowanie czasu 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]);

Odległość do następnego miejsca docelowego

Aby uzyskać odległość do następnego miejsca docelowego, wybierz distanceToNextDestination(). Zwraca 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]);

Informacje o warunkach na drodze do następnego miejsca docelowego

Aby uzyskać wartość wskazującą na przepływ ruchu do następnego miejsca docelowego, wywołaj funkcję delayCategoryToNextDestination. Ten parametr zwraca GMSNavigationDelayCategory. Poniższy przykład pokazuje sprawdzanie wyniku i rejestrowanie komunikatu o 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, zadzwoń pod numer currentRouteLeg. Zwraca to instancję GMSRouteLeg, z której możesz uzyskać:

  • Miejsce docelowe odcinka.
  • Ostatnia współrzędna na odcinku.
  • Ścieżka zawierająca współrzędne, z których składa się odległość.

Ten przykład pokazuje rejestrowanie tytułu i współrzędnych lat/lng dla 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]);

Pobieranie ostatnio przebytej ścieżki

Aby uzyskać ostatnio przebytą trasę, zadzwoń pod numer traveledPath. Zwraca to instancję GMSPath, która została uproszczona w celu usunięcia nadmiarowych punktów (np. przez przekształcenie kolejnych współliniowych punktów w pojedynczy segment linii). Ta ścieżka jest pusta, dopóki nie rozpocznie się nawigacja. W tym przykładzie pokazano uzyskanie ścieżki ostatnio przebytej przez użytkownika:

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