Bạn có thể tính toán khoảng cách và thời lượng của một tuyến đường cho nhiều điểm xuất phát và điểm đến bằng cách sử dụng phương thức ComputeRouteMatrix của Routes Preferred API. ComputeRouteMatrix hỗ trợ cả lệnh gọi gRPC truyền trực tuyến và lệnh gọi HTTP REST.
Với danh sách các cặp điểm xuất phát và điểm đến, ComputeRouteMatrix sẽ tính toán khoảng cách và thời lượng của một tuyến đường bắt đầu từ mỗi điểm xuất phát và kết thúc tại mỗi điểm đến. Mỗi phần tử của luồng tương ứng với thông tin cho một tuyến đường.
Phương thức ComputeRouteMatrix có một số ưu điểm so với Dịch vụ ma trận khoảng cách:
- Tính năng truyền trực tuyến cho phép trả về các phần tử trước khi tính toán toàn bộ ma trận, giúp giảm độ trễ.
ComputeRouteMatrixcó các lựa chọn chi tiết để tính toán lưu lượng truy cập, cho phép bạn đưa ra quyết định đánh đổi giữa chất lượng và độ trễ.- Các yêu cầu được chạy ở mức độ ưu tiên cao hơn trong cơ sở hạ tầng của Google, giúp tăng khả năng cung cấp.
- Bạn có thể chỉ định hướng (hướng di chuyển) và thông tin về phía đường cho các điểm tham chiếu.
- Bạn có thể yêu cầu trả về thông tin về phí cầu đường, cùng với khoảng cách tuyến đường và thời gian đến dự kiến.
Bật phương thức ComputeRouteMatrix
Trước khi có thể sử dụng phương thức ComputeRouteMatrix trong mã, bạn phải bật phương thức này. Để biết thêm thông tin về cách bật các phương thức của Routes Preferred API, hãy xem phần Bắt đầu.
Sử dụng phương thức ComputeRouteMatrix
Phương thức ComputeRouteMatrix có sẵn thông qua điểm cuối v1 của Routes Preferred.
Hãy xem tài liệu sau để biết thêm thông tin chi tiết:
Các bước chung sau đây mô tả cách sử dụng gRPC để gọi phương thức ComputeRouteMatrix:
Kiểm tra các bộ đệm giao thức cần thiết từ kho lưu trữ googleapis:
https://github.com/googleapis/googleapis/tree/master/google/maps/routes
Xin lưu ý rằng một số hệ thống xây dựng, chẳng hạn như Go, có thể tự động thực hiện việc này cho bạn.
Sử dụng ngôn ngữ và bộ công cụ xây dựng mà bạn ưu tiên để tạo mã bộ đệm giao thức có liên quan.
Tạo yêu cầu. Bạn phải gửi 2 phần siêu dữ liệu bắt buộc cùng với yêu cầu:
- Bạn phải đặt X-Goog-Api-Key thành khoá API.
Bạn phải đặt X-Goog-Fieldmask thành danh sách các trường được phân tách bằng dấu phẩy mà bạn yêu cầu từ phản hồi. Ví dụ: X-Goog-FieldMask: originIndex,destinationIndex,duration,distanceMeters,status. Bạn có thể sử dụng ký tự đại diện (*) để biểu thị tất cả các trường, nhưng không nên làm như vậy. Sử dụng ký tự đại diện để kiểm tra và hiểu phản hồi của API, nhưng hãy liệt kê rõ ràng các trường mà bạn muốn trong mặt nạ trường trong mã sản xuất.
Để biết thêm thông tin về cách tạo chuỗi mặt nạ trường, hãy xem https://github.com/protocolbuffers/protobuf/blob/master/src/google/protobuf/field_mask.proto. Xin lưu ý rằng việc tắt các trường mà bạn không cần có thể giảm độ trễ vì các trường đó có thể yêu cầu tính toán thêm. Độ trễ sẽ ổn định nếu bạn chỉ định các trường cần thiết và các trường mới yêu cầu tính toán thêm sẽ được thêm sau.
Gửi yêu cầu đến
routespreferred.googleapis.com:443.Bạn phải sử dụng giao thức TLS.
Để xem ví dụ về cách sử dụng phương thức ComputeRouteMatrix, hãy xem
Ví dụ về cách tính toán ma trận tuyến đường (Bản dùng thử).
Một tính năng đặc biệt của phương thức ComputeRouteMatrix là mã lỗi có thể được trả về cho toàn bộ luồng hoặc cho từng phần tử. Ví dụ: kết nối luồng trả về lỗi nếu yêu cầu bị định dạng sai (ví dụ: có 0 điểm xuất phát). Tuy nhiên, nếu lỗi chỉ áp dụng cho một vài phần tử của luồng (ví dụ: đặt Mã địa điểm không hợp lệ cho một điểm xuất phát), thì chỉ các phần tử bị ảnh hưởng bởi lỗi mới chứa mã lỗi.
Các phần tử do luồng trả về không được đảm bảo sẽ được trả về theo bất kỳ thứ tự nào. Do đó, mỗi phần tử chứa một origin_index và một destination_index. Đối với các điểm xuất phát và điểm đến do yêu cầu chỉ định, điểm xuất phát của tuyến đường tương đương với origins[origin_index] cho một phần tử nhất định và điểm đến của tuyến đường tương đương với destinations[destination_index]. Các mảng này được lập chỉ mục từ 0. Bạn cần lưu trữ thứ tự danh sách điểm xuất phát và điểm đến.
Tính phí cầu đường
Để biết thông tin về cách tính phí cầu đường, hãy xem Tính phí cầu đường.
Để xem ví dụ về cách tính phí cầu đường, hãy xem phần Ví dụ về cách tính toán ma trận tuyến đường.