대중교통 경로 확인

유럽 경제 지역 (EEA) 개발자

대중교통 경로는 해당 지역에서 이용할 수 있는 대중교통 옵션을 사용하여 내비게이션 안내를 제공합니다. 대중교통 옵션에는 버스, 지하철, 기차 등이 포함될 수 있습니다. 대중교통 경로에는 일반적으로 대중교통 정류장으로 이동하거나 대중교통 정류장에서 이동하거나 대중교통 정류장 간 이동하는 방법에 관한 안내도 포함됩니다. 대중교통 경로는 일반적으로 두 가지 이상의 이동 수단을 사용하여 이동해야 하므로 경로를 요청하는 방법과 응답의 일부가 다릅니다.

대중교통 경로가 다른 경로와 다른 점

travelMode를 TRANSIT로 설정하여 요청하는 대중교통 경로는 다른 travelMode 옵션을 사용하는 경로와 다릅니다. 다른 경로와 비교할 때 동일한 객체와 옵션을 모두 요청할 수 없으며 응답에서 다른 필드를 반환합니다.

Routes API에서 단계는 모든 유형의 이동에서 일관되게 하나의 내비게이션 안내입니다. 따라서 각 내비게이션 안내는 단계입니다. 대중교통 경로 응답은 몇 가지 주요 차이점을 제외하고 다른 이동 수단의 경로와 매우 유사합니다.

요청 차이점 응답 차이점
중간 경유지를 지정할 수 없습니다. 대중교통 세부정보가 포함됩니다.
친환경 경로를 가져올 수 없음 해당 이동 수단의 단계 요약이 포함된 각 이동 수단의 메타데이터가 `stepsOverview`에 포함됩니다 (이 메타데이터를 요청하려면 `routes.legs.stepsOverview` 필드 마스크를 사용).
트래픽 데이터를 포함하는 방법과 포함 여부를 지정할 수 없음
피할 경로 기능을 지정할 수 없음
transitPreferences만 지정할 수 있습니다routingPreference. 자세한 내용은 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 선택사항입니다. 이동 경로 계산에서 최대 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
          }
        },
        {},
        {},
        {},
        {},
        {},
        {}
        ]
      }
    ]
  }
]
}