computeRoutes तरीके (REST) और ComputeRoutes तरीके (gRPC), दोनों ही रिस्पॉन्स के तौर पर, पॉलीलाइन से दिखाया गया रूट दिखाते हैं. ये एपीआई दो तरह की पॉलीलाइन दिखाते हैं:
बेसिक पॉलीलाइन (डिफ़ॉल्ट), रूट को दिखाती है, लेकिन पॉलीलाइन में ट्रैफ़िक की जानकारी एम्बेड नहीं की जाती. बेसिक पॉलीलाइन दिखाने वाले अनुरोधों की बिलिंग, रूट के लिए सामान्य दर के हिसाब से की जाती है. Routes API के लिए, बिलिंग के बारे में ज़्यादा जानें.
ट्रैफ़िक की जानकारी रखने वाली पॉलीलाइन में, रास्ते के आस-पास के ट्रैफ़िक की स्थिति की जानकारी होती है. ट्रैफ़िक की स्थितियों को स्पीड की कैटगरी (
NORMAL
,SLOW
,TRAFFIC_JAM
) के हिसाब से दिखाया जाता है. यह पॉलीलाइन के दिए गए इंटरवल पर लागू होता है. ट्रैफ़िक की जानकारी देने वाले पॉलीलाइन के अनुरोधों की बिलिंग, रूट की सुझाई गई दर पर की जाती है. Routes API की बिलिंग के बारे में ज़्यादा जानें. ज़्यादा जानकारी के लिए, पॉलीलाइन क्वालिटी कॉन्फ़िगर करें देखें
पॉलीलाइन के बारे में ज़्यादा जानकारी के लिए, देखें:
इंटरैक्टिव पॉलीलाइन एन्कोडर यूटिलिटी की मदद से, यूज़र इंटरफ़ेस (यूआई) में कोड में बदली गई पॉलीलाइन बनाई जा सकती हैं या मैप पर दिखाने के लिए पॉलीलाइन को डिकोड किया जा सकता है. उदाहरण के लिए, इस यूटिलिटी का इस्तेमाल नीचे दिए गए कोड से बनाई गई पॉलीलाइन को डिकोड करने के लिए करें.
किसी रास्ते, रास्ते या रास्ते के लिए सामान्य पॉलीलाइन का अनुरोध करें
पॉलीलाइन को पॉलीलाइन (REST) या पॉलीलाइन (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_@@_@?" } } ] }
इस अनुरोध में सिर्फ़ शुरुआत की जगह और मंज़िल शामिल है, इसलिए लौटाए गए रास्ते में सिर्फ़ एक लेग है. इसलिए, पैर और रास्ते के लिए पॉलीलाइन एक ही है.
अगर अनुरोध में बीच का वेपॉइंट जोड़ा जाता है, तो दिखाए गए रास्ते में दो चरण होंगे:
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'
यह अनुरोध पूरे रास्ते के लिए दो पैरों को दिखाता है, जिनमें से हर एक में एक खास पॉलीलाइन और एक पॉलीलाइन होती है:
{ "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
का मतलब है कि
GeoJSON LineString फ़ॉर्मैट
का इस्तेमाल किया जाएगा.
उदाहरण के लिए, अनुरोध के मुख्य हिस्से में:
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'
Poyline क्वालिटी कॉन्फ़िगर करें
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
) के हिसाब से दिखाया जाता है. इंटरवल, उनके शुरुआती (शामिल) और आखिरी (खास) पॉलीलाइन पॉइंट के इंडेक्स से तय होते हैं.
उदाहरण के लिए, नीचे दिए गए रिस्पॉन्स में, पॉलीलाइन पॉइंट 2 और 4 के बीच के NORMAL
ट्रैफ़िक को दिखाया गया है:
{ "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'
ट्रैफ़िक की जानकारी देने वाले पॉलीलाइन के लिए रिस्पॉन्स का उदाहरण
रिस्पॉन्स में, ट्रैफ़िक डेटा को पॉलीलाइन में एन्कोड किया जाता है और
RouteLegTravelAdvisory
ऑब्जेक्ट (हर लेग) और
RouteTravelAdvisory ऑब्जेक्ट (रूट) टाइप के travelAdvisory
फ़ील्ड में शामिल किया जाता है.
उदाहरण के लिए:
{ "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
, और स्पीड की कैटगरी से दी जाती है.
ध्यान दें कि इंटरवल में शुरुआती इंडेक्स की कमी, proto3 तरीकों के हिसाब से इंडेक्स 0 से मेल खाती है.
startPolylinePointIndex
और endPolylinePointIndex
वैल्यू, हमेशा क्रम में नहीं होती हैं. उदाहरण के लिए:
{ "startPolylinePointIndex": 2, "endPolylinePointIndex": 4, "speed": "NORMAL" }
इस मामले में, इंडेक्स 2 से इंडेक्स 4 तक, ट्रैफ़िक की शर्तें एक जैसी थीं.
Maps SDK टूल की मदद से, ट्रैफ़िक की जानकारी देने वाली पॉलीलाइन रेंडर करें
हमारी सलाह है कि आप Google Maps SDK टूल की कई सुविधाओं का इस्तेमाल करके, मैप पर ट्रैफ़िक की जानकारी देने वाले पॉलीलाइन दिखाएं. इनमें, पसंद के मुताबिक रंग, स्ट्रोक, और पॉलीलाइन स्ट्रेच के साथ पैटर्न वाले पैटर्न शामिल हैं. पॉलीलाइन इस्तेमाल करने के बारे में ज़्यादा जानने के लिए, Android के लिए पॉलीलाइन की सुविधाएं और iOS के लिए पॉलीलाइन की सुविधाएं देखें.
पॉलीलाइन रेंडरिंग का उदाहरण
Maps SDK टूल का इस्तेमाल करने वाले लोगों के पास, स्पीड कैटगरी और पॉलीलाइन रेंडरिंग स्कीमा के बीच, पसंद के मुताबिक मैपिंग लॉजिक तय करने का विकल्प होता है. उदाहरण के तौर पर, कोई व्यक्ति मैप पर "NORMAL" स्पीड को मोटी नीली लाइन के तौर पर दिखा सकता है, जबकि "धीमी" स्पीड को मोटी नारंगी लाइन के तौर पर दिखा सकता है.
नीचे दिए गए स्निपेट में, मेलबर्न से पर्थ तक के जियोडेसिक सेगमेंट के साथ मोटी नीली पॉलीलाइन जोड़ी गई है. ज़्यादा जानकारी के लिए, ये लेख पढ़ें: थीम को पसंद के मुताबिक बनाना (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