ทั้งเมธอด computeRoutes (REST) และ ComputeRoutes (gRPC) จะแสดงผลลัพธ์เป็นเส้นทางที่แสดงด้วยเส้นประกอบเป็นส่วนหนึ่งของการตอบกลับ API เหล่านี้จะแสดงผลเส้นประกอบ 2 ประเภท ได้แก่
เส้นประกอบพื้นฐาน (ค่าเริ่มต้น) แสดงเส้นทางแต่ไม่มีข้อมูลการจราจรที่ฝังอยู่ในเส้นประกอบ คำขอที่แสดงผลเส้นประกอบพื้นฐานจะเรียกเก็บเงินในอัตรา Routes Basic ดูข้อมูลเพิ่มเติมเกี่ยวกับ billing สำหรับ Routes API
เส้นประกอบที่คำนึงถึงการจราจร มีข้อมูลเกี่ยวกับสภาพการจราจรตลอดเส้นทาง สภาพการจราจรจะแสดงเป็นหมวดหมู่ความเร็ว (
NORMAL
,SLOW
,TRAFFIC_JAM
) ที่ใช้กับช่วงเวลาหนึ่งๆ ของเส้นประกอบ คำขอเส้นประกอบที่คำนึงถึงสภาพการจราจรจะเรียกเก็บเงินในอัตรา Routes Preferred ดูข้อมูลเพิ่มเติมเกี่ยวกับการเรียกเก็บเงินสำหรับ Routes API โปรดดูรายละเอียดที่หัวข้อกำหนดคุณภาพของเส้นประกอบ
ดูข้อมูลเพิ่มเติมเกี่ยวกับเส้นประกอบได้ที่
ยูทิลิตีโปรแกรมเข้ารหัสรูปหลายเหลี่ยมแบบอินเทอร์แอกทีฟช่วยให้คุณสร้างรูปหลายเหลี่ยมที่เข้ารหัสใน UI หรือถอดรหัสรูปหลายเหลี่ยมเพื่อแสดงบนแผนที่ได้ เช่น ใช้ยูทิลิตีนี้เพื่อถอดรหัสเส้นประกอบที่สร้างโดยโค้ดด้านล่าง
ขอเส้นประกอบพื้นฐานสำหรับเส้นทาง ช่วง หรือขั้นตอน
เส้นประกอบแสดงโดยออบเจ็กต์ Polyline (REST) หรือ Polyline (gRPC) คุณสามารถแสดงผลรูปหลายเหลี่ยมในการตอบกลับที่ระดับเส้นทาง ช่วง และขั้นตอน
ระบุเส้นประกอบที่จะแสดงผลโดยใช้มาสก์ฟิลด์คำตอบ ดังนี้
ที่ระดับเส้นทาง ให้แสดงผลรูปหลายเส้นในการตอบกลับโดยใส่
routes.polyline
ในมาสก์ช่องการตอบกลับที่ระดับเส้นทาง ให้แสดงผลรูปหลายเหลี่ยมในการตอบกลับสำหรับแต่ละเส้นทางโดยใส่
routes.legs.polyline
ที่ระดับขั้นตอน ให้แสดงผลรูปหลายเหลี่ยมในการตอบกลับสำหรับแต่ละขั้นตอนของขาโดยใส่
routes.legs.steps.polyline
ตัวอย่างเช่น หากต้องการแสดงผลเส้นประกอบสำหรับทั้งเส้นทาง สำหรับแต่ละช่วง และสำหรับแต่ละขั้นตอนของแต่ละช่วง ให้ทำดังนี้
curl -X POST -d '{ "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "travelMode": "DRIVE" }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.polyline,routes.legs.polyline,routes.legs.steps.polyline' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
คำขอนี้จะแสดงผลลัพธ์ต่อไปนี้ ซึ่งรวมถึงเส้นประกอบสำหรับเส้นทาง สำหรับแต่ละช่วงของเส้นทาง และสำหรับแต่ละขั้นตอนของช่วง
{ "routes": [ { "legs": [ { "polyline": { "encodedPolyline": "ipkcFfich...@Bs@?A?O?SD{A@o@B}@I?qA?_AA_@@_@?" } }, "steps": [ { "polyline": { "encodedPolyline": "kclcF...@sC@YIOKI" } }, { "polyline": { "encodedPolyline": "wblcF~...SZSF_@?" } }, ... ], "distanceMeters": 56901, "duration": "2420s", "polyline": { "encodedPolyline": "ipkcFfich...@Bs@?A?O?SD{A@o@B}@I?qA?_AA_@@_@?" } } ] }
เนื่องจากคำขอนี้มีต้นทางและปลายทางเท่านั้น เส้นทางที่แสดงจึงมีเพียงเที่ยวเดียว ดังนั้น เส้นประกอบของช่วงและของเส้นทางจึงเหมือนกัน
หากคุณเพิ่มจุดแวะพักกลางทางลงในคำขอ เส้นทางที่แสดงผลจะมี 2 ช่วง ดังนี้
curl -X POST -d '{ "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "intermediates": [ { "address": "450 Serra Mall, Stanford, CA 94305, USA"}, ], "travelMode": "DRIVE", }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.polyline,routes.legs.polyline' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
คําขอนี้จะแสดงผล 2 ช่วง โดยแต่ละช่วงจะมีเส้นประกอบที่ไม่ซ้ำกัน และเส้นประกอบสําหรับเส้นทางทั้งหมด
{ "routes": [ { "legs": [ { "polyline": { "encodedPolyline": "kclcFfqchV?A...?I@G?GAECCCEKICBAFG" } "steps": [ { "polyline": { "encodedPolyline": "kclcFfqch...YIOKI" } }, ... }, { "polyline": { "encodedPolyline": "ojmcFtethV?K...QOYQOGA?_@MUG[Ga@G" } "steps": [ { "polyline": { "encodedPolyline": "uypeFbo`jVgJq...PoBiC" } }, ... } ], "distanceMeters": 68403, "duration": "3759s", "polyline": { "encodedPolyline": "kclcFfqchV?A?CBKF[Ha...?GAECCCEKICBAFGJEBE" } } ] }
คุณภาพของเส้นประกอบ
คุณภาพของเส้นประกอบสามารถอธิบายได้ด้วยคำศัพท์ต่อไปนี้
ความแม่นยำของจุดลอยตัวของจุด
จุดจะระบุเป็นค่าละติจูดและลองจิจูด ซึ่งแสดงในรูปแบบทศนิยมแบบความแม่นยำเดี่ยว ซึ่งเหมาะกับค่าขนาดเล็ก (ซึ่งแสดงได้อย่างแม่นยำ) แต่ความแม่นยำจะลดลงเมื่อค่าเพิ่มขึ้นเนื่องจากข้อผิดพลาดในการปัดเศษทศนิยม
ในเมธอด computeRoutes (REST) และ ComputeRoutes การดำเนินการนี้จะควบคุมโดย
polylineEncoding
จํานวนจุดที่ประกอบกันเป็นเส้นประกอบ
ยิ่งมีจุดมากเท่าใด เส้นประกอบก็จะยิ่งเรียบเนียนมากขึ้นเท่านั้น (โดยเฉพาะในโค้ง)
ในเมธอด computeRoutes (REST) และ ComputeRoutes การดำเนินการนี้จะควบคุมโดย
polylineQuality
กำหนดค่าประเภทการเข้ารหัสเส้นประกอบ
ใช้ตัวเลือกคำขอ polylineEncoding
เพื่อควบคุมประเภทเส้นประกอบ
พร็อพเพอร์ตี้ polylineEncoding
จะควบคุมว่าจะเข้ารหัสเส้นประกอบเป็น ENCODED_POLYLINE
(ค่าเริ่มต้น) หรือไม่ ซึ่งหมายความว่าจะใช้รูปแบบอัลกอริทึมของเส้นประกอบที่เข้ารหัส หรือ GEO_JSON_LINESTRING
ซึ่งหมายความว่าจะใช้รูปแบบ LineString ของ GeoJSON
เช่น ในเนื้อหาคําขอ
curl -X POST -d '{ "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "travelMode": "DRIVE", "polylineEncoding": "ENCODED_POLYLINE" }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.polyline,routes.legs.polyline' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
กำหนดค่าคุณภาพของโพลีไลน์
polylineQuality
ระบุคุณภาพของเส้นประกอบเป็น HIGH_QUALITY
หรือ OVERVIEW
(ค่าเริ่มต้น) เมื่อใช้ OVERVIEW
ระบบจะประกอบรูปหลายเส้นโดยใช้จุดจํานวนน้อยและมีเวลาในการตอบสนองของคําขอต่ำกว่า HIGH_QUALITY
เช่น ในเนื้อหาคําขอ
{ "origin":{ "location":{ "latLng":{ "latitude": 37.419734, "longitude": -122.0827784 } } }, "destination":{ "location":{ "latLng":{ "latitude": 37.417670, "longitude": -122.079595 } } }, "travelMode": "DRIVE", "routingPreference": "TRAFFIC_AWARE", "polylineQuality": "HIGH_QUALITY", "polylineEncoding": "ENCODED_POLYLINE", "departureTime": "2023-10-15T15:01:23.045123456Z", ... }
ขอเส้นประกอบที่คำนึงถึงสภาพการจราจร
ตัวอย่างที่แสดงข้างต้นทั้งหมดจะแสดงผลเป็นเส้นประกอบพื้นฐาน ซึ่งก็คือเส้นประกอบที่ไม่มีข้อมูลการจราจร นอกจากนี้ คุณยังขอให้เส้นประกอบมีข้อมูลการจราจรสำหรับเส้นทางและแต่ละช่วงของเส้นทางได้ด้วย
เส้นประกอบที่คำนึงถึงสภาพการจราจรมีข้อมูลเกี่ยวกับสภาพการจราจรตลอดเส้นทาง สภาพการจราจรจะแสดงเป็นหมวดหมู่ความเร็ว (NORMAL
, SLOW
, TRAFFIC_JAM
) สำหรับช่วงเวลาหนึ่งๆ ของเส้นประกอบคำตอบ ช่วงเวลาจะกำหนดโดยดัชนีของจุดเริ่มต้น (รวม) และจุดสิ้นสุด (ไม่รวม) ของเส้นประกอบ
ตัวอย่างเช่น การตอบกลับต่อไปนี้แสดงNORMAL
การเข้าชมระหว่างจุด 2 และ 4 ของเส้นประกอบ
{ "startPolylinePointIndex": 2, "endPolylinePointIndex": 4, "speed": "NORMAL" }
หากต้องการส่งคําขอคํานวณเส้นประกอบที่คำนึงถึงสภาพการจราจร ให้ตั้งค่าพร็อพเพอร์ตี้ต่อไปนี้ในคําขอ
ตั้งค่าฟิลด์อาร์เรย์
extraComputations
เป็นTRAFFIC_ON_POLYLINE
เพื่อเปิดใช้การคำนวณการเข้าชมตั้งค่า
travelMode
เป็นDRIVE
หรือTWO_WHEELER
คำขอสำหรับรูปแบบการเดินทางอื่นๆ จะแสดงข้อผิดพลาดระบุค่ากำหนดการกำหนดเส้นทาง
TRAFFIC_AWARE
หรือTRAFFIC_AWARE_OPTIMAL
ในคำขอ โปรดดูข้อมูลเพิ่มเติมที่หัวข้อกำหนดค่าคุณภาพเทียบกับเวลาในการตอบสนองตั้งค่ามาสก์ฟิลด์คำตอบที่ระบุให้แสดงผลพร็อพเพอร์ตี้คำตอบ
ที่ระดับเส้นทาง ให้แสดงข้อมูลการเดินทางทั้งหมดในการตอบกลับโดยใส่
routes.travelAdvisory
ในมาสก์ช่องคำตอบ หากต้องการแสดงเฉพาะข้อมูลการจราจร ให้ระบุroutes.travelAdvisory.speedReadingIntervals
ที่ระดับช่วง ให้แสดงข้อมูลการเดินทางทั้งหมดในการตอบกลับสำหรับแต่ละช่วงของเส้นทางโดยใส่
routes.legs.travelAdvisory
หากต้องการแสดงเฉพาะข้อมูลการจราจร ให้ระบุroutes.legs.travelAdvisory.speedReadingIntervals
curl -X POST -d '{ "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "travelMode": "DRIVE", "extraComputations": ["TRAFFIC_ON_POLYLINE"], "routingPreference": "TRAFFIC_AWARE_OPTIMAL" }' \ -H 'Content-Type: application/json' \ -H 'X-Goog-Api-Key: YOUR_API_KEY' \ -H 'X-Goog-FieldMask: routes.duration,routes.distanceMeters,routes.polyline,routes.legs.polyline,routes.travelAdvisory,routes.legs.travelAdvisory' \ 'https://routes.googleapis.com/directions/v2:computeRoutes'
ตัวอย่างการตอบกลับสำหรับเส้นประกอบที่คำนึงถึงสภาพการจราจร
ในคำตอบ ข้อมูลการจราจรจะเข้ารหัสในเส้นประกอบและอยู่ในช่อง travelAdvisory
ของออบเจ็กต์ RouteLegTravelAdvisory (แต่ละช่วง) และออบเจ็กต์ RouteTravelAdvisory (เส้นทาง)
เช่น
{ "routes": [ { "legs": { "polyline": { "encodedPolyline": "}boeF~zbjVAg@EmB`GWHlD" }, // Traffic data for the leg. "travelAdvisory": { "speedReadingIntervals": [ { "endPolylinePointIndex": 1, "speed": "NORMAL" }, { "startPolylinePointIndex": 1, "endPolylinePointIndex": 2, "speed": "SLOW" }, { "startPolylinePointIndex": 2, "endPolylinePointIndex": 4, "speed": "NORMAL" } ] } }, "polyline": { "encodedPolyline": "}boeF~zbjVAg@EmB`GWHlD" }, // Traffic data for the route. "travelAdvisory": { "speedReadingIntervals": [ { "endPolylinePointIndex": 1, "speed": "NORMAL" }, { "startPolylinePointIndex": 1, "endPolylinePointIndex": 2, "speed": "SLOW" }, { "startPolylinePointIndex": 2, "endPolylinePointIndex": 4, "speed": "NORMAL" } ] } } ] }
ทั้ง RouteTravelAdvisory
และ RouteLegTravelAdvisory
มีฟิลด์อาร์เรย์ชื่อ speedReadingIntervals
ที่มีข้อมูลความเร็วของการจราจร ออบเจ็กต์แต่ละรายการในอาร์เรย์จะแสดงด้วยออบเจ็กต์ SpeedReadingInterval (REST) หรือ SpeedReadingInterval (gRPC)
ออบเจ็กต์ SpeedReadingInterval
มีข้อมูลความเร็วในการอ่านสำหรับช่วงเวลาของเส้นทาง เช่น NORMAL
, SLOW
หรือ TRAFFIC_JAM
อาร์เรย์ของออบเจ็กต์ทั้งหมดครอบคลุมรูปหลายเส้นทั้งหมดของเส้นทางโดยไม่ซ้อนทับกัน จุดเริ่มต้นของช่วงเวลาที่ระบุจะเหมือนกับจุดสิ้นสุดของช่วงเวลาก่อนหน้า
แต่ละช่วงเวลาจะอธิบายด้วย startPolylinePointIndex
,
endPolylinePointIndex
และหมวดหมู่ความเร็วที่เกี่ยวข้อง
โปรดทราบว่าการไม่มีดัชนีเริ่มต้นภายในช่วงเวลาจะสอดคล้องกับดัชนี 0 ตามแนวทางปฏิบัติของ proto3
ค่า startPolylinePointIndex
และ endPolylinePointIndex
ไม่จำเป็นต้องเรียงต่อกันเสมอไป เช่น
{ "startPolylinePointIndex": 2, "endPolylinePointIndex": 4, "speed": "NORMAL" }
ในกรณีนี้ สภาพการจราจรจากดัชนี 2 ถึงดัชนี 4 เหมือนกัน
แสดงผลเส้นประกอบที่คำนึงถึงสภาพการจราจรด้วย Maps SDK
เราขอแนะนำให้แสดงเส้นประกอบที่คำนึงถึงสภาพการจราจรบนแผนที่โดยใช้ฟีเจอร์ต่างๆ ที่ Google Maps SDK มีให้ เช่น การระบายสี เส้น และรูปแบบที่กำหนดเองตามแนวเส้นประกอบ ดูรายละเอียดเพิ่มเติมเกี่ยวกับการใช้เส้นประกอบได้ที่ฟีเจอร์เส้นประกอบสำหรับ Android และฟีเจอร์เส้นประกอบสำหรับ iOS
ตัวอย่างการแสดงผลโพลีไลน์
ผู้ใช้ Maps SDK สามารถกำหนดตรรกะการแมปที่กําหนดเองระหว่างหมวดหมู่ความเร็วกับสคีมาการแสดงผลเส้นประกอบ ตัวอย่างเช่น คุณอาจเลือกแสดงความเร็ว "ปกติ" เป็นเส้นหนาสีน้ำเงินบนแผนที่ ส่วนความเร็ว "ช้า" อาจแสดงเป็นเส้นหนาสีส้ม
ข้อมูลโค้ดต่อไปนี้จะเพิ่มเส้นประกอบสีน้ำเงินหนาที่มีส่วนของเส้น geodesic จากเมลเบิร์นไปยังเพิร์ท ดูข้อมูลเพิ่มเติมได้ที่การปรับแต่งลักษณะที่ปรากฏ (สําหรับ Android) และปรับแต่งเส้นประกอบ (สําหรับ iOS)
Android
Java
Polyline line = map.addPolyline(new PolylineOptions() .add(new LatLng(-37.81319, 144.96298), new LatLng(-31.95285, 115.85734)) .width(25) .color(Color.BLUE) .geodesic(true));
Kotlin
val line: Polyline = map.addPolyline( PolylineOptions() .add(LatLng(-37.81319, 144.96298), LatLng(-31.95285, 115.85734)) .width(25f) .color(Color.BLUE) .geodesic(true) )
iOS
Objective-C
GMSMutablePath *path = [GMSMutablePath path]; [path addLatitude:-37.81319 longitude:144.96298]; [path addLatitude:-31.95285 longitude:115.85734]; GMSPolyline *polyline = [GMSPolyline polylineWithPath:path]; polyline.strokeWidth = 10.f; polyline.strokeColor = .blue; polyline.geodesic = YES; polyline.map = mapView;
Swift
let path = GMSMutablePath() path.addLatitude(-37.81319, longitude: 144.96298) path.addLatitude(-31.95285, longitude: 115.85734) let polyline = GMSPolyline(path: path) polyline.strokeWidth = 10.0 polyline.geodesic = true polyline.map = mapView
ใช้เส้นประกอบที่เข้ารหัสกับการค้นหาบนเส้นทาง
ใช้การค้นหาข้อความของ Places API เพื่อค้นหาตามเส้นทางที่คำนวณไว้ คุณสามารถส่งเส้นประกอบที่เข้ารหัสของเส้นทางที่คำนวณไว้ล่วงหน้าจาก Routes API ไปยังคำขอการค้นหาข้อความ จากนั้นการตอบกลับจะมีสถานที่ที่ตรงกับเกณฑ์การค้นหาและอยู่ใกล้กับเส้นทางที่ระบุด้วย โปรดดูรายละเอียดที่หัวข้อค้นหาตามเส้นทาง
เช่น หากต้องการดูคาเฟ่ระหว่างเส้นทางจากต้นทางไปยังจุดหมาย ให้ทำดังนี้
Node.js
const API_KEY = 'YOUR_API_KEY'; const routes_service = 'https://routes.googleapis.com/directions/v2:computeRoutes'; const textSearch_service = 'https://places.googleapis.com/v1/places:searchText';function init(){ const routes_request = { "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "travelMode": "DRIVE" }; const textSearch_request = { "textQuery": "cafe", "searchAlongRouteParameters": { "polyline": { "encodedPolyline": "" } } }; fetchResources(routes_service,routes_request).then(routes => { textSearch_request.searchAlongRouteParameters.polyline.encodedPolyline = routes.routes[0].polyline.encodedPolyline; fetchResources(textSearch_service,textSearch_request).then(places => { console.log(places); }); }); } async function fetchResources(resource,reqBody){ const response = await fetch(resource, { method: 'POST', body: JSON.stringify(reqBody), headers: { 'Content-Type': 'application/json', 'X-Goog-Api-Key': API_KEY, 'X-Goog-FieldMask': '*' } }); const responseJSON = await response.json(); return responseJSON; } init();