Ricevi informazioni sul percorso

Segui questa guida per configurare l'app in modo da recuperare tempi, distanze e tratti per il percorso corrente.

Panoramica

Per ottenere informazioni sulla route corrente, recupera la proprietà appropriata dall'istanza navigator:

Visualizza il codice

Tempo per raggiungere la prossima destinazione

Per ottenere il tempo per la destinazione successiva, chiama il numero timeToNextDestination(). Viene restituito un valore NSTimeInterval. L'esempio seguente mostra il logging dell'ora nella destinazione successiva:

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

Raggiungere la prossima destinazione

Per conoscere la distanza per la destinazione successiva, chiama il numero distanceToNextDestination(). Viene restituito un valore CLLocationDistance. Le unità sono specificate in metri.

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

Recupero delle condizioni del traffico per la destinazione successiva

Per ottenere un valore che indica il flusso di traffico verso la destinazione successiva, chiama delayCategoryToNextDestination. Questo parametro restituisce GMSNavigationDelayCategory. Nell'esempio seguente viene mostrata la valutazione del risultato e il logging di un messaggio sul traffico:

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

Recupero di informazioni sulla tratta attuale

Per ricevere informazioni sulla tratta attuale del percorso, chiama il numero currentRouteLeg. La richiesta restituisce un'istanza GMSRouteLeg, da cui puoi recuperare:

  • La destinazione per la gamba.
  • La coordinata finale nella gamba.
  • Il percorso contenente le coordinate che compongono il tratto del percorso.

L'esempio seguente mostra il logging delle coordinate di titolo e latitudine/longitudine per il tratto successivo del percorso:

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

Recupero del percorso più recente

Per ottenere il percorso più recente, chiama traveledPath. Viene restituita un'istanza GMSPath che è stata semplificata per rimuovere i punti ridondanti (ad esempio trasformando punti colineari consecutivi in un unico segmento di linea). Questo percorso è vuoto fino all'avvio delle indicazioni. L'esempio seguente mostra il percorso più seguito:

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