默认情况下,中间航点用于停靠上车点,以及 您也可以指定中间路径点只是 才能通过。
包含起点航点、直通车中间路径的路线
而一个目的地航点只包含一段
连接起点和终点,同时经过中间
(称为 via
)航点。
将中间航点配置为直通航点
使用以下任一方法将航点的 via
属性设置为 true
:
Waypoint (REST) 或
Waypoint (gRPC)。
via
属性在创建路由以响应
用户在地图上拖动航点。这样,用户就可以了解
最终路线可实时查看,这有助于确保航点
计算路由可访问的位置中。
以下示例展示了如何将中间航点标记为 传递路径点。
{ "location": { "latLng": { "latitude":37.419734, "longitude":-122.0827784 } }, "via": true }
访问中间航点的地点 ID
如果您指定了出发地、目的地或中间航点的位置
作为地址字符串或 Plus Code 表示,API 会尝试查找
且具有对应的地点 ID 的最相关营业地点。通过
geocodingResults.intermediates
数组包含与
航点以及关于该位置的其他数据
对于 intermediates
数组的每个元素,使用
intermediateWaypointRequestIndex
属性来确定
请求中的航点与响应中的地点 ID 相对应。
例如:
您可以在请求中指定三个中间路标。其中两项 航点由地址字符串指定,一个由纬度/经度指定 坐标。
您可以在响应字段掩码中加入
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 处的航点。由于
请求是通过使用纬度/经度坐标指定的,
响应的 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" } ] } }