รับเส้นทางขนส่งสาธารณะ

นักพัฒนาซอฟต์แวร์ในเขตเศรษฐกิจยุโรป (EEA)

เส้นทางขนส่งมวลชนจะแสดงวิธีการนำทางโดยใช้ตัวเลือกขนส่งมวลชนที่มีให้บริการในภูมิภาค ตัวเลือกขนส่งสาธารณะอาจรวมถึงรถประจำทาง รถไฟใต้ดิน และรถไฟ เป็นต้น นอกจากนี้ เส้นทางขนส่งสาธารณะมักจะรวมวิธีการเดินไปยังสถานีขนส่งสาธารณะ จากสถานีขนส่งสาธารณะ และระหว่างสถานีขนส่งสาธารณะด้วย เนื่องจากเส้นทางขนส่งสาธารณะมักกำหนดให้คุณเดินทางโดยใช้รูปแบบการเดินทางมากกว่า 1 รูปแบบ วิธีการขอเส้นทางและบางส่วนของการตอบกลับจึงแตกต่างกัน

ความแตกต่างระหว่างเส้นทางขนส่งสาธารณะกับเส้นทางอื่นๆ

เส้นทางขนส่งสาธารณะซึ่งคุณขอโดยตั้งค่า travelMode เป็น TRANSIT จะแตกต่างจากเส้นทางที่ใช้ตัวเลือก travelMode อื่นๆ คุณไม่สามารถขอออบเจ็กต์และตัวเลือกทั้งหมดแบบเดียวกันได้ และการตอบกลับจะแสดงช่องที่แตกต่างกันเมื่อเทียบกับเส้นทางอื่นๆ

ใน Routes API ขั้นตอนต่างๆ จะเป็นวิธีการนำทาง 1 รายการในรูปแบบการเดินทางทุกประเภท ดังนั้นวิธีการนำทางแต่ละรายการจึงเป็น 1 ขั้นตอน การตอบกลับของเส้นทางขนส่งสาธารณะจะคล้ายกับเส้นทางที่มีรูปแบบการเดินทางอื่นๆ มาก โดยมีความแตกต่างที่สำคัญ 2-3 จุด ดังนี้

ความแตกต่างของคำขอ ความแตกต่างของการตอบกลับ
คุณไม่สามารถระบุจุดแวะพักระหว่างทางได้ รวมรายละเอียดการขนส่งสาธารณะ
ไม่สามารถรับเส้นทางที่เป็นมิตรต่อสิ่งแวดล้อม รวมข้อมูลเมตาสำหรับรูปแบบการเดินทางแต่ละรูปแบบที่มีข้อมูลสรุปของขั้นตอนสำหรับ รูปแบบการเดินทางนั้นๆ ใน `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) เป็นข้อมูลอ้างอิง
  • ไม่เกิน 7 วันก่อน now
  • ไม่เกิน 100 วันหลังจาก now
เวลาจะแสดงเป็นการประทับเวลาในรูปแบบ RFC3339 UTC "Zulu" ดูข้อมูลเพิ่มเติม

หมายเหตุ: กำหนดเวลาขนส่งสาธารณะมีการเปลี่ยนแปลงบ่อยครั้ง การเดินทางด้วยขนส่งสาธารณะที่มีให้บริการอาจ เปลี่ยนแปลงไปตามเวลา และเราไม่รับประกันว่าจะให้ผลลัพธ์ที่สอดคล้องกันสำหรับการคาดการณ์ล่วงหน้า

รวมเส้นทางอื่น "computeAlternativeRoutes": 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 สำหรับเส้นทาง 2 เส้นทาง

{
  "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
          }
        },
        {},
        {},
        {},
        {},
        {},
        {}
        ]
      }
    ]
  }
]
}