Theo mặc định, phương thức Compute Routes
của Routes API tính toán một tuyến đường qua nhiều điểm dừng, được gọi là điểm dừng, theo thứ tự mà bạn cung cấp các điểm dừng đó.
Bạn có thể giúp API Tuyến đường tối ưu hoá tuyến đường được cung cấp bằng cách sắp xếp lại các điểm dừng theo thứ tự hiệu quả hơn. Tính năng tối ưu hoá điểm tham chiếu sẽ tối ưu hoá thời gian di chuyển, nhưng cũng xem xét các yếu tố khác như khoảng cách và số vòng khi quyết định tuyến đường nào hiệu quả nhất.
Để tối ưu hoá điểm tham chiếu
Hãy đảm bảo không có điểm tham chiếu nào trong tuyến đường có
via
được đặt thànhtrue
, ví dụ:{"address": "Clare,SA", "via": true}
. Để biết thêm thông tin về điểm tham chiếu trung gian, hãy xem phần Chỉ định điểm tham chiếu trung gian.Hãy đảm bảo rằng
routing_preference
không được đặt thànhTRAFFIC_AWARE_OPTIMAL
.Đặt
optimize_waypoint_order
thànhtrue
. Ví dụ:"optimizeWaypointOrder": "true",
Chỉ định trường
routes.optimizedIntermediateWaypointIndex
trong mặt nạ trường:Kiến trúc chuyển trạng thái đại diện (REST)
-H X-Goog-FieldMask: routes.optimizedIntermediateWaypointIndex
RPC
const (fieldMask = "routes.optimizedIntermediateWaypointIndex")
Tìm hiểu cách tối ưu hoá thứ tự điểm tham chiếu
Dưới đây là cách API Tuyến đường tối ưu hoá thứ tự của các điểm tham chiếu trong một tuyến đường:
Tự động lập chỉ mục điểm tham chiếu dựa trên thứ tự bạn cung cấp chúng trong yêu cầu, bắt đầu bằng 0.
Tối ưu hoá thứ tự của các điểm tham chiếu bằng cách sử dụng số chỉ mục được chỉ định cho các điểm tham chiếu trong yêu cầu.
Trả về thứ tự điểm tham chiếu được tối ưu hoá trong đối tượng
routes
, thuộc trườngwaypoint_order
dướiroutes.optimizedIntermediateWaypointIndex
.
Ví dụ:
Yêu cầu này yêu cầu tối ưu hoá một tuyến đường từ Adelaide (Nam Úc) đến từng vùng sản xuất rượu vang chính của Nam Úc, sau đó quay trở lại Adelaide.
curl -X POST -H 'content-type: application/json' -d ' { "origin": { "address": "Adelaide,SA" }, "destination": { "address": "Adelaide,SA" }, "intermediates": [ {"address": "Barossa+Valley,SA"}, {"address": "Clare,SA"}, {"address": "Connawarra,SA"}, {"address": "McLaren+Vale,SA"} ], "travelMode": "DRIVE", "optimizeWaypointOrder": "true" }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.optimizedIntermediateWaypointIndex' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
API Tuyến lập chỉ mục các điểm tham chiếu trung gian được cung cấp trong yêu cầu, bắt đầu từ 0. Ví dụ:
0 {"address": "Barossa+Valley,SA"}, 1 {"address": "Clare,SA"}, 2 {"address": "Connawarra,SA"}, 3 {"address": "McLaren+Vale,SA"}
Khi sử dụng số chỉ mục cho 4 điểm tham chiếu được cung cấp trong yêu cầu, dịch vụ sẽ trả về thứ tự được tối ưu hoá:
"optimizedIntermediateWaypointIndex": [ 3, 2, 0, 1 ]