交通機関の経路を取得

交通機関のルートでは、その地域で利用可能な公共交通機関オプションを使用した移動手順が示されます。公共交通機関には、バス、地下鉄、電車などがあります。乗換案内には通常、駅までの徒歩経路や駅までの徒歩ルートも含まれます。通常、1 つの交通機関のルートでは複数の移動手段を使用する必要があるため、ルートのリクエスト方法とレスポンスの一部が異なります。

交通機関のルートと他の経路との違い

交通機関のルートは、travelMode を TRANSIT に設定してリクエストしますが、travelMode オプションが異なるルートとは異なります。同じオブジェクトとオプションをすべてリクエストすることはできません。他のルートと比較すると、レスポンスは異なるフィールドを返します。

Routes API のステップは、すべての種類の移動において一貫して 1 つのナビゲーション手順です。つまり、各ナビゲーション命令が 1 つのステップとなります。交通機関のルートのレスポンスは、他の移動手段のルートとよく似ていますが、重要な違いがいくつかあります。

リクエストの差異 レスポンスの違い
中間地点を指定することはできません。 交通機関の詳細が含まれます。
環境に優しいルートを取得できません その交通手段のステップの概要を含む、各交通手段のメタデータを「stepsOverview」に格納します(このメタデータをリクエストするには、「routes.legs.stepsOverview」フィールド マスクを使用します)。
トラフィック データを含めるかどうか、含める場合は指定できません
回避するルート対象物を指定できません
routingPreference には transitPreferences のみ指定できます。詳しくは、[TransitPreferences](reference/rest/v2/TransitPreferences) をご覧ください。

Routes API から返されるレスポンスの詳細については、乗換案内ルートのレスポンスを確認するをご覧ください。

交通機関のルートを検索するには

  1. 出発地と目的地を設定します。

  2. 移動手段を交通機関に設定します。

    travelMode: "TRANSIT"

  3. 必要なレスポンス フィールドを取得するために、フィールド マスクを追加します。必要な乗換案内フィールドをリクエストするをご覧ください。

  4. 必要に応じて、省略可能なパラメータを設定します。交通機関のルートのパラメータを設定するをご覧ください。

必要な乗換案内フィールドをリクエストする

フィールド マスクを使用して、必要な乗換案内フィールドをリクエストします。次の表に、交通機関ルートに対して推奨されるレスポンスと、そのリクエストに使用するフィールド マスクを示します。

この情報をリクエストするには、 このフィールド マスクを使用
すべてのルートの詳細 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

注: transitFare は、API がすべてのステップで交通機関の運賃情報を特定できる場合にのみ指定します。

所要時間と距離のローカライズ済みテキスト routes.localizedValues

フィールド マスクの設定の詳細については、返されるフィールドを選択するをご覧ください。

交通機関のルートのパラメータを設定する

交通機関のルートに関連するパラメータは次のとおりです。

操作 このパラメータを使用する メモ
交通機関モードの選択 travelMode: "TRANSIT" 必須。詳細
到着時刻または出発時刻を設定する "arrivalTime": "yyyy-mm-ddThh:mm:ssZ"

または

"departureTime": "yyyy-mm-ddThh:mm:ssZ"
省略可。arrival_time または departure_time のいずれかを指定できます。どちらも指定されていない場合、departure_time はデフォルトで現在の実行時間(now)に設定されます。現在の実行時間(now)を基準として、次の時間枠内でのみ到着時刻と出発時刻を設定できます。
  • now の 7 日前まで
  • now から最大 100 日間
時刻は、RFC3339 UTC「Zulu」形式のタイムスタンプで表現されます。詳細
代替ルートを含める "computeAlternativeRoutes": true 省略可。true に設定すると、Routes API は利用可能な場合に最大 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
          }
        },
        {},
        {},
        {},
        {},
        {},
        {}
        ]
      }
    ]
  }
]
}