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