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