เส้นทางขนส่งมวลชนจะแสดงวิธีการนำทางโดยใช้ตัวเลือกขนส่งมวลชนที่มีให้บริการในภูมิภาค ตัวเลือกขนส่งสาธารณะอาจรวมถึงรถประจำทาง รถไฟใต้ดิน และรถไฟ เป็นต้น นอกจากนี้ เส้นทางขนส่งสาธารณะมักจะรวมวิธีการเดินไปยังสถานีขนส่งสาธารณะ จากสถานีขนส่งสาธารณะ และระหว่างสถานีขนส่งสาธารณะด้วย เนื่องจากเส้นทางขนส่งสาธารณะมักกำหนดให้คุณเดินทางโดยใช้รูปแบบการเดินทางมากกว่า 1 รูปแบบ วิธีการขอเส้นทางและบางส่วนของการตอบกลับจึงแตกต่างกัน
ความแตกต่างระหว่างเส้นทางขนส่งสาธารณะกับเส้นทางอื่นๆ
เส้นทางขนส่งสาธารณะซึ่งคุณขอโดยตั้งค่า travelMode เป็น TRANSIT จะแตกต่างจากเส้นทางที่ใช้ตัวเลือก travelMode อื่นๆ คุณไม่สามารถขอออบเจ็กต์และตัวเลือกทั้งหมดแบบเดียวกันได้ และการตอบกลับจะแสดงช่องที่แตกต่างกันเมื่อเทียบกับเส้นทางอื่นๆ
ใน Routes API ขั้นตอนต่างๆ จะเป็นวิธีการนำทาง 1 รายการในรูปแบบการเดินทางทุกประเภท ดังนั้นวิธีการนำทางแต่ละรายการจึงเป็น 1 ขั้นตอน การตอบกลับของเส้นทางขนส่งสาธารณะจะคล้ายกับเส้นทางที่มีรูปแบบการเดินทางอื่นๆ มาก โดยมีความแตกต่างที่สำคัญ 2-3 จุด ดังนี้
| ความแตกต่างของคำขอ | ความแตกต่างของการตอบกลับ |
|---|---|
| คุณไม่สามารถระบุจุดแวะพักระหว่างทางได้ | รวมรายละเอียดการขนส่งสาธารณะ |
| ไม่สามารถรับเส้นทางที่เป็นมิตรต่อสิ่งแวดล้อม | รวมข้อมูลเมตาสำหรับรูปแบบการเดินทางแต่ละรูปแบบที่มีข้อมูลสรุปของขั้นตอนสำหรับ รูปแบบการเดินทางนั้นๆ ใน `stepsOverview` (หากต้องการขอข้อมูลเมตานี้ ให้ใช้ ฟิลด์มาสก์ `routes.legs.stepsOverview`) |
| ไม่สามารถระบุวิธีและตำแหน่งที่จะรวมข้อมูลการจราจร | |
| ไม่สามารถระบุฟีเจอร์เส้นทางที่จะหลีกเลี่ยง | |
ระบุได้เฉพาะ transitPreferences สำหรับ
routingPreference. ดูรายละเอียดได้ที่
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 |
ไม่บังคับ ตั้งค่าเป็น "จริง" เพื่อให้ 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 } }, {}, {}, {}, {}, {}, {} ] } ] } ] }