การเพิ่มประสิทธิภาพ Waypoint เป็นฟีเจอร์ "เส้นทางที่ต้องการ" ที่ขยายการให้บริการ ComputeRoutes
ช่วยเพิ่มประสิทธิภาพให้ลำดับของจุดอ้างอิงระดับกลางในเส้นทางของผู้เดินทาง เพื่อให้มั่นใจได้ว่าการเดินทางเป็นเส้นทางที่มีประสิทธิภาพที่สุดเท่าที่จะเป็นไปได้ การใช้งานการเพิ่มประสิทธิภาพจุดอ้างอิง ComputeRoutes
รองรับโหมดการเดินทางต่อไปนี้
- รถ
- มอเตอร์ 2 ล้อ
- ปั่นจักรยาน
- เดินเท้า
เหตุใดจึงควรใช้การเพิ่มประสิทธิภาพจุดอ้างอิง
เมื่อสร้างแอปที่นำทางผู้ใช้ผ่านจุดอ้างอิงจำนวนมากระหว่างทางไปยังจุดหมายหนึ่งๆ ผู้เดินทางจะต้องข้ามจุดอ้างอิงตามจุดอ้างอิงในลำดับที่เหมาะสมที่สุด วิธีนี้ช่วยให้มั่นใจได้ว่าผู้เดินทางจะไปถึงจุดอ้างอิงทุกจุดในเวลาที่สั้นที่สุด
วิธีการทำงาน
โดยค่าเริ่มต้น ComputeRoutes
จะคำนวณเส้นทางผ่านจุดอ้างอิงตามลำดับเวลาที่ให้มา คุณสามารถรับ ComputeRoutes
เพื่อเพิ่มประสิทธิภาพเส้นทางได้โดยจัดเรียงจุดอ้างอิงระดับกลางใหม่เป็นลำดับที่มีประสิทธิภาพมากขึ้น
คุณจะได้รับเส้นทางที่มีจุดอ้างอิงที่มีการเพิ่มประสิทธิภาพ หากคุณตั้งค่าช่อง optimizeWaypointOrder
ในเนื้อหาคำขอเป็น true
หมายเหตุ: การคํานวณการเพิ่มประสิทธิภาพการชี้ทางนั้นอิงตามเวลาเดินทางเป็นหลัก แต่ฟีเจอร์นี้จะพิจารณาปัจจัยอื่นๆ ด้วย เช่น ระยะทางและจํานวนเลี้ยว
รับจุดอ้างอิงที่เรียงลำดับใหม่
หากต้องการรับเส้นทางที่มีจุดอ้างอิงที่เรียงลำดับใหม่ ให้ตั้งค่าช่องบูลีน optimizeWaypointOrder
เป็น true
ในส่วนเนื้อหาของคำขอเป็น ComputeRoutes
และใส่ช่อง optimizedIntermediateWaypointIndex
ในมาสก์ของช่องด้วย เนื้อหาการตอบกลับมีลำดับจุดอ้างอิงที่เพิ่มประสิทธิภาพไว้ในช่อง optimizedIntermediateWaypointIndex
หมายเหตุ: ช่อง optimizedIntermediateWaypointIndex
จะแสดงค่าฐาน 0
ตัวอย่างคำขอ
ตัวอย่างต่อไปนี้เป็นคำขอเส้นทางใกล้กับวิทยาเขตของมหาวิทยาลัยสแตนฟอร์ด มีการระบุจุดอ้างอิงของเส้นทางตามลำดับในคำขอ คำขอมีต้นทางและปลายทาง พร้อมจุดระหว่างกลาง 2 จุด
POST /v1alpha:computeRoutes
Host: routespreferred.googleapis.com
Content-Type: application/json
X-Server-Timeout: 10
X-Goog-Api-Key: YOUR_API_KEY
X-Goog-FieldMask: routes.optimizedIntermediateWaypointIndex,routes.duration,routes.distanceMeters,routes.polyline.encodedPolyline
{
"origin":{
"location":{
"latLng":{
"latitude": 37.418956,
"longitude": -122.160815
}
}
},
"intermediates": [
{
"location":{
"latLng":{
"latitude": 37.4176423,
"longitude":-122.1102246
}
}
},
{
"location":{
"latLng":{
"latitude": 37.407689,
"longitude": -122.1360597
}
}
}
],
"destination":{
"location":{
"latLng":{
"latitude": 37.4032137,
"longitude": -122.0349119
}
}
},
"travelMode": "DRIVE",
"optimizeWaypointOrder": true,
"routingPreference": "TRAFFIC_AWARE"}
ตัวอย่างการตอบกลับ
คุณดูดัชนีจุดอ้างอิงระหว่างกลางที่จัดเรียงใหม่ได้ในช่อง optimizedIntermediateWaypointIndex
ภายในออบเจ็กต์เส้นทางในเนื้อหาคำตอบ โพลีไลน์ที่เข้ารหัสจะเหมือนกับใน Directions API และ ComputeRoutes
routes {
distance_meters: 17647
duration {
seconds: 1866
}
polyline {
encoded_polyline: "wkkcFvorhVU{@Ec@C}CG}@Mm@[}@i@y@[[g@_@Tk@BSjCgGfF|D\\Pv@Lj@@XaCTeC\\aCTs@`ByD`@k@h@e@x@Yh@GtADhBF|@G`AWpAs@lAsAdA{A`BmDr@cBmUqQoS}OyGmFiBsAgEwD}CaCU_@Og@@e@Hy@nGkO~@sBr@cBlDqIlByEp@}AjIfGnBbBHLLd@^p@~ErDfNrKrA~@DIhEeBTQ~AqDlE{KjBgE|FnEh@aAi@`A}FoE~AmD`A}BcAm@mHwFwD}CkLwIsDqCgF_EG[GKnCsDrA_BrC_CnCoBpEkD`EyClCsBcBeBIAkGkH]k@eJmKQKsAuA_@g@wCoDGQmEmFmIqROKaDuHvBkBxAgANCRH^f@v@dBHDD?`AUiBqEhBpEaATMCQYm@wAY]SIOByAfAwBjB_ByDaAwBiCeIA[c@aBqEuNOm@IQbA{c@p@aZFmCTuBLg@Tc@BUAKxOeV~Vy_@nBoDv@_BvAcDzA_EdG{RdC{HtIsY|B{Hx@mDbAuFdBsMbKsv@TaBf@}AdF{Sn@_DJq@Lo@aE`@]GUQmAmAQk@@g@RK`Ce@d@UDEPc@f@cCrAyGJs@X{AbIem@bA{JD_AIaAMg@o@{A_Ad@y@NaCLCsCK_FGI"
}
optimizedIntermediateWaypointIndex: 1
optimizedIntermediateWaypointIndex: 0
}
ในตัวอย่างนี้ จะสังเกตเห็นว่าการเพิ่มประสิทธิภาพจุดอ้างอิงย้อนกลับลำดับเดิม
แนวทางปฏิบัติที่แนะนำ
คำขอที่มีจุดอ้างอิงที่เพิ่มประสิทธิภาพแล้วจะใช้เวลาประมวลผลนานกว่าคำขอการกำหนดเส้นทางแบบง่าย เราจึงขอแนะนำให้คุณตั้งค่าระยะหมดเวลาในการเรียกใช้เมธอดให้สูงขึ้นโดยตั้งค่าส่วนหัวของคำขอ X-Server-Timeout
อย่างน้อย 10 วินาที หากยังคงได้รับข้อผิดพลาดการหมดเวลา คุณสามารถเพิ่มอีกวินาทีแล้วลองอีกครั้งได้
ข้อจำกัดการใช้งาน
หากต้องการใช้การเพิ่มประสิทธิภาพจุดอ้างอิง คุณต้องทำตามข้อจำกัดและเงื่อนไขการใช้งานต่อไปนี้
คุณสามารถระบุขีดจำกัดการใช้งานสูงสุดสำหรับจุดอ้างอิงระดับกลางบนเส้นทางของคุณ ดังนี้
- จุดอ้างอิงสูงสุด 98 จุดโดยใช้เพียงพิกัดละติจูดและลองจิจูดเท่านั้น
- จุดอ้างอิงสูงสุด 25 จุดหากคุณระบุจุดอ้างอิงโดยใช้รหัสสถานที่
จุดอ้างอิงทั้งหมดของคุณต้องเป็นประเภทแวะพัก ไม่มีจุดอ้างอิงที่เป็นประเภทผ่านเลย
คุณต้องเพิ่ม
routes.optimizedIntermediateWaypointIndex
ลงในมาสก์หากคำขอมีจุดอ้างอิงระดับกลาง 25 จุดขึ้นไป คำขอนั้นต้องเป็นไปตามเงื่อนไขต่อไปนี้ด้วย
ระยะทางของเส้นตรงสะสมระหว่างจุดอ้างอิงทั้งหมดต้องน้อยกว่า 1,000 กม. โดยระยะทางนี้รวมทั้งต้นทางและจุดหมาย
โหมดการเดินทางต้องเป็นไดรฟ์