设置途经点

默认情况下,中继航点用于停车上车和下车,但您也可以指定中继航点只是用于通过。

包含起点航点、直通中继航点和目的地航点的路线仅包含一条路线航段,该航段连接起点和目的地,并经过中继航点(称为 via)。

使用 Waypoint (REST) 或 Waypoint (gRPC) 将航点的 via 属性设置为 true,即可将中间航点配置为直通航点。

在创建路线来响应用户在地图上拖动航点时,via 属性最为有效。这样做可让用户实时了解最终路线的具体走向,并有助于确保将路径点放置在计算路线可以访问的位置。

以下示例演示了如何将中间航点标记为透视航点。

{
  "location": {
    "latLng": {
      "latitude":37.419734,
      "longitude":-122.0827784
    }
  },
  "via": true
}

访问中间航点的地点 ID

如果您以地址字符串Plus Code 的形式指定出发地、目的地或中途航点的位置,该 API 会尝试查找具有对应地点 ID 的最相关位置。结果中的 geocodingResults.intermediates 数组包含与航点位置对应的地点 ID,以及与该位置相关的其他数据。

对于 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 数组,其中包含出发地、目的地和三个航点中两个航点的地点 ID。这些是请求中索引为 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"
      }
    ]
  }
}