根據預設,中繼路線控點可用於停靠上車, 但也能指定中繼路線控點 才能傳遞
包含起點路線控點、直通式中繼器的路線
而目的地路點則僅包含一個路線路段
連結起點和目的地,同時通過
(稱為 via
) 路線控點。
如要將中繼路點設定為直通路點,請
使用以下程式碼,將路線控點的 via
屬性設為 true
Waypoint (REST) 或
Waypoint (gRPC)。
建立路徑以回應via
使用者拖曳地圖上的路線控點。方便使用者瞭解
最終路線可能會即時檢視,而且有助於確保路線控點
並且放置在可存取 Compute Routes 的位置
以下範例說明如何將中繼路線控點標示為 直通式路線控點
{ "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" } ] } }