Panoramica
Puoi calcolare le indicazioni stradali (utilizzando una serie di metodi di trasporto) utilizzando l'oggetto DirectionsService. Questo oggetto comunica con il servizio Directions API di Google Maps, che riceve le richieste di indicazioni e restituisce un percorso efficiente.
Il tempo di percorrenza è il fattore principale che viene ottimizzato, ma possono essere presi in considerazione anche altri fattori
come distanza, numero di svolte e molti altri.
Puoi gestire personalmente i risultati delle indicazioni stradali o utilizzare l'oggetto
DirectionsRenderer per visualizzarli.
Quando specifichi l'origine o la destinazione in una richiesta di indicazioni stradali,
puoi specificare una stringa di query (ad esempio "Chicago, IL" o
"Darwin, NSW, Australia"), un valore LatLng o un
oggetto Luogo.
Il servizio Directions può restituire indicazioni stradali in più parti utilizzando una serie
di waypoint. Le indicazioni stradali vengono visualizzate come un disegno polilineare
del percorso su una mappa oppure, in alternativa, come una serie di descrizioni
testuali all'interno di un elemento <div> (ad esempio,
"Svolta a destra sulla rampa del Williamsburg Bridge").
Per iniziare
Prima di utilizzare il servizio Directions nell'API Maps JavaScript, assicurati che l'API Directions (legacy) sia abilitata nella console Google Cloud, nello stesso progetto configurato per l'API Maps JavaScript.
Per visualizzare l'elenco delle API abilitate:
- Vai alla console Google Cloud.
- Fai clic sul pulsante Seleziona un progetto, poi seleziona lo stesso progetto che hai configurato per l'API Maps JavaScript e fai clic su Apri.
- Nell'elenco delle API nella dashboard, cerca API Directions (legacy).
- Se vedi l'API nell'elenco, non devi fare altro. Se l'API non è elencata, abilitala all'indirizzo https://console.cloud.google.com/apis/library/directions-backend.googleapis.com
Prezzi e norme
Prezzi
Per informazioni sui prezzi e sulle norme di utilizzo del servizio Directions JavaScript, consulta la sezione Utilizzo e fatturazione per l'API Directions (legacy).
Norme
L'utilizzo del servizio Directions deve essere conforme alle norme descritte per l'API Directions (legacy).
Richieste di indicazioni stradali
L'accesso al servizio Directions è asincrono, poiché
l'API Google Maps deve effettuare una chiamata a un server esterno. Per questo motivo, devi passare un metodo callback
da eseguire al completamento della richiesta. Questo
metodo di callback deve elaborare i risultati. Tieni presente che il
servizio Indicazioni stradali potrebbe restituire più di un itinerario possibile
come array di routes[] separati.
Per utilizzare le indicazioni nell'API Maps JavaScript, crea un oggetto di tipo DirectionsService e chiama DirectionsService.route() per avviare una richiesta al servizio Directions, passando un letterale oggetto DirectionsRequest contenente i termini di input e un metodo di callback da eseguire al ricevimento della risposta.
Il valore letterale dell'oggetto DirectionsRequest contiene i seguenti campi:
{ origin: LatLng | String | google.maps.Place, destination: LatLng | String | google.maps.Place, travelMode: TravelMode, transitOptions: TransitOptions, drivingOptions: DrivingOptions, unitSystem: UnitSystem, waypoints[]: DirectionsWaypoint, optimizeWaypoints: Boolean, provideRouteAlternatives: Boolean, avoidFerries: Boolean, avoidHighways: Boolean, avoidTolls: Boolean, region: String }
Questi campi sono spiegati di seguito:
origin(obbligatorio) specifica la posizione di partenza da cui calcolare le indicazioni. Questo valore può essere specificato comeString(ad esempio "Chicago, IL"), come valoreLatLngo come oggetto Place. Se utilizzi un oggetto Place, puoi specificare un ID luogo, una stringa di query o unaLatLngposizione. Puoi recuperare gli ID luogo dai servizi Geocoding, Place Search e Place Autocomplete nell'API Maps JavaScript. Per un esempio che utilizza gli ID luogo di Place Autocomplete, vedi Place Autocomplete e indicazioni stradali.destination(obbligatorio) specifica la posizione finale per cui calcolare le indicazioni stradali. Le opzioni sono le stesse del campoorigindescritto sopra.travelMode(obbligatorio) specifica la modalità di trasporto da utilizzare per calcolare le indicazioni. I valori validi sono specificati nella sezione Modalità di trasporto di seguito.transitOptions(facoltativo) specifica i valori che si applicano solo alle richieste in cuitravelModeèTRANSIT. I valori validi sono descritti nella sezione Opzioni di transito di seguito.drivingOptions(facoltativo) specifica i valori che si applicano solo alle richieste in cuitravelModeèDRIVING. I valori validi sono descritti nella sezione Opzioni di guida di seguito.unitSystem(facoltativo) specifica quale sistema di unità utilizzare per visualizzare i risultati. I valori validi sono specificati in Sistemi di unità di misura di seguito.waypoints[](facoltativo) specifica un array diDirectionsWaypoint. I waypoint modificano un percorso indirizzandolo attraverso le posizioni specificate. Un waypoint viene specificato come un oggetto letterale con i campi mostrati di seguito:locationspecifica la posizione della tappa, comeLatLng, come oggetto Place o comeStringche verrà geocodificato.stopoverè un valore booleano che indica che il waypoint è una fermata sul percorso, il che comporta la suddivisione del percorso in due percorsi.
Per ulteriori informazioni sui waypoint, vedi Utilizzo dei waypoint nelle route di seguito.
optimizeWaypoints(facoltativo) specifica che il percorso che utilizzawaypointsfornito può essere ottimizzato riorganizzando i waypoint in un ordine più efficiente. Setrue, il servizio Directions restituiràwaypointsriordinati in un campowaypoint_order. Per ulteriori informazioni, vedi Utilizzo delle tappe nelle route di seguito.provideRouteAlternatives(facoltativo) quando è impostato sutruespecifica che il servizio Directions può fornire più di un'alternativa di percorso nella risposta. Tieni presente che fornire alternative di percorso può aumentare il tempo di risposta del server. Questa opzione è disponibile solo per le richieste senza tappe intermedie.avoidFerries(facoltativo) quando è impostato sutrueindica che le tratte calcolate devono evitare i traghetti, se possibile.avoidHighways(facoltativo) se impostato sutrueindica che i percorsi calcolati devono evitare le autostrade principali, se possibile.avoidTolls(facoltativo) se impostato sutrueindica che i percorsi calcolati devono evitare le strade a pedaggio, se possibile.region(facoltativo) specifica il codice regione, specificato come valore ccTLD ("dominio di primo livello") di due caratteri. Per saperne di più, vedi Bias della regione di seguito.
Di seguito è riportato un esempio di DirectionsRequest:
{ origin: 'Chicago, IL', destination: 'Los Angeles, CA', waypoints: [ { location: 'Joplin, MO', stopover: false },{ location: 'Oklahoma City, OK', stopover: true }], provideRouteAlternatives: false, travelMode: 'DRIVING', drivingOptions: { departureTime: new Date(/* now, or future date */), trafficModel: 'pessimistic' }, unitSystem: google.maps.UnitSystem.IMPERIAL }
Modalità di viaggio
Quando calcoli le indicazioni stradali, devi specificare la modalità di trasporto da utilizzare. Attualmente sono supportate le seguenti modalità di viaggio:
DRIVING(predefinito) indica le indicazioni stradali standard che utilizzano la rete stradale.BICYCLINGrichiede indicazioni stradali in bicicletta tramite piste ciclabili e strade preferite.TRANSITrichiede indicazioni tramite percorsi di trasporto pubblico.WALKINGrichiede indicazioni stradali a piedi tramite sentieri pedonali e marciapiedi.
Consulta i Dettagli della copertura di Google Maps Platform
per determinare in che misura un paese supporta le indicazioni stradali. Se richiedi
indicazioni stradali per una regione in cui questo tipo di indicazioni non è disponibile,
la risposta restituirà
DirectionsStatus="ZERO_RESULTS".
Nota: le indicazioni a piedi potrebbero non includere percorsi pedonali
chiari, pertanto le indicazioni a piedi restituiranno avvisi in
DirectionsResult. Questi avvisi devono essere sempre mostrati all'utente. Se non utilizzi DirectionsRenderer predefinito, è tua
responsabilità assicurarti che gli avvisi vengano visualizzati.
Opzioni di trasporto pubblico
Le opzioni disponibili per una richiesta di indicazioni stradali variano in base alla modalità di viaggio.
Quando richiedi indicazioni stradali per il trasporto pubblico, le opzioni avoidHighways,
avoidTolls, waypoints[] e
optimizeWaypoints verranno ignorate. Puoi specificare
opzioni di routing specifiche per il trasporto pubblico tramite
il letterale oggetto
TransitOptions.
Le indicazioni stradali con mezzi pubblici sono sensibili al tempo. Le indicazioni stradali verranno restituite solo per orari futuri.
Il valore letterale dell'oggetto TransitOptions contiene i seguenti campi:
{ arrivalTime: Date, departureTime: Date, modes[]: TransitMode, routingPreference: TransitRoutePreference }
Questi campi sono spiegati di seguito:
arrivalTime(facoltativo) specifica l'ora di arrivo desiderata come oggettoDate. Se viene specificato l'orario di arrivo, l'orario di partenza viene ignorato.departureTime(facoltativo) specifica l'ora di partenza desiderata come oggettoDate. Il valoredepartureTimeverrà ignorato se viene specificatoarrivalTime. Se non viene specificato alcun valore perdepartureTimeoarrivalTime, il valore predefinito è ora (ovvero l'ora corrente).modes[](facoltativo) è un array contenente uno o più valori letterali dell'oggettoTransitMode. Questo campo può essere incluso solo se la richiesta include una chiave API. OgniTransitModespecifica una modalità di trasporto pubblico preferita. Sono consentiti i seguenti valori:BUSindica che l'itinerario calcolato deve preferire gli spostamenti in autobus.RAILindica che l'itinerario calcolato deve privilegiare gli spostamenti in treno, tram, metropolitana leggera e metropolitana.SUBWAYindica che l'itinerario calcolato deve preferire gli spostamenti in metropolitana.TRAINindica che l'itinerario calcolato deve dare la precedenza al viaggio in treno.TRAMindica che il percorso calcolato deve dare la precedenza agli spostamenti in tram e metropolitana leggera.
routingPreference(facoltativo) specifica le preferenze per i percorsi con il trasporto pubblico. Utilizzando questa opzione, puoi dare la priorità alle opzioni restituite, anziché accettare il percorso migliore predefinito scelto dall'API. Questo campo può essere specificato solo se la richiesta include una chiave API. Sono consentiti i seguenti valori:FEWER_TRANSFERSindica che l'itinerario calcolato deve preferire un numero limitato di trasferimenti.LESS_WALKINGindica che il percorso calcolato deve preferire quantità limitate di camminata.
Di seguito è riportato un esempio di DirectionsRequest per transito:
{ origin: 'Hoboken NJ', destination: 'Carroll Gardens, Brooklyn', travelMode: 'TRANSIT', transitOptions: { departureTime: new Date(1337675679473), modes: ['BUS'], routingPreference: 'FEWER_TRANSFERS' }, unitSystem: google.maps.UnitSystem.IMPERIAL }
Opzioni di guida
Puoi specificare le opzioni di routing per le indicazioni stradali tramite l'oggetto
DrivingOptions.
L'oggetto DrivingOptions contiene i seguenti campi:
{ departureTime: Date, trafficModel: TrafficModel }
Questi campi sono spiegati di seguito:
departureTime(obbligatorio per la validità del letterale oggettodrivingOptions) specifica l'ora di partenza desiderata come oggettoDate. Il valore deve essere impostato sull'ora corrente o su un'ora futura. Non può essere nel passato. L'API converte tutte le date in UTC per garantire una gestione coerente nei vari fusi orari. Per i clienti del piano Premium di Google Maps Platform, se includidepartureTimenella richiesta, l'API restituisce il percorso migliore in base alle condizioni di traffico previste al momento e include il tempo previsto nel traffico (duration_in_traffic) nella risposta. Se non specifichi un orario di partenza (ovvero se la richiesta non includedrivingOptions), l'itinerario restituito è un itinerario generalmente buono che non tiene conto delle condizioni del traffico.trafficModel(facoltativo) specifica i presupposti da utilizzare per calcolare il tempo nel traffico. Questa impostazione influisce sul valore restituito nel campoduration_in_trafficdella risposta, che contiene il tempo previsto nel traffico in base alle medie storiche. Il valore predefinito èbestguess. Sono consentiti i seguenti valori:bestguess(impostazione predefinita) indica che il valore restituitoduration_in_trafficdeve essere la migliore stima del tempo di percorrenza in base a ciò che è noto sulle condizioni del traffico storico e sul traffico in tempo reale. Il traffico in tempo reale diventa più importante quanto più vicino è ildepartureTimeal momento attuale.pessimisticindica che il valore restituitoduration_in_trafficdovrebbe essere superiore al tempo di percorrenza effettivo nella maggior parte dei giorni, anche se in alcuni giorni con condizioni di traffico particolarmente difficili potrebbe superare questo valore.optimisticindica che il valoreduration_in_trafficrestituito dovrebbe essere inferiore al tempo di percorrenza effettivo nella maggior parte dei giorni, anche se in alcuni giorni con condizioni di traffico particolarmente buone il tempo di percorrenza potrebbe essere inferiore a questo valore.
Di seguito è riportato un esempio di DirectionsRequest per le indicazioni stradali:
{ origin: 'Chicago, IL', destination: 'Los Angeles, CA', travelMode: 'DRIVING', drivingOptions: { departureTime: new Date(Date.now() + N), // for the time N milliseconds from now. trafficModel: 'optimistic' } }
Sistemi di unità di misura
Per impostazione predefinita, le indicazioni stradali vengono calcolate e visualizzate utilizzando
il sistema di unità di misura del paese o della regione di origine.
(Nota: le origini espresse utilizzando
coordinate di latitudine/longitudine anziché indirizzi vengono sempre impostate
sulle unità metriche.) Ad esempio, un percorso da
"Chicago, IL" a "Toronto, ONT" mostrerà i risultati in miglia, mentre
il percorso inverso mostrerà i risultati in chilometri. Puoi
ignorare questo sistema di unità impostandone uno esplicitamente all'interno della
richiesta utilizzando uno dei seguenti valori UnitSystem:
UnitSystem.METRICspecifica l'utilizzo del sistema metrico decimale. Le distanze vengono visualizzate in chilometri.UnitSystem.IMPERIALspecifica l'utilizzo del sistema imperiale (inglese). Le distanze vengono visualizzate in miglia.
Nota:questa impostazione del sistema di unità influisce solo sul testo visualizzato dall'utente. Il risultato delle indicazioni stradali contiene anche valori di distanza, non mostrati all'utente, che sono sempre espressi in metri.
Bias regionale per le indicazioni stradali
Il servizio Directions dell'API Google Maps restituisce risultati di indirizzi influenzati
dal dominio (regione o paese) da cui hai caricato il bootstrap
JavaScript. (Poiché la maggior parte degli utenti carica https://maps.googleapis.com/,
questo imposta un dominio implicito negli Stati Uniti.) Se carichi il
bootstrap da un altro dominio supportato, i risultati
saranno influenzati da quel dominio. Ad esempio, le ricerche di "San Francisco" potrebbero
restituire risultati diversi dalle applicazioni che caricano
https://maps.googleapis.com/ (Stati Uniti) rispetto a quelle che caricano
http://maps.google.es/ (Spagna).
Puoi anche impostare il servizio Directions in modo che restituisca risultati orientati a una
determinata regione utilizzando il parametro region. Questo parametro
accetta un codice regione specificato come tag secondario della regione Unicode di due caratteri (non numerici). Nella maggior parte dei casi, questi tag vengono mappati direttamente ai valori di due caratteri del ccTLD ("dominio di primo livello"), ad esempio "uk" in "co.uk". In alcuni
casi, il tag region supporta anche i codici ISO-3166-1, che
a volte differiscono dai valori dei TLD con codice paese ("GB" per "Gran Bretagna", ad esempio).
Quando utilizzi il parametro region:
- Specifica un solo paese o una sola regione. Più valori vengono ignorati e potrebbero comportare una richiesta non riuscita.
- Utilizza solo sottotag di regione di due caratteri (formato Unicode CLDR). Tutti gli altri input genereranno errori.
La distorsione regionale è supportata solo per i paesi e le regioni che supportano le indicazioni stradali. Consulta i Dettagli sulla copertura di Google Maps Platform per visualizzare la copertura internazionale dell'API Directions (legacy).
Indicazioni per il rendering
L'avvio di una richiesta di indicazioni per
DirectionsService con il metodo route()
richiede il passaggio di un callback che viene eseguito al termine della
richiesta di servizio. Questo callback restituirà un
DirectionsResult e un codice DirectionsStatus
nella risposta.
Stato della query di indicazioni stradali
DirectionsStatus può restituire i seguenti valori:
OKindica che la risposta contiene unDirectionsResultvalido.NOT_FOUNDindica che non è stato possibile geocodificare almeno una delle località specificate nell'origine, nella destinazione o nei waypoint della richiesta.ZERO_RESULTSindica che non è stato possibile trovare un percorso tra l'origine e la destinazione.MAX_WAYPOINTS_EXCEEDEDindica che sono stati forniti troppi campiDirectionsWaypointinDirectionsRequest. Consulta la sezione di seguito sui limiti per i punti di passaggio.MAX_ROUTE_LENGTH_EXCEEDEDindica che l'itinerario richiesto è troppo lungo e non può essere elaborato. Questo errore si verifica quando vengono restituite indicazioni più complesse. Prova a ridurre il numero di waypoint, svolte o istruzioni.INVALID_REQUESTindica che ilDirectionsRequestfornito non era valido. Le cause più comuni di questo codice di errore sono le richieste a cui manca un'origine o una destinazione oppure una richiesta di transito che include waypoint.OVER_QUERY_LIMITindica che la pagina web ha inviato troppe richieste nel periodo di tempo consentito.REQUEST_DENIEDindica che la pagina web non è autorizzata a utilizzare il servizio di indicazioni stradali.UNKNOWN_ERRORindica che una richiesta di indicazioni non è stato possibile elaborare a causa di un errore del server. La richiesta potrebbe andare a buon fine se riprovi.
Prima di elaborare il risultato, devi assicurarti che la query di indicazioni abbia restituito risultati validi controllando questo valore.
Visualizzazione di DirectionsResult
DirectionsResult contiene il risultato della
query di indicazioni stradali, che puoi gestire autonomamente o passare
a un oggetto DirectionsRenderer, che può
gestire automaticamente la visualizzazione del risultato su una mappa.
Per visualizzare un DirectionsResult utilizzando un
DirectionsRenderer, devi procedere nel
seguente modo:
- Crea un oggetto
DirectionsRenderer. - Chiama
setMap()sul renderer per associarlo alla mappa passata. - Chiama
setDirections()sul renderer, passandoDirectionsResultcome indicato sopra. Poiché il renderer è unMVCObject, rileverà automaticamente eventuali modifiche alle sue proprietà e aggiornerà la mappa quando le indicazioni associate sono cambiate.
L'esempio seguente calcola le indicazioni stradali tra
due località sulla Route 66, dove l'origine e la destinazione
sono impostate dai valori "start" e "end"
forniti negli elenchi a discesa. Il DirectionsRenderer
gestisce la visualizzazione della polilinea tra le posizioni indicate
e il posizionamento dei marcatori all'origine, alla destinazione e a eventuali tappe intermedie, se applicabile.
function initMap() { var directionsService = new google.maps.DirectionsService(); var directionsRenderer = new google.maps.DirectionsRenderer(); var chicago = new google.maps.LatLng(41.850033, -87.6500523); var mapOptions = { zoom:7, center: chicago } var map = new google.maps.Map(document.getElementById('map'), mapOptions); directionsRenderer.setMap(map); } function calcRoute() { var start = document.getElementById('start').value; var end = document.getElementById('end').value; var request = { origin: start, destination: end, travelMode: 'DRIVING' }; directionsService.route(request, function(result, status) { if (status == 'OK') { directionsRenderer.setDirections(result); } }); }
Nel corpo HTML:
<div> <strong>Start: </strong> <select id="start" onchange="calcRoute();"> <option value="chicago, il">Chicago</option> <option value="st louis, mo">St Louis</option> <option value="joplin, mo">Joplin, MO</option> <option value="oklahoma city, ok">Oklahoma City</option> <option value="amarillo, tx">Amarillo</option> <option value="gallup, nm">Gallup, NM</option> <option value="flagstaff, az">Flagstaff, AZ</option> <option value="winona, az">Winona</option> <option value="kingman, az">Kingman</option> <option value="barstow, ca">Barstow</option> <option value="san bernardino, ca">San Bernardino</option> <option value="los angeles, ca">Los Angeles</option> </select> <strong>End: </strong> <select id="end" onchange="calcRoute();"> <option value="chicago, il">Chicago</option> <option value="st louis, mo">St Louis</option> <option value="joplin, mo">Joplin, MO</option> <option value="oklahoma city, ok">Oklahoma City</option> <option value="amarillo, tx">Amarillo</option> <option value="gallup, nm">Gallup, NM</option> <option value="flagstaff, az">Flagstaff, AZ</option> <option value="winona, az">Winona</option> <option value="kingman, az">Kingman</option> <option value="barstow, ca">Barstow</option> <option value="san bernardino, ca">San Bernardino</option> <option value="los angeles, ca">Los Angeles</option> </select> </div>
Il seguente esempio mostra le indicazioni stradali utilizzando diverse modalità di trasporto tra Haight-Ashbury e Ocean Beach a San Francisco, California:
function initMap() { var directionsService = new google.maps.DirectionsService(); var directionsRenderer = new google.maps.DirectionsRenderer(); var haight = new google.maps.LatLng(37.7699298, -122.4469157); var oceanBeach = new google.maps.LatLng(37.7683909618184, -122.51089453697205); var mapOptions = { zoom: 14, center: haight } var map = new google.maps.Map(document.getElementById('map'), mapOptions); directionsRenderer.setMap(map); } function calcRoute() { var selectedMode = document.getElementById('mode').value; var request = { origin: haight, destination: oceanBeach, // Note that JavaScript allows us to access the constant // using square brackets and a string value as its // "property." travelMode: google.maps.TravelMode[selectedMode] }; directionsService.route(request, function(response, status) { if (status == 'OK') { directionsRenderer.setDirections(response); } }); }
Nel corpo HTML:
<div> <strong>Mode of Travel: </strong> <select id="mode" onchange="calcRoute();"> <option value="DRIVING">Driving</option> <option value="WALKING">Walking</option> <option value="BICYCLING">Bicycling</option> <option value="TRANSIT">Transit</option> </select> </div>
Un DirectionsRenderer non solo gestisce la visualizzazione
della polilinea e di eventuali indicatori associati, ma può anche gestire
la visualizzazione testuale delle indicazioni stradali come una serie di passaggi. Per farlo, chiama setPanel() sul tuo
DirectionsRenderer, passando il
<div> in cui visualizzare queste informazioni.
In questo modo, ti assicuri anche di visualizzare le informazioni sul copyright
appropriate e gli eventuali avvisi associati al
risultato.
Le indicazioni testuali verranno fornite utilizzando l'impostazione della lingua preferita del browser o la lingua specificata durante il caricamento del JavaScript dell'API utilizzando il parametro language. Per ulteriori informazioni, vedi
Localizzazione. Nel caso delle indicazioni stradali per il trasporto pubblico, l'ora verrà
visualizzata nel fuso orario della fermata del trasporto pubblico.
L'esempio seguente è identico a quello mostrato sopra,
ma include un pannello <div> in cui
visualizzare le indicazioni:
function initMap() { var directionsService = new google.maps.DirectionsService(); var directionsRenderer = new google.maps.DirectionsRenderer(); var chicago = new google.maps.LatLng(41.850033, -87.6500523); var mapOptions = { zoom:7, center: chicago } var map = new google.maps.Map(document.getElementById('map'), mapOptions); directionsRenderer.setMap(map); directionsRenderer.setPanel(document.getElementById('directionsPanel')); } function calcRoute() { var start = document.getElementById('start').value; var end = document.getElementById('end').value; var request = { origin:start, destination:end, travelMode: 'DRIVING' }; directionsService.route(request, function(response, status) { if (status == 'OK') { directionsRenderer.setDirections(response); } }); }
Nel corpo HTML:
<div id="map" style="float:left;width:70%;height:100%"></div> <div id="directionsPanel" style="float:right;width:30%;height:100%"></div>
L'oggetto DirectionsResult
Quando invii una richiesta di indicazioni all'DirectionsService, ricevi una risposta composta da un codice di stato e un risultato, ovvero un oggetto DirectionsResult. DirectionsResult è un oggetto letterale
con i seguenti campi:
geocoded_waypoints[]contiene un array di oggettiDirectionsGeocodedWaypoint, ognuno dei quali contiene dettagli sulla geocodifica di origine, destinazione e waypoint.routes[]contiene un array di oggettiDirectionsRoute. Ogni percorso indica un modo per andare dall'origine alla destinazione fornita inDirectionsRequest. In genere, per ogni richiesta viene restituito un solo percorso, a meno che il campoprovideRouteAlternativesdella richiesta non sia impostato sutrue, nel qual caso potrebbero essere restituiti più percorsi.
Nota:la proprietà via_waypoint è deprecata
nelle alternative di percorso. La versione 3.27 è l'ultima versione dell'API che aggiunge waypoint intermedi
in percorsi alternativi. Per le versioni 3.28 e successive dell'API, puoi continuare a implementare
indicazioni stradali trascinabili utilizzando il servizio Directions disabilitando il trascinamento di percorsi alternativi.
Solo l'itinerario principale deve essere trascinabile. Gli utenti possono trascinare l'itinerario principale finché non corrisponde a un
itinerario alternativo.
Tappe geocodificate delle indicazioni stradali
Un DirectionsGeocodedWaypoint contiene dettagli sulla geocodifica di
origine, destinazione e tappe intermedie.
DirectionsGeocodedWaypoint è un oggetto letterale con i seguenti campi:
geocoder_statusindica il codice di stato risultante dall'operazione di geocodifica. Questo campo può contenere i seguenti valori."OK"indica che non si sono verificati errori; l'indirizzo è stato analizzato correttamente e è stato restituito almeno un geocodice."ZERO_RESULTS"indica che il geocodice è stato creato correttamente, ma non ha restituito risultati. Ciò può verificarsi se al geocoder è stato trasmesso unaddressinesistente.
-
partial_matchindica che il geocoder non ha restituito una corrispondenza esatta per la richiesta originale, anche se è riuscito a trovare una corrispondenza parziale dell'indirizzo richiesto. Ti consigliamo di esaminare la richiesta originale per verificare la presenza di errori ortografici e/o un indirizzo incompleto.Le corrispondenze parziali si verificano più spesso per gli indirizzi stradali che non esistono all'interno della località che trasmetti nella richiesta. Le corrispondenze parziali possono essere restituite anche quando una richiesta corrisponde a due o più località nella stessa località. Ad esempio, "Hillpar St, Bristol, UK" restituirà una corrispondenza parziale sia per Henry Street sia per Henrietta Street. Tieni presente che se una richiesta include un componente dell'indirizzo con errori ortografici, il servizio di geocoding potrebbe suggerire un indirizzo alternativo. I suggerimenti attivati in questo modo verranno contrassegnati anche come corrispondenza parziale.
place_idè un identificatore univoco di un luogo, che può essere utilizzato con altre API di Google. Ad esempio, puoi utilizzareplace_idcon la libreria dell'API Google Places per ottenere i dettagli di un'attività locale, come il numero di telefono, l'orario di apertura, le recensioni degli utenti e altro ancora. Consulta la panoramica degli ID luogo.types[]è un array che indica il tipo del risultato restituito. Questo array contiene un insieme di zero o più tag che identificano il tipo di funzionalità restituita nel risultato. Ad esempio, un geocodice di "Chicago" restituisce "locality", che indica che "Chicago" è una città, e anche "political", che indica che è un'entità politica.
Percorsi indicazioni stradali
Nota: l'oggetto DirectionsTrip precedente è stato rinominato DirectionsRoute. Tieni presente che un itinerario
ora si riferisce all'intero percorso dall'inizio alla fine, anziché semplicemente
a una tappa di un viaggio principale.
Un DirectionsRoute contiene un singolo risultato
dall'origine e dalla destinazione specificate. Questo percorso può essere costituito da
una o più tappe (di tipo DirectionsLeg)
a seconda che siano stati specificati punti di passaggio. Inoltre, il
percorso contiene anche informazioni su copyright e avvisi che devono
essere visualizzati all'utente oltre alle informazioni sul percorso.
DirectionsRoute è un oggetto letterale con i seguenti campi:
legs[]contiene un array di oggettiDirectionsLeg, ognuno dei quali contiene informazioni su una tratta del percorso, da due località all'interno del percorso specificato. Verrà visualizzata una tappa separata per ogni waypoint o destinazione specificati. Un itinerario senza tappe conterrà esattamente unDirectionsLeg. Ogni tratta è composta da una serie diDirectionStep.waypoint_ordercontiene un array che indica l'ordine di eventuali waypoint nel percorso calcolato. Questo array potrebbe contenere un ordine modificato se è stato superatoDirectionsRequestoptimizeWaypoints: true.overview_pathcontiene un array diLatLngche rappresentano un percorso approssimativo (uniforme) delle indicazioni stradali risultanti.overview_polylinecontiene un singolo oggettopointsche contiene una rappresentazione codificata della polilinea dell'itinerario. Questa polilinea è un percorso approssimativo (uniforme) delle indicazioni stradali risultanti.boundscontiene unLatLngBoundsche indica i limiti della polilinea lungo questo percorso specifico.copyrightscontiene il testo dei diritti d'autore da visualizzare per questo percorso.warnings[]contiene un array di avvisi da visualizzare quando vengono mostrate queste indicazioni. Se non utilizzi l'oggettoDirectionsRendererfornito, devi gestire e visualizzare questi avvisi autonomamente.farecontiene la tariffa totale (ovvero il costo totale del biglietto) per questa tratta. Questa proprietà viene restituita solo per le richieste di trasporto pubblico e solo per i percorsi in cui sono disponibili informazioni sulla tariffa per tutti i segmenti di trasporto pubblico. Le informazioni includono:currency: un codice valuta ISO 4217 che indica la valuta in cui è espresso l'importo.value: l'importo totale della tariffa, nella valuta specificata sopra.
Gambe per indicazioni
Nota: l'oggetto DirectionsRoute precedente è stato rinominato DirectionsLeg.
Un DirectionsLeg definisce un singolo segmento di un
viaggio dall'origine alla destinazione nell'itinerario calcolato.
Per i percorsi che non contengono waypoint, il percorso sarà costituito da un
singolo "tratto", ma per i percorsi che definiscono uno o più waypoint,
il percorso sarà costituito da uno o più tratti, corrispondenti ai
tratti specifici del viaggio.
DirectionsLeg è un oggetto letterale con i
seguenti campi:
steps[]contiene un array di oggettiDirectionsStepche indicano informazioni su ogni fase separata della tratta del viaggio.distanceindica la distanza totale percorsa da questa tratta, come oggettoDistancedella seguente forma:valueindica la distanza in metritextcontiene una rappresentazione stringa della distanza, che per impostazione predefinita viene visualizzata in unità come utilizzato all'origine. Ad esempio, le miglia verranno utilizzate per qualsiasi origine all'interno degli Stati Uniti. Puoi ignorare questo sistema di unità impostando in modo specifico unUnitSystemnella query originale. Tieni presente che, indipendentemente dal sistema di unità utilizzato, il campodistance.valuecontiene sempre un valore espresso in metri.
Questi campi potrebbero essere indefiniti se la distanza è sconosciuta.
durationindica la durata totale di questa tratta, come oggettoDurationdel seguente formato:valueindica la durata in secondi.textcontiene una rappresentazione di stringa della durata.
Questi campi potrebbero non essere definiti se la durata è sconosciuta.
duration_in_trafficindica la durata totale di questo tratto, tenendo conto delle condizioni del traffico attuali. Ilduration_in_trafficviene restituito solo se tutte le seguenti condizioni sono vere:- La richiesta non include i waypoint di sosta. ovvero non
include i waypoint in cui
stopoverètrue. - La richiesta riguarda specificamente le indicazioni stradali: il
modeè impostato sudriving. departureTimeè incluso nel campodrivingOptionsdella richiesta.- Le condizioni del traffico sono disponibili per l'itinerario richiesto.
duration_in_trafficcontiene i seguenti campi:valueindica la durata in secondi.textcontiene una rappresentazione leggibile della durata.
- La richiesta non include i waypoint di sosta. ovvero non
include i waypoint in cui
arrival_timecontiene l'orario di arrivo stimato per questa tratta. Questa proprietà viene restituita solo per le indicazioni stradali con i mezzi pubblici. Il risultato viene restituito come oggettoTimecon tre proprietà:valuel'ora specificata come oggettoDateJavaScript.textl'ora specificata come stringa. L'ora viene visualizzata nel fuso orario della fermata del trasporto pubblico.time_zonecontiene il fuso orario di questa stazione. Il valore è il nome del fuso orario definito nel database dei fusi orari IANA, ad es. "America/New_York".
departure_timecontiene l'orario di partenza stimato per questa tratta, specificato come oggettoTime.departure_timeè disponibile solo per le indicazioni stradali per il trasporto pubblico.start_locationcontieneLatLngdell'origine di questa tratta. Poiché il servizio web Directions calcola le indicazioni stradali tra le località utilizzando l'opzione di trasporto più vicina (di solito una strada) nei punti di partenza e di arrivo,start_locationpotrebbe essere diverso dall'origine fornita di questa tratta se, ad esempio, una strada non è vicina all'origine.end_locationcontieneLatLngdella destinazione di questa tratta. PoichéDirectionsServicecalcola le indicazioni stradali tra le località utilizzando l'opzione di trasporto più vicina (di solito una strada) nei punti di partenza e di arrivo,end_locationpotrebbe essere diverso dalla destinazione fornita per questa tratta se, ad esempio, una strada non è vicina alla destinazione.start_addresscontiene l'indirizzo leggibile (in genere un indirizzo stradale) dell'inizio di questa tratta.
Questi contenuti devono essere letti così come sono. Non analizzare l'indirizzo formattato in modo programmatico.end_addresscontiene l'indirizzo leggibile (in genere un indirizzo stradale) della fine di questa tratta.
Questi contenuti devono essere letti così come sono. Non analizzare l'indirizzo formattato in modo programmatico.
Passaggi delle indicazioni stradali
Un DirectionsStep è l'unità più atomica di un
itinerario di indicazioni stradali, contenente un singolo passaggio che descrive una singola
istruzione specifica del viaggio. Ad esempio, "Svolta a sinistra in W. 4th St." Il passaggio non
solo descrive l'istruzione, ma contiene anche informazioni su distanza e durata
relative al modo in cui questo passaggio si collega al successivo.
Ad esempio, un passaggio indicato come "Immettersi sulla I-80 ovest" potrebbe contenere una
durata di "37 miglia" e "40 minuti", a indicare che il passaggio successivo
si trova a 37 miglia/40 minuti da questo passaggio.
Quando utilizzi il servizio Directions per cercare indicazioni stradali per il trasporto pubblico, l'array steps includerà informazioni specifiche sul trasporto pubblico aggiuntive sotto forma di oggetto transit. Se
le indicazioni includono più mezzi di trasporto, le indicazioni dettagliate
saranno fornite per i passaggi a piedi o in auto in un array steps[].
Ad esempio, un passo a piedi includerà le indicazioni dalle località di partenza e di arrivo: "Cammina fino a Innes Ave e Fitch St". Questo passaggio includerà
indicazioni dettagliate a piedi per l'itinerario nell'array steps[],
ad esempio: "Vai a nord-ovest", "Svolta a sinistra su Arelious Walker" e
"Svolta a sinistra su Innes Ave".
DirectionsStep è un oggetto letterale con i
seguenti campi:
instructionscontiene le istruzioni per questo passaggio all'interno di una stringa di testo.distancecontiene la distanza percorsa da questo passo fino al successivo, come oggettoDistance. (vedi la descrizione inDirectionsLegsopra). Questo campo potrebbe essere indefinito se la distanza è sconosciuta.durationcontiene una stima del tempo necessario per eseguire il passaggio, fino al passaggio successivo, come oggettoDuration. (vedi la descrizione inDirectionsLegsopra). Questo campo potrebbe essere indefinito se la durata è sconosciuta.start_locationcontiene le coordinate geograficheLatLngdel punto di partenza di questo passaggio.end_locationcontiene leLatLngdel punto finale di questo passaggio.polylinecontiene un singolo oggettopointsche contiene una rappresentazione codificata della polilinea del passaggio. Questa polilinea è un percorso approssimativo (uniforme) del passo.steps[]un letterale oggettoDirectionsStepche contiene indicazioni dettagliate per i passaggi a piedi o in auto nelle indicazioni di transito. I passaggi secondari sono disponibili solo per le indicazioni per trasporti pubblici.travel_modecontieneTravelModeutilizzato in questo passaggio. Le indicazioni stradali per il trasporto pubblico possono includere una combinazione di indicazioni stradali a piedi e per il trasporto pubblico.pathcontiene un array diLatLngsche descrivono il corso di questo passaggio.transitcontiene informazioni specifiche sul trasporto pubblico, ad esempio gli orari di arrivo e partenza e il nome della linea di trasporto pubblico.
Informazioni specifiche sul trasporto pubblico
Le indicazioni per il trasporto pubblico restituiscono informazioni aggiuntive non pertinenti per
altre modalità di trasporto. Queste proprietà aggiuntive vengono esposte
tramite l'oggetto TransitDetails, restituito come proprietà di
DirectionsStep. Dall'oggetto TransitDetails puoi accedere a informazioni aggiuntive per gli oggetti TransitStop, TransitLine, TransitAgency e VehicleType, come descritto di seguito.
Dettagli del transito
L'oggetto TransitDetails espone le seguenti
proprietà:
arrival_stopcontiene un oggettoTransitStopche rappresenta la stazione/fermata di arrivo con le seguenti proprietà:nameil nome della stazione/fermata di transito. Ad esempio: "Union Square".locationla posizione della stazione/fermata del trasporto pubblico, rappresentata da unLatLng.
departure_stopcontiene un oggettoTransitStopche rappresenta la stazione/fermata di partenza.arrival_timecontiene l'ora di arrivo, specificata come oggettoTimecon tre proprietà:valuel'ora specificata come oggettoDateJavaScript.textl'ora specificata come stringa. L'ora viene visualizzata nel fuso orario della fermata del trasporto pubblico.time_zonecontiene il fuso orario di questa stazione. Il valore è il nome del fuso orario definito nel database dei fusi orari IANA, ad es. "America/New_York".
departure_timecontiene l'orario di partenza, specificato come oggettoTime.headsignspecifica la direzione in cui viaggiare su questa linea, come indicato sul veicolo o alla fermata di partenza. Spesso si tratta della stazione di capolinea.headwayse disponibile, specifica il numero previsto di secondi tra le partenze dalla stessa fermata in questo momento. Ad esempio, con un valore diheadwaypari a 600, dovresti aspettarti un'attesa di dieci minuti se dovessi perdere l'autobus.linecontiene unTransitLineoggetto letterale che contiene informazioni sulla linea di trasporto pubblico utilizzata in questo passaggio.TransitLinefornisce il nome e l'operatore della linea, insieme ad altre proprietà descritte nella documentazione di riferimento diTransitLine.num_stopscontiene il numero di fermate in questo passaggio. Include la fermata di arrivo, ma non quella di partenza. Ad esempio, se le tue indicazioni stradali prevedono di partire dalla fermata A, passare per le fermate B e C e arrivare alla fermata D,num_stopsrestituirà 3.
Linea di trasporto pubblico
L'oggetto TransitLine espone le seguenti proprietà:
namecontiene il nome completo di questa linea di trasporto pubblico. Ad es. "7 Avenue Express" o "14th St Crosstown".short_namecontiene il nome breve di questa linea di trasporto pubblico. In genere si tratta di un numero di riga, ad esempio "2" o "M14".agenciesè un array contenente un singolo oggettoTransitAgency. L'oggettoTransitAgencyfornisce informazioni sull'operatore di questa linea, incluse le seguenti proprietà:namecontiene il nome dell'azienda di trasporto pubblico.phonecontiene il numero di telefono dell'azienda di trasporto pubblico.urlcontiene l'URL dell'azienda di trasporto pubblico.
Nota: se esegui il rendering delle indicazioni stradali per il trasporto pubblico manualmente anziché utilizzare l'oggetto
DirectionsRenderer, devi mostrare i nomi e gli URL delle aziende di trasporto pubblico che servono i risultati dell'itinerario.urlcontiene un URL per questa linea di trasporto pubblico fornito da dall'azienda di trasporto pubblico.iconcontiene un URL per l'icona associata a questa riga. La maggior parte delle città utilizza icone generiche che variano in base al tipo di veicolo. Alcune linee di trasporto pubblico, come la metropolitana di New York, hanno icone specifiche per quella linea.colorcontiene il colore comunemente utilizzato nella segnaletica per questo mezzo di trasporto pubblico. Il colore verrà specificato come stringa esadecimale, ad esempio #FF0033.text_colorcontiene il colore del testo comunemente utilizzato per la segnaletica di questa linea. Il colore verrà specificato come stringa esadecimale.vehiclecontiene un oggettoVehicleche include le seguenti proprietà:namecontiene il nome del veicolo su questa riga. Ad esempio: "Subway".typecontiene il tipo di veicolo utilizzato su questa linea. Consulta la documentazione relativa al tipo di veicolo per un elenco completo dei valori supportati.iconcontiene un URL per l'icona comunemente associata a questo tipo di veicolo.local_iconcontiene l'URL dell'icona associata a questo tipo di veicolo, in base alla segnaletica dei trasporti locali.
Tipo di veicolo
L'oggetto VehicleType espone le seguenti
proprietà:
| Valore | Definizione |
|---|---|
VehicleType.RAIL |
Ferrovia. |
VehicleType.METRO_RAIL |
Metropolitana leggera. |
VehicleType.SUBWAY |
Metropolitana leggera sotterranea. |
VehicleType.TRAM |
Metropolitana leggera di superficie. |
VehicleType.MONORAIL |
Monorail. |
VehicleType.HEAVY_RAIL |
Ferrovia pesante. |
VehicleType.COMMUTER_TRAIN |
Ferrovia suburbana. |
VehicleType.HIGH_SPEED_TRAIN |
Treno ad alta velocità. |
VehicleType.BUS |
Autobus. |
VehicleType.INTERCITY_BUS |
Autobus interurbano. |
VehicleType.TROLLEYBUS |
Filobus. |
VehicleType.SHARE_TAXI |
Un taxi condiviso è un tipo di autobus che può caricare e scaricare passeggeri ovunque lungo il suo percorso. |
VehicleType.FERRY |
Traghetto. |
VehicleType.CABLE_CAR |
Un veicolo che funziona con un cavo, di solito a terra. Le funivie
possono essere di tipo VehicleType.GONDOLA_LIFT. |
VehicleType.GONDOLA_LIFT |
Una funivia. |
VehicleType.FUNICULAR |
Un veicolo che viene tirato su una ripida salita da un cavo. Una funicolare è in genere costituita da due vagoni, ciascuno dei quali funge da contrappeso per l'altro. |
VehicleType.OTHER |
Tutti gli altri veicoli restituiranno questo tipo. |
Ispezione di DirectionsResults
I componenti DirectionsResults, ovvero DirectionsRoute, DirectionsLeg, DirectionsStep e TransitDetails, possono essere esaminati e utilizzati durante l'analisi di qualsiasi risposta relativa alle indicazioni stradali.
Importante: se esegui il rendering delle indicazioni
di transito manualmente anziché utilizzare l'oggetto DirectionsRenderer, devi visualizzare i nomi e gli URL delle aziende di trasporto pubblico
che servono i risultati del viaggio.
L'esempio seguente traccia le indicazioni stradali a piedi per alcune attrazioni turistiche di New York. Esaminiamo il DirectionsStep
dell'itinerario per aggiungere indicatori per ogni passaggio e
allegare informazioni a un InfoWindow con testo
istruttivo per quel passaggio.
Nota: poiché calcoliamo le indicazioni stradali a piedi, mostriamo anche
eventuali avvisi all'utente in un riquadro <div> separato.
var map; var directionsRenderer; var directionsService; var stepDisplay; var markerArray = []; function initMap() { // Instantiate a directions service. directionsService = new google.maps.DirectionsService(); // Create a map and center it on Manhattan. var manhattan = new google.maps.LatLng(40.7711329, -73.9741874); var mapOptions = { zoom: 13, center: manhattan } map = new google.maps.Map(document.getElementById('map'), mapOptions); // Create a renderer for directions and bind it to the map. var rendererOptions = { map: map } directionsRenderer = new google.maps.DirectionsRenderer(rendererOptions) // Instantiate an info window to hold step text. stepDisplay = new google.maps.InfoWindow(); } function calcRoute() { // First, clear out any existing markerArray // from previous calculations. for (i = 0; i < markerArray.length; i++) { markerArray[i].setMap(null); } // Retrieve the start and end locations and create // a DirectionsRequest using WALKING directions. var start = document.getElementById('start').value; var end = document.getElementById('end').value; var request = { origin: start, destination: end, travelMode: 'WALKING' }; // Route the directions and pass the response to a // function to create markers for each step. directionsService.route(request, function(response, status) { if (status == "OK") { var warnings = document.getElementById("warnings_panel"); warnings.innerHTML = "" + response.routes[0].warnings + ""; directionsRenderer.setDirections(response); showSteps(response); } }); } function showSteps(directionResult) { // For each step, place a marker, and add the text to the marker's // info window. Also attach the marker to an array so we // can keep track of it and remove it when calculating new // routes. var myRoute = directionResult.routes[0].legs[0]; for (var i = 0; i < myRoute.steps.length; i++) { var marker = new google.maps.Marker({ position: myRoute.steps[i].start_point, map: map }); attachInstructionText(marker, myRoute.steps[i].instructions); markerArray[i] = marker; } } function attachInstructionText(marker, text) { google.maps.event.addListener(marker, 'click', function() { stepDisplay.setContent(text); stepDisplay.open(map, marker); }); }
Nel corpo HTML:
<div>
<strong>Start: </strong>
<select id="start">
<option value="penn station, new york, ny">Penn Station</option>
<option value="grand central station, new york, ny">Grand Central Station</option>
<option value="625 8th Avenue New York NY 10018">Port Authority Bus Terminal</option>
<option value="staten island ferry terminal, new york, ny">Staten Island Ferry Terminal</option>
<option value="101 E 125th Street, New York, NY">Harlem - 125th St Station</option>
</select>
<strong>End: </strong>
<select id="end" onchange="calcRoute();">
<option value="260 Broadway New York NY 10007">City Hall</option>
<option value="W 49th St & 5th Ave, New York, NY 10020">Rockefeller Center</option>
<option value="moma, New York, NY">MOMA</option>
<option value="350 5th Ave, New York, NY, 10118">Empire State Building</option>
<option value="253 West 125th Street, New York, NY">Apollo Theatre</option>
<option value="1 Wall St, New York, NY">Wall St</option>
</select>
<div>Utilizzare i waypoint in Routes
Come indicato in DirectionsRequest,
puoi anche specificare waypoint
(di tipo DirectionsWaypoint) quando calcoli
i percorsi utilizzando il servizio Directions per le indicazioni stradali a piedi, in bicicletta o in auto. Le tappe non sono disponibili per le indicazioni per trasporti pubblici.
Le tappe ti consentono di calcolare i percorsi attraverso località aggiuntive, nel qual caso il percorso restituito passa attraverso le tappe specificate.
Un waypoint è costituito dai seguenti campi:
location(obbligatorio) specifica l'indirizzo del waypoint.stopover(facoltativo) indica se questa tappa è una fermata effettiva dell'itinerario (true) o solo una preferenza per passare per la posizione indicata (false). Le soste sonotrueper impostazione predefinita.
Per impostazione predefinita, il servizio Directions calcola un percorso attraverso
i waypoint forniti nell'ordine indicato. Se vuoi, puoi
trasmettere optimizeWaypoints: true all'interno di
DirectionsRequest per consentire al servizio Directions di
ottimizzare l'itinerario fornito riorganizzando le tappe in
un ordine più efficiente. (Questa ottimizzazione è un'applicazione del
problema del commesso viaggiatore.) Il tempo di percorrenza è il fattore principale
ottimizzato, ma nella scelta del percorso più efficiente possono essere presi in considerazione anche altri fattori, come distanza, numero di svolte e molti altri. Tutti
i waypoint devono essere soste intermedie per consentire al servizio Indicazioni di ottimizzare il
percorso.
Se chiedi al servizio Directions di ottimizzare l'ordine dei
waypoint, il loro ordine verrà restituito nel campo
waypoint_order all'interno dell'oggetto
DirectionsResult.
L'esempio seguente calcola i percorsi transnazionali negli Stati Uniti utilizzando una serie di punti di partenza, punti di arrivo e tappe intermedie. (Per selezionare più tappe, premi
Ctrl-Click quando selezioni gli elementi all'interno dell'elenco.)
Tieni presente che esaminiamo routes.start_address
e routes.end_address per fornirci
il testo per il punto di partenza e di arrivo di ogni percorso.
TypeScript
function initMap(): void { const directionsService = new google.maps.DirectionsService(); const directionsRenderer = new google.maps.DirectionsRenderer(); const map = new google.maps.Map( document.getElementById("map") as HTMLElement, { zoom: 6, center: { lat: 41.85, lng: -87.65 }, } ); directionsRenderer.setMap(map); (document.getElementById("submit") as HTMLElement).addEventListener( "click", () => { calculateAndDisplayRoute(directionsService, directionsRenderer); } ); } function calculateAndDisplayRoute( directionsService: google.maps.DirectionsService, directionsRenderer: google.maps.DirectionsRenderer ) { const waypts: google.maps.DirectionsWaypoint[] = []; const checkboxArray = document.getElementById( "waypoints" ) as HTMLSelectElement; for (let i = 0; i < checkboxArray.length; i++) { if (checkboxArray.options[i].selected) { waypts.push({ location: (checkboxArray[i] as HTMLOptionElement).value, stopover: true, }); } } directionsService .route({ origin: (document.getElementById("start") as HTMLInputElement).value, destination: (document.getElementById("end") as HTMLInputElement).value, waypoints: waypts, optimizeWaypoints: true, travelMode: google.maps.TravelMode.DRIVING, }) .then((response) => { directionsRenderer.setDirections(response); const route = response.routes[0]; const summaryPanel = document.getElementById( "directions-panel" ) as HTMLElement; summaryPanel.innerHTML = ""; // For each route, display summary information. for (let i = 0; i < route.legs.length; i++) { const routeSegment = i + 1; summaryPanel.innerHTML += "<b>Route Segment: " + routeSegment + "</b><br>"; summaryPanel.innerHTML += route.legs[i].start_address + " to "; summaryPanel.innerHTML += route.legs[i].end_address + "<br>"; summaryPanel.innerHTML += route.legs[i].distance!.text + "<br><br>"; } }) .catch((e) => window.alert("Directions request failed due to " + status)); } declare global { interface Window { initMap: () => void; } } window.initMap = initMap;
JavaScript
function initMap() { const directionsService = new google.maps.DirectionsService(); const directionsRenderer = new google.maps.DirectionsRenderer(); const map = new google.maps.Map(document.getElementById("map"), { zoom: 6, center: { lat: 41.85, lng: -87.65 }, }); directionsRenderer.setMap(map); document.getElementById("submit").addEventListener("click", () => { calculateAndDisplayRoute(directionsService, directionsRenderer); }); } function calculateAndDisplayRoute(directionsService, directionsRenderer) { const waypts = []; const checkboxArray = document.getElementById("waypoints"); for (let i = 0; i < checkboxArray.length; i++) { if (checkboxArray.options[i].selected) { waypts.push({ location: checkboxArray[i].value, stopover: true, }); } } directionsService .route({ origin: document.getElementById("start").value, destination: document.getElementById("end").value, waypoints: waypts, optimizeWaypoints: true, travelMode: google.maps.TravelMode.DRIVING, }) .then((response) => { directionsRenderer.setDirections(response); const route = response.routes[0]; const summaryPanel = document.getElementById("directions-panel"); summaryPanel.innerHTML = ""; // For each route, display summary information. for (let i = 0; i < route.legs.length; i++) { const routeSegment = i + 1; summaryPanel.innerHTML += "<b>Route Segment: " + routeSegment + "</b><br>"; summaryPanel.innerHTML += route.legs[i].start_address + " to "; summaryPanel.innerHTML += route.legs[i].end_address + "<br>"; summaryPanel.innerHTML += route.legs[i].distance.text + "<br><br>"; } }) .catch((e) => window.alert("Directions request failed due to " + status)); } window.initMap = initMap;
Limiti e restrizioni per i waypoint
Si applicano i seguenti limiti e limitazioni di utilizzo:
- Il numero massimo di tappe consentite quando si utilizza il servizio Directions nell'API Maps JavaScript è 25, più l'origine e la destinazione. I limiti sono gli stessi per il servizio web API Directions (legacy).
- Per il servizio web Directions API (legacy), i clienti possono utilizzare 25 waypoint, più l'origine e la destinazione.
- I clienti del piano Premium di Google Maps Platform possono utilizzare 25 tappe intermedie, oltre all'origine e alla destinazione.
- Le tappe intermedie non sono supportate per le indicazioni stradali con il trasporto pubblico.
Indicazioni trascinabili
Gli utenti possono modificare le indicazioni stradali per bicicletta, a piedi o in auto visualizzate utilizzando un
DirectionsRenderer in modo dinamico se sono
trascinabili, consentendo a un utente di selezionare e modificare
i percorsi facendo clic e trascinando i percorsi risultanti sulla mappa.
Indica se la visualizzazione di un renderer consente di trascinare
le indicazioni impostando la proprietà draggable
su true. Le indicazioni per i trasporti pubblici non possono essere trascinate.
Quando le indicazioni stradali sono trascinabili, un utente può selezionare qualsiasi punto del percorso (o waypoint) del risultato visualizzato e spostare il componente indicato in una nuova posizione. Il DirectionsRenderer
si aggiornerà dinamicamente per mostrare il percorso modificato. Al rilascio, sulla mappa verrà aggiunto un punto di passaggio (indicato da un piccolo indicatore bianco). Se selezioni e sposti un segmento del percorso,
modificando la tratta dell'itinerario, mentre se selezioni e sposti
un indicatore di waypoint (inclusi i punti di partenza e di arrivo), modifichi le
tratte dell'itinerario che passano per quel waypoint.
Poiché le indicazioni stradali trascinabili vengono modificate e visualizzate lato client,
potresti voler monitorare e gestire l'evento directions_changed
su DirectionsRenderer per ricevere una notifica quando l'utente
ha modificato le indicazioni stradali visualizzate.
Il seguente codice mostra un viaggio da Perth, sulla costa occidentale dell'Australia,
a Sydney, sulla costa orientale. Il codice monitora l'evento
directions_changed per aggiornare la distanza totale
di tutte le tappe del viaggio.
TypeScript
function initMap(): void { const map = new google.maps.Map( document.getElementById("map") as HTMLElement, { zoom: 4, center: { lat: -24.345, lng: 134.46 }, // Australia. } ); const directionsService = new google.maps.DirectionsService(); const directionsRenderer = new google.maps.DirectionsRenderer({ draggable: true, map, panel: document.getElementById("panel") as HTMLElement, }); directionsRenderer.addListener("directions_changed", () => { const directions = directionsRenderer.getDirections(); if (directions) { computeTotalDistance(directions); } }); displayRoute( "Perth, WA", "Sydney, NSW", directionsService, directionsRenderer ); } function displayRoute( origin: string, destination: string, service: google.maps.DirectionsService, display: google.maps.DirectionsRenderer ) { service .route({ origin: origin, destination: destination, waypoints: [ { location: "Adelaide, SA" }, { location: "Broken Hill, NSW" }, ], travelMode: google.maps.TravelMode.DRIVING, avoidTolls: true, }) .then((result: google.maps.DirectionsResult) => { display.setDirections(result); }) .catch((e) => { alert("Could not display directions due to: " + e); }); } function computeTotalDistance(result: google.maps.DirectionsResult) { let total = 0; const myroute = result.routes[0]; if (!myroute) { return; } for (let i = 0; i < myroute.legs.length; i++) { total += myroute.legs[i]!.distance!.value; } total = total / 1000; (document.getElementById("total") as HTMLElement).innerHTML = total + " km"; } declare global { interface Window { initMap: () => void; } } window.initMap = initMap;
JavaScript
function initMap() { const map = new google.maps.Map(document.getElementById("map"), { zoom: 4, center: { lat: -24.345, lng: 134.46 }, // Australia. }); const directionsService = new google.maps.DirectionsService(); const directionsRenderer = new google.maps.DirectionsRenderer({ draggable: true, map, panel: document.getElementById("panel"), }); directionsRenderer.addListener("directions_changed", () => { const directions = directionsRenderer.getDirections(); if (directions) { computeTotalDistance(directions); } }); displayRoute( "Perth, WA", "Sydney, NSW", directionsService, directionsRenderer, ); } function displayRoute(origin, destination, service, display) { service .route({ origin: origin, destination: destination, waypoints: [ { location: "Adelaide, SA" }, { location: "Broken Hill, NSW" }, ], travelMode: google.maps.TravelMode.DRIVING, avoidTolls: true, }) .then((result) => { display.setDirections(result); }) .catch((e) => { alert("Could not display directions due to: " + e); }); } function computeTotalDistance(result) { let total = 0; const myroute = result.routes[0]; if (!myroute) { return; } for (let i = 0; i < myroute.legs.length; i++) { total += myroute.legs[i].distance.value; } total = total / 1000; document.getElementById("total").innerHTML = total + " km"; } window.initMap = initMap;