Dati un insieme di tappe terminali e intermedi e un obiettivo del percorso, calcola il percorso migliore per l'obiettivo del percorso. Restituisce anche il percorso più veloce e il percorso più breve come percorsi di riferimento.
NOTA:questo metodo richiede la specifica di una maschera del campo di risposta nell'input. Puoi fornire la maschera del campo di risposta utilizzando il parametro URL $fields
o fields
oppure l'intestazione HTTP/gRPC X-Goog-FieldMask
(consulta le intestazioni e i parametri URL disponibili. Il valore è un elenco separato da virgole di percorsi di campi. Consulta questa documentazione dettagliata sulla creazione dei percorsi dei campi.
Ad esempio, in questo metodo:
- Maschera di tutti i campi disponibili (per l'ispezione manuale):
X-Goog-FieldMask: *
- Maschera di campo con le distanze, le durate e le informazioni relative al token e ai pedaggi:
X-Goog-FieldMask: routes.route.distanceMeters,routes.route.duration,routes.token,routes.route.travelAdvisory.tollInfo
Google sconsiglia di utilizzare la maschera del campo di risposta con caratteri jolly (*
) o di specificare la maschera del campo al livello superiore (routes
), perché:
- La selezione dei soli campi di cui hai bisogno consente al nostro server di salvare i cicli di calcolo, consentendoci di restituirti il risultato con una latenza inferiore.
- La selezione dei soli campi necessari nel job di produzione garantisce prestazioni di latenza stabili. In futuro potremmo aggiungere altri campi di risposta e questi nuovi campi potrebbero richiedere tempi di calcolo aggiuntivi. Se selezioni tutti i campi o tutti i campi al livello superiore, si potrebbe verificare un peggioramento delle prestazioni, poiché ogni nuovo campo che aggiungiamo verrà incluso automaticamente nella risposta.
- Se selezioni solo i campi necessari, la risposta avrà una dimensione inferiore e quindi una velocità effettiva di rete più elevata.
Richiesta HTTP
POST https://routespreferred.googleapis.com/v1:computeCustomRoutes
L'URL utilizza la sintassi di transcodifica gRPC.
Corpo della richiesta
Il corpo della richiesta contiene dati con la seguente struttura:
Rappresentazione JSON |
---|
{ "origin": { object ( |
Campi | |
---|---|
origin |
Obbligatorio. Tappa di partenza. |
destination |
Obbligatorio. Tappa di destinazione. |
intermediates[] |
(Facoltativo) Una serie di tappe lungo il percorso (esclusi i punti di arrivo), dove fermarti o passare. Sono supportate fino a 25 tappe intermedie. |
travelMode |
(Facoltativo) Specifica la modalità di trasporto. Al momento è supportato solo Drive. |
routingPreference |
(Facoltativo) Specifica come calcolare la route. Il server tenta di utilizzare la preferenza di routing selezionata per calcolare il percorso. Se la preferenza di routing genera un errore o una latenza molto lunga, viene restituito un errore. In futuro, potremmo implementare un meccanismo di riserva per utilizzare un'opzione diversa quando l'opzione preferita non fornisce un risultato valido. Puoi specificare questa opzione solo quando |
polylineQuality |
(Facoltativo) Specifica la tua preferenza per la qualità della polilinea. |
polylineEncoding |
(Facoltativo) Specifica la codifica preferita per la polilinea. |
departureTime |
(Facoltativo) L'orario di partenza. Se non imposti questo valore, verrà usato per impostazione predefinita l'ora in cui hai effettuato la richiesta. Se imposti questo valore su un'ora già avvenuta, la richiesta non va a buon fine. Un timestamp nel formato RFC3339 UTC "Zulu" con risoluzione in nanosecondi e fino a nove cifre frazionarie. Esempi: |
routeModifiers |
(Facoltativo) Un insieme di condizioni da soddisfare che influiscono sulla modalità di calcolo delle route. |
routeObjective |
Obbligatorio. Un obiettivo del percorso per cui eseguire l'ottimizzazione. |
languageCode |
(Facoltativo) Il codice lingua BCP-47, ad esempio "en-US" o "sr-Latn". Per ulteriori informazioni, consulta http://www.unicode.org/reports/tr35/#Unicode_locale_identifier. Per l'elenco delle lingue supportate, consulta la sezione Supporto delle lingue. Se non fornisci questo valore, la lingua di visualizzazione viene dedotta dalla posizione della richiesta di percorso. |
units |
(Facoltativo) Specifica le unità di misura per i campi di visualizzazione. È incluso il campo |
Corpo della risposta
In caso di esito positivo, il corpo della risposta contiene un'istanza di ComputeCustomRoutesResponse
.
Ambiti di autorizzazione
Richiede il seguente ambito OAuth:
https://www.googleapis.com/auth/maps-platform.routespreferred
Per ulteriori informazioni, consulta la panoramica di OAuth 2.0.