เพิ่มประสิทธิภาพจุดอ้างอิงของเส้นทาง

การเพิ่มประสิทธิภาพจุดอ้างอิงเป็นฟีเจอร์ที่ต้องการของ Routes ซึ่งขยายฟังก์ชันการทำงานของ ComputeRoutes โดยจะเพิ่มประสิทธิภาพลำดับของจุดอ้างอิงระหว่างทางในเส้นทางของผู้เดินทาง เพื่อให้ผู้เดินทางเดินทางในเส้นทางที่มีประสิทธิภาพมากที่สุด การใช้งาน ComputeRoutes ของการเพิ่มประสิทธิภาพจุดอ้างอิงรองรับโหมดการเดินทางต่อไปนี้

  • ขับรถ
  • ขับรถจักรยานยนต์
  • การปั่นจักรยาน
  • เดินเท้า

เหตุใดจึงควรใช้การเพิ่มประสิทธิภาพจุดอ้างอิง

เมื่อสร้างแอปที่แนะนำผู้ใช้ผ่านจุดอ้างอิงหลายจุดระหว่างทางไปยังปลายทาง สิ่งสำคัญคือผู้เดินทางต้องผ่านจุดอ้างอิงตามลำดับที่เหมาะสม ซึ่งจะช่วยให้ผู้เดินทางไปถึงจุดอ้างอิงทุกจุดในเวลาที่สั้นที่สุด

วิธีการทำงาน

โดยค่าเริ่มต้น 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 ภายในออบเจ็กต์ routes ในเนื้อหาของการตอบกลับ โพลีไลน์ที่เข้ารหัสจะเหมือนกับใน 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 วินาที หากยังคงได้รับข้อผิดพลาดการหมดเวลา คุณสามารถเพิ่มเวลาอีก 1 วินาทีแล้วลองอีกครั้ง

ข้อจำกัดการใช้งาน

หากต้องการใช้การเพิ่มประสิทธิภาพจุดอ้างอิง คุณต้องปฏิบัติตามข้อจำกัดและเงื่อนไขการใช้งานต่อไปนี้

  • คุณระบุจุดอ้างอิงระหว่างทางในเส้นทางได้สูงสุดตามขีดจำกัดการใช้งานต่อไปนี้

    • จุดอ้างอิงสูงสุด 98 จุดโดยใช้พิกัดละติจูดและลองจิจูดเท่านั้น
    • จุดอ้างอิงสูงสุด 25 จุดหากคุณระบุจุดอ้างอิงโดยใช้รหัสสถานที่
  • จุดอ้างอิงทั้งหมดต้องเป็นประเภทแวะพัก จุดอ้างอิงทั้งหมดต้องไม่ใช่ประเภทผ่าน

  • คุณต้องเพิ่ม routes.optimizedIntermediateWaypointIndex ลงในฟิลด์มาสก์

  • หากคำขอมีจุดอ้างอิงระหว่างทางตั้งแต่ 25 จุดขึ้นไป คำขอดังกล่าวต้องเป็นไปตามเงื่อนไขต่อไปนี้ด้วย

    • ระยะทางเส้นตรงสะสมระหว่างจุดอ้างอิงทั้งหมดต้องน้อยกว่า 1,000 กม. ระยะทางนี้รวมทั้งต้นทางและปลายทาง

    • โหมดการเดินทางต้องเป็น DRIVE