公交路线会使用相应区域中可用的公共交通选项提供导航说明。公交选项可能包括公交车、地铁和火车等。公交路线通常还包括有关步行前往公交站、从公交站步行离开以及在公交站之间步行的说明。由于公交路线通常需要您使用多种出行方式,因此您请求路线的方式和响应的某些部分会有所不同。
公交路线与其他路线有何不同
您可以通过将 travelMode 设置为 TRANSIT 来请求公交路线,这种路线与使用其他 travelMode 选项的路线不同。您无法请求所有相同的对象和选项,并且与其他路由相比,响应会返回不同的字段。
在 Routes API 中,无论采用何种出行方式,步数始终是一条导航指令。因此,每条导航指令都是一个步骤。公交路线响应与其他出行方式的路线非常相似,但存在一些关键区别:
请求差异 | 回答差异 |
---|---|
您无法指定中间途经点。 | 包含 Transit 详细信息。 |
无法获取环保路线 | 包含每种出行方式的元数据,其中包含相应出行方式的步数摘要,位于 `stepsOverview` 中(如需请求此元数据,请使用 `routes.legs.stepsOverview` 字段遮盖)。 |
无法指定如何以及是否包含流量数据 | |
无法指定要避开的路线特征 | |
只能为 routingPreference 指定 transitPreferences 。如需了解详情,请参阅 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
注意:仅当 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 ) 为参考:
注意:公交时刻表会经常变化,可用的公交行程可能会随时间变化,并且无法保证提前很久做出的预测结果始终一致。 |
包含备选路线 | "computeAlternativeRoutes": true |
可选。设置为 true 可让 Compute Routes 计算最多 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 } }, {}, {}, {}, {}, {}, {} ] } ] } ] }