Por padrão, os pontos intermediários são usados para paradas de coleta e entrega, mas você também pode especificar que um ponto intermediário é apenas para passar.
Uma rota que contém um waypoint de origem, um waypoint intermediário de passagem e um waypoint de destino contém apenas um trecho de rota que conecta a origem e o destino, passando pelo waypoint intermediário (chamado de via
).
Configure um ponto de passagem intermediário definindo a propriedade via
do ponto de passagem como true
usando Waypoint (REST) ou Waypoint (gRPC).
A propriedade via
é mais eficiente ao criar rotas em resposta ao usuário arrastar os pontos de referência pelo mapa. Isso permite que o usuário veja como
a rota final pode ficar em tempo real e ajuda a garantir que os pontos de referência sejam posicionados
em locais acessíveis para as rotas de computação.
O exemplo a seguir demonstra como marcar um ponto de passagem intermediário como um ponto de passagem de passagem.
{ "location": { "latLng": { "latitude":37.419734, "longitude":-122.0827784 } }, "via": true }
Acessar IDs de lugares para waypoints intermediários
Se você especificar o local de uma origem, destino ou ponto intermediário como um endereço em string ou um Plus Code, a API vai tentar encontrar o local mais relevante que tenha um ID de lugar correspondente. A matriz
geocodingResults.intermediates
nos resultados contém o ID de lugar correspondente ao local dos
waypoints, além de outros dados sobre o local.
Para cada elemento da matriz intermediates
, use a propriedade intermediateWaypointRequestIndex
para determinar qual ponto de passagem intermediário na solicitação corresponde ao ID do lugar na resposta.
Exemplo:
Você especifica três pontos de passagem intermediários em uma solicitação. Dois desses pontos de referência são especificados por strings de endereço e um por coordenadas de latitude/longitude.
Inclua
geocodingResults
na máscara de campo de resposta para especificar o retorno da matrizgeocodingResults
nos resultados.
curl -X POST -d '{ "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "intermediates": [ { "address": "450 Serra Mall, Stanford, CA 94305, USA" }, { "location":{ "latLng":{ "latitude": 37.419734, "longitude": -122.0807784 } } }, { "address": "1836 El Camino Real, Redwood City, CA 94063" } ], "travelMode": "DRIVE", }' -H 'Content-Type: application/json' -H 'X-Goog-Api-Key: YOUR_API_KEY' -H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.legs,geocodingResults' 'https://routes.googleapis.com/directions/v2:computeRoutes'
A resposta inclui a matriz geocodingResults
, que contém o ID do lugar para a origem, o destino e dois dos três pontos de passagem. Estes são os pontos de passagem nos índices 0 e 2 da solicitação. Como o ponto de passagem no índice 1 da solicitação foi especificado usando coordenadas de latitude/longitude, ele foi omitido da matriz geocodingResults
na resposta.
{ "routes": [{...}], "geocodingResults": { "origin": { "geocoderStatus": {}, "type": [ "premise" ], "placeId": "ChIJj38IfwK6j4ARNcyPDnEGa9g" }, "destination": { "geocoderStatus": {}, "type": [ "premise" ], "placeId": "ChIJI7ES6tl_j4ARVpDZoXbWAiY" }, "intermediates": [ { "geocoderStatus": {}, "intermediateWaypointRequestIndex": 0, "type": [ "street_address" ], "placeId": "ChIJvdLMGyq7j4ARScE5tWX_C0Y" }, { "geocoderStatus": {}, "intermediateWaypointRequestIndex": 2, "type": [ "premise" ], "placeId": "ChIJkTc0GKajj4AR9UMsOSHwGD0" } ] } }