По умолчанию промежуточные точки маршрута используются для остановок при посадке и высадке пассажиров, но вы также можете указать, что промежуточная точка маршрута предназначена только для проезда.
Маршрут, содержащий исходную точку маршрута, промежуточную точку маршрута и точку назначения, содержит только один отрезок маршрута, который соединяет исходную точку и точку назначения, проходя при этом через промежуточную (называемую via
) точку маршрута.
Настройте промежуточную точку маршрута как сквозную точку маршрута, установив свойство via
точки маршрута в true
, используя Waypoint (REST) или Waypoint (gRPC).
Свойство via
наиболее эффективно при создании маршрутов в ответ на перетаскивание пользователем путевых точек на карте. Это позволяет пользователю увидеть, как может выглядеть окончательный маршрут в реальном времени, и помогает гарантировать, что путевые точки размещаются в местах, доступных для Compute Routes.
В следующем примере показано, как обозначить промежуточную точку маршрута как сквозную точку маршрута.
{ "location": { "latLng": { "latitude":37.419734, "longitude":-122.0827784 } }, "via": true }
Доступ к идентификаторам мест для промежуточных точек маршрута
Если указать местоположение исходной, конечной или промежуточной точки маршрута в виде адресной строки или кода Plus , API попытается найти наиболее релевантное местоположение, имеющее соответствующий идентификатор места. Массив geocodingResults.intermediates
в результатах содержит идентификатор места, соответствующий местоположению точек маршрута, а также дополнительные данные о местоположении.
Для каждого элемента массива intermediates
используйте свойство intermediateWaypointRequestIndex
, чтобы определить, какая промежуточная точка маршрута в запросе соответствует идентификатору места в ответе.
Например:
Вы указываете три промежуточные точки маршрута в запросе. Две из этих точек маршрута указываются адресными строками, а одна — координатами широты/долготы.
Вы включаете
geocodingResults
в маску поля ответа, чтобы указать, что в результатах следует вернуть массивgeocodingResults
.
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'
Ответ включает массив geocodingResults
, содержащий идентификатор места для исходной точки, пункта назначения и двух из трех путевых точек. Это путевые точки с индексом 0 и 2 запроса. Поскольку путевая точка с индексом 1 запроса была указана с использованием координат широты/долготы, она опущена из массива geocodingResults
в ответе.
{ "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" } ] } }