Regola le preferenze di routing

I calcoli del percorso (incluso il ricalcolo) restituiscono il percorso che richiede il minor tempo di navigazione come miglior percorso predefinito. Tuttavia, puoi modificare la strategia di routing in modo che venga restituito l'itinerario più breve tra le alternative.

Il termine più breve indica l'itinerario più breve tra quelli ottimali in base al nostro modello di costo predefinito. Il percorso più breve potrebbe non essere il percorso più breve assoluto, poiché questa opzione potrebbe essere una scarsa alternativa. Ad esempio, se il percorso più breve in assoluto è di 10 km e richiede 50 minuti per essere percorso e un altro percorso è di 15 km, ma richiede solo 20 minuti, la seconda scelta è ottimale, perché impiegare 30 minuti per ridurre di 5 km non è un buon compromesso.

Una volta impostata la strategia di routing per un viaggio, questa non cambierà fino al completamento del viaggio. Per modificare la strategia di routing per un viaggio esistente, devi cancellare le destinazioni e reimpostarle con la nuova strategia di routing.

Recupero dei dettagli della route

Per determinare quale strategia di percorso è la scelta ottimale per un determinato waypoint, chiama getRouteInfoForDestination() per ottenere i dettagli del percorso sia per il percorso migliore predefinito sia per il percorso più breve assoluto. I dettagli includono la durata e la distanza da un waypoint di destinazione.

Questi dettagli provengono da GMSNavigationRouteInfo nel callback.

Esempio

Il seguente esempio di codice mostra come ottenere i dettagli del percorso per ciascuna delle due strategie di routing.

Swift

let routingOptions = GMSNavigationRoutingOptions()
navigator?.getRouteInfoForDestination(destination,
                                      routingOptions: routingOptions) { routeInfo in
  ...
}

Objective-C

GMSNavigationRoutingOptions *routingOptions =
    [[GMSNavigationRoutingOptions alloc] init];
[navigator getRouteInfoForDestination:destination
                   withRoutingOptions:routingOptions
                             callback:^(GMSNavigationRouteInfo *routeInfo){...}];

Impostazione della strategia di routing

Puoi configurare la strategia di routing utilizzando GMSNavigationRoutingOptions e impostando routingStrategy quando chiami setDestinations().

routingStrategy accetta uno dei seguenti valori di enumerazione:

Valore di enumerazioneDescrizione
GMSNavigationRoutingStrategyDefaultBest Classifica i percorsi in base al modello di costo predefinito dell'SDK Navigation. Questa è la strategia di routing predefinita.
GMSNavigationRoutingStrategyShorter Ordina i percorsi in base alla distanza. Il percorso con il ranking più alto è il più breve tra quelli restituiti.

Esempio

Il seguente esempio di codice mostra come impostare la strategia di routing dell'itinerario più breve.

Swift

let routingOptions = GMSNavigationRoutingOptions(routingStrategy: .shorter)
navigator?.setDestinations(destinations,
                           routingOptions: routingOptions) { routeStatus in
  ...
}

Objective-C

GMSNavigationRoutingOptions *routingOptions = [[GMSNavigationRoutingOptions alloc] initWithRoutingStrategy:GMSNavigationRoutingStrategyShorter];
[navigator setDestinations:destinations
            routingOptions:routingOptions
                  callback:^(GMSRouteStatus routeStatus){...}];

Percorsi che includono traghetti

Per impostazione predefinita, l'SDK Navigation per iOS esclude i percorsi che includono traghetti. Se preferisci includere le opzioni di traghetto nei tuoi percorsi, puoi modificare questa preferenza di routing per mostrare il viaggio ai segmenti di traghetto impostando avoidsFerries su false.

Esempio

Swift

self.mapView.navigator?.avoidsFerries = false

Objective-C

self.mapView.navigator.avoidsFerries = NO

Formato del callout dell'itinerario

Nella strategia di routing del percorso più breve, i callout lungo il percorso mostrano i dettagli della distanza. ma puoi utilizzare i callout con l'ETA.

Configurazione del formato del callout dell'itinerario

Puoi modificare il formato del callout dell'itinerario impostando routeCalloutFormat in GMSMapView. routeCalloutFormat accetta uno dei seguenti valori di enumerazione:

Valore di enumerazioneDescrizione
GMSNavigationRouteCalloutFormatDefault Mostra il tempo rimanente quando utilizzi la strategia di routing del percorso migliore predefinita. Mostra la distanza rimanente quando si utilizza la strategia di routing dell'itinerario più breve
GMSNavigationRouteCalloutFormatTime Visualizza il tempo rimanente.
GMSNavigationRouteCalloutFormatDistance DVisualizza la distanza rimanente.

Esempio

Il seguente esempio di codice mostra come configurare il formato del callout dell'itinerario.

Swift

self.mapView.routeCalloutFormat = .time

Objective-C

_mapView.routeCalloutFormat = GMSNavigationRouteCalloutFormatTime;