公共交通機関のルートは、その地域で利用できる公共交通機関のオプションを使用してナビゲーションの手順を提供します。公共交通機関のオプションには、バス、地下鉄、電車などがあります。公共交通機関のルートには通常、公共交通機関の駅までの徒歩、駅からの徒歩、駅間の移動に関する手順も含まれます。公共交通機関のルートでは通常、複数の移動手段を使用する必要があるため、ルートのリクエスト方法とレスポンスの一部が異なります。
公共交通機関のルートと他のルートの違い
travelMode を TRANSIT に設定してリクエストする公共交通機関のルートは、異なる travelMode オプションを使用するルートとは異なります。 他のルートと比較して、同じオブジェクトとオプションをすべてリクエストすることはできず、レスポンスで返されるフィールドも異なります。
Routes API では、ステップはすべての移動手段で一貫して 1 つのナビゲーション手順です。つまり、各ナビゲーション手順が 1 つのステップになります。公共交通機関のルートのレスポンスは、他の移動手段のルートとよく似ていますが、いくつかの重要な違いがあります。
| リクエストの違い | レスポンスの違い |
|---|---|
| 中間経由地を指定することはできません。 | 公共交通機関の詳細が含まれます。 |
| 環境に優しいルートを取得できません | 各移動手段のメタデータが含まれます。このメタデータには、その移動手段のステップの概要が `stepsOverview` に含まれています(このメタデータをリクエストするには、`routes.legs.stepsOverview` フィールド マスクを使用します)。 |
| 交通データを含める方法と含めるかどうかを指定できません | |
| 回避するルートの機能を指定できません | |
に指定できるのは transitPreferences のみです。routingPreference詳細については、
TransitPreferences をご覧ください。 |
Routes API から返されるレスポンスの詳細については、 公共交通機関のルートのレスポンスを確認するをご覧ください。
公共交通機関のルートを取得するには
出発地と目的地を設定します。
移動手段を公共交通機関に設定します。
travelMode: "TRANSIT"フィールド マスクを追加して、必要なレスポンス フィールドを取得します。 必要な公共交通機関のルート フィールドをリクエストするをご覧ください。
必要に応じて、省略可能なパラメータを設定します。公共交通機関のルートのパラメータを設定する をご覧ください。
必要な公共交通機関のルート フィールドをリクエストする
フィールド マスクを使用して、必要な公共交通機関のルート フィールドをリクエストします。次の表に、公共交通機関のルートのレスポンスの例と、リクエストに使用するフィールド マスクを示します。
| この情報をリクエストするには | このフィールド マスクを使用します |
|---|---|
| すべてのルートの詳細 | routes.* |
| 公共交通機関の詳細 | routes.legs.steps.transitDetails |
| 各区間の出発地 | routes.legs.steps.startLocation |
| 各区間の目的地 | routes.legs.steps.endLocation |
| 各ステップのルートポリライン | routes.legs.steps.polyline |
| 各ステップで使用される公共交通機関の種類 | routes.legs.steps.travelMode |
| 各ステップとルートの推定料金、ローカライズされた推定料金 | routes.travel_advisory.transitFare
localized routes.localizedValues.transitFare
注: |
| 所要時間と距離のローカライズされたテキスト | routes.localizedValues |
フィールド マスクの設定の詳細については、 返すフィールドの選択をご覧ください。
公共交通機関のルートのパラメータを設定する
公共交通機関のルートに関連するパラメータは次のとおりです。
| 操作 | 使用するパラメータ | メモ |
|---|---|---|
| 公共交通機関モードを選択する | travelMode: "TRANSIT" |
必須。 詳細 |
| 到着時刻または出発時刻を設定する | "arrivalTime": "yyyy-mm-ddThh:mm:ssZ"
または "departureTime": "yyyy-mm-ddThh:mm:ssZ" |
省略可。arrival_time または departure_time のいずれかを指定できます。どちらの時刻も指定しない場合、departure_time はデフォルトで現在の実行時刻(now)になります。到着時刻と出発時刻は、現在の実行時刻(now)を基準として、次の期間内にのみ設定できます。
注: 公共交通機関のスケジュールは頻繁に変更されるため、利用可能な公共交通機関のルートは時間とともに変化する可能性があります。また、かなり先の予測について一貫した結果を提供することは保証されません。 |
| 別のルートを含める | "computeAlternativeRoutes": true |
省略可。true に設定すると、利用可能な場合、ルートの計算で最大 3 つの追加ルートが計算されます。 詳細 |
| 公共交通機関の種類の条件を指定する | "transitPreferences": { allowedTravelModes: ["BUS","SUBWAY","TRAIN","LIGHT_RAIL","RAIL"]}
注: 希望する移動手段を指定した場合でも、希望する移動手段のルートの効率や利用可能性によっては、返されるルートで他の公共交通機関のモードが使用されることがあります。 |
省略可。希望する公共交通機関の移動手段を指定します。 詳細 |
| 公共交通機関のルートの条件を指定する | "transitPreferences": {routingPreference: "LESS_WALKING|FEWER_TRANSFERS"} |
省略可。公共交通機関のルーティングの条件を指定します。詳細 |
例: 公共交通機関のルートを取得する
次の例では、次のパラメータを使用して公共交通機関のルートを取得します。
電車での移動と徒歩での移動を少なくする条件を指定します。
別のルートをリクエストします。
公共交通機関の詳細を返すフィールド マスクを指定します。
curl -X POST -H 'content-type: application/json' -d '{ "origin": { "address": "Humberto Delgado Airport, Portugal" }, "destination": { "address": "Basílica of Estrela, Praça da Estrela, 1200-667 Lisboa, Portugal" }, "travelMode": "TRANSIT", "computeAlternativeRoutes": true, "transitPreferences": { routingPreference: "LESS_WALKING", allowedTravelModes: ["TRAIN"] }, }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.legs.steps.transitDetails' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
レスポンスには、2 つのルートの route.legs.steps.transitDetails フィールドが表示されます。
{ "routes": [ { "legs": [ { "steps": [ {}, {}, {}, { "transitDetails": { "stopDetails": { "arrivalStop": { "name": "Saldanha", "location": { "latLng": { "latitude": 38.73532, "longitude": -9.14543 } } }, "arrivalTime": "2023-08-26T10:49:42Z", "departureStop": { "name": "Aeroporto", "location": { "latLng": { "latitude": 38.769047799999996, "longitude": -9.1284593 } } }, "departureTime": "2023-08-26T10:32:10Z" }, "localizedValues": { "arrivalTime": { "time": { "text": "11:49" }, "timeZone": "Europe/Lisbon" }, "departureTime": { "time": { "text": "11:32" }, "timeZone": "Europe/Lisbon" } }, "headsign": "São Sebastião", "transitLine": { "agencies": [ { "name": "Metropolitano de Lisboa, E.P.E.", "phoneNumber": "+351 21 350 0115", "uri": "https://www.metrolisboa.pt/" } ], "name": "Vermelha", "color": "#f23061", "nameShort": "Vm", "textColor": "#000000", "vehicle": { "name": { "text": "Metrô" }, "type": "SUBWAY", "iconUri": "//maps.gstatic.com/mapfiles/transit/iw2/6/subway2.png" } }, "stopCount": 11 } }, {}, { "transitDetails": { "stopDetails": { "arrivalStop": { "name": "Rato", "location": { "latLng": { "latitude": 38.7201022, "longitude": -9.1540562 } } }, "arrivalTime": "2023-08-26T11:01:37Z", "departureStop": { "name": "Saldanha", "location": { "latLng": { "latitude": 38.73527, "longitude": -9.1455200000000012 } } }, "departureTime": "2023-08-26T10:57:57Z" }, "localizedValues": { "arrivalTime": { "time": { "text": "12:01" }, "timeZone": "Europe/Lisbon" }, "departureTime": { "time": { "text": "11:57" }, "timeZone": "Europe/Lisbon" } }, "headsign": "Rato", "transitLine": { "agencies": [ { "name": "Metropolitano de Lisboa, E.P.E.", "phoneNumber": "+351 21 350 0115", "uri": "https://www.metrolisboa.pt/" } ], "name": "Amarela", "color": "#f2c200", "nameShort": "Am", "textColor": "#000000", "vehicle": { "name": { "text": "Metrô" }, "type": "SUBWAY", "iconUri": "//maps.gstatic.com/mapfiles/transit/iw2/6/subway2.png" } }, "stopCount": 4 } }, {}, {}, {}, {}, {}, {} ] } ] } ] }