デフォルトでは、中間ウェイポイントは乗車と降車の停車地点として使用されますが、中間ウェイポイントを通過地点として指定することもできます。
出発地ウェイポイント、通過中間ウェイポイント、目的地ウェイポイントを含むルートには、出発地と目的地を接続し、中間ウェイポイント(via
という)を通過するルート区間が 1 つだけ含まれます。
Waypoint(REST)または Waypoint(gRPC)を使用して、中間ウェイポイントの via
プロパティを true
に設定し、パススルー ウェイポイントとして構成します。
via
プロパティは、ユーザーがマップ上でウェイポイントをドラッグしてルートを作成する場合に最も効果的です。そうすることで、ユーザーはリアルタイムで最終ルートを確認でき、Compute Routes がアクセス可能な地点に確実にウェイポイントを配置するのに役立ちます。
次の例は、中間ウェイポイントをパススルー ウェイポイントとしてマークする方法を示しています。
{ "location": { "latLng": { "latitude":37.419734, "longitude":-122.0827784 } }, "via": true }
中間ウェイポイントのプレイス ID にアクセスする
出発地、目的地、または中間ウェイポイントの位置を住所文字列またはプラスコードとして指定すると、API は対応するプレイス ID を持つ最も関連性の高い位置を検索しようとします。結果の geocodingResults.intermediates
配列には、ウェイポイントの位置に対応するプレイス ID と、その場所に関する追加データが含まれます。
intermediates
配列の各要素について、intermediateWaypointRequestIndex
プロパティを使用して、リクエスト内のどの中間ウェイポイントがレスポンスのプレイス ID に対応しているかを判断します。
次に例を示します。
リクエストで 3 つの中間ウェイポイントを指定します。これらの 3 つのウェイポイントのうち 2 つは住所文字列で指定され、1 つは緯度と経度の座標で指定されます。
レスポンス フィールド マスクに
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'
レスポンスには、出発地、目的地、3 つのウェイポイントのうち 2 つのプレイス ID を含む 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" } ] } }