查询公交路线

公交路线使用相应地区提供的公共交通选项提供导航指示。公交选项可能包括公交车、地铁和火车等。公交路线通常还包括有关步行前往公交站、往返公交站和在公交站之间步行的说明。由于公交路线通常需要您采用多种出行方式出行,因此您请求路线的方式与响应的某些部分会有所不同。

公交路线与其他路线的区别

公交路线(通过将 travelMode 设置为 Transit 来请求)不同于使用不同 travelMode 选项的路线。您不能请求所有相同的对象和选项,并且与其他路由相比,响应会返回不同的字段。

在 Routes API 中,所有出行方式中的路段始终是一条导航指令。因此每条导航指令都是一个步骤。公交路线响应与具有其他出行方式的路线响应非常相似,但存在一些主要区别:

请求差异 响应差异
您无法指定中间航点。 包含公交详细信息。
无法获取环保路线 包含每种出行方式的元数据,其中包含该出行方式的步骤摘要,具体位于“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

注意:仅当 API 可以确定所有路段的公交票价信息时,才需要提供 transitFare

时长和距离的本地化文本 routes.localizedValues

如需详细了解如何设置字段掩码,请参阅选择要返回的字段

设置公交路线的参数

以下是公交路线的相关参数:

操作步骤 使用此参数 备注
选择公交模式 travelMode: "TRANSIT" 必需。 了解详情
设置到达或出发时间 "arrivalTime": "yyyy-mm-ddThh:mm:ssZ"

"departureTime": "yyyy-mm-ddThh:mm:ssZ"
可选。您可以指定 arrival_time 或 flight_time。如果这两个时间均未指定,则 departure_time 默认为当前的执行时间 (now)。您可以仅在以下时间范围内设置到达时间和出发时间,并以当前执行时间 (now) 为参考:
  • now之前最多 7 天(含)
  • now后 100 天内(含)
时间表示为时间戳,采用 RFC3339 世界协调时间 (UTC)(即“祖鲁时”)格式。 了解详情
包括备选路线 "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'

响应会显示两个路由的 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
          }
        },
        {},
        {},
        {},
        {},
        {},
        {}
        ]
      }
    ]
  }
]
}