Ricevi informazioni sul percorso

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

Panoramica

Per ottenere informazioni sul percorso corrente, ottieni la proprietà appropriata da l'istanza navigator:

Visualizza il codice

Tempo per la prossima destinazione in corso...

Per informazioni sul tempo necessario per la prossima destinazione, chiama timeToNextDestination(). Viene restituito un valore NSTimeInterval. L'esempio seguente mostra registrando il tempo per la 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]);

Calcolo della distanza per raggiungere la destinazione successiva

Per ottenere la distanza dalla destinazione successiva, chiama 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 indichi il flusso di traffico verso la destinazione successiva, richiama delayCategoryToNextDestination Questo parametro restituisce GMSNavigationDelayCategory. Le seguenti l'esempio mostra la valutazione dei risultati e la registrazione 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 delle informazioni sulla tratta attuale in corso...

Per ricevere informazioni sulla tratta del percorso corrente, chiama currentRouteLeg. Questo restituisce un'istanza GMSRouteLeg, da cui puoi ottenere:

  • Il punto di riferimento per la tappa.
  • La coordinata finale della gamba.
  • Il percorso contenente le coordinate che compongono la tratta del percorso.

L'esempio seguente mostra il logging del titolo e delle coordinate di latitudine/longitudine per la tappa del percorso successiva:

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

Calcolo del percorso seguito più di recente

Per visualizzare il percorso seguito più di recente, chiama traveledPath. Viene restituito un GMSPath un'istanza, che è stata semplificata per rimuovere i punti ridondanti (ad esempio la trasformazione di punti colineari consecutivi in un unico segmento di linea). Questo percorso è vuoto fino all'avvio della guida. L'esempio seguente mostra come ottenere il massimo percorso percorso di recente:

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