대중교통 경로는 해당 지역에서 이용 가능한 대중교통 옵션을 사용하여 내비게이션 안내를 제공합니다. 대중교통 옵션에는 버스, 지하철, 기차 등이 포함될 수 있습니다. 대중교통 경로에는 일반적으로 환승역을 오고 가는 경로 안내도 포함됩니다. 대중교통 경로는 일반적으로 두 가지 이상의 이동 수단을 사용하여 이동해야 하므로 경로를 요청하는 방법과 응답의 일부가 다릅니다.
대중교통 노선과 다른 노선의 차이점
travelMode를 TRANSIT으로 설정하여 요청하는 대중교통 경로는 다른 travelMode 옵션을 사용하는 경로와 다릅니다. 동일한 객체와 옵션을 모두 요청할 수는 없으며, 다른 경로와 비교할 때 응답은 다른 필드를 반환합니다.
Routes API에서 단계는 모든 유형의 이동에서 일관되게 하나의 탐색 안내입니다. 따라서 각 탐색 안내는 한 단계입니다. 대중교통 경로 응답은 다른 이동 수단을 사용하는 경로와 매우 유사하지만 몇 가지 주요 차이점이 있습니다.
요청 차이 | 응답 차이 |
---|---|
중간 경유지를 지정할 수 없습니다. | 대중교통 세부정보를 포함합니다. |
친환경 경로를 가져올 수 없음 | `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
참고: |
시간 및 거리에 관한 현지화된 텍스트 | 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 |
선택사항입니다. 가능한 경우 Routes API가 최대 3개의 경로를 추가로 계산하도록 true로 설정합니다. 자세히 알아보기 |
대중교통 유형에 대한 환경설정 지정 | "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 } }, {}, {}, {}, {}, {}, {} ] } ] } ] }