computeRoutes तरीका (REST) और ComputeRoutes तरीका (gRPC) दोनों ही पॉलीलाइन से दिखाए गए रूट को जवाब. ये एपीआई दो तरह की पॉलीलाइन दिखाते हैं:
बेसिक पॉलीलाइन (डिफ़ॉल्ट), रास्ते को दिखाता है, लेकिन ट्रैफ़िक के बिना पॉलीलाइन में एम्बेड की गई जानकारी. बेसिक पॉलीलाइन दिखाने वाले अनुरोध के लिए आपको रूट की बुनियादी दर के हिसाब से बिल भेजा जाता है. इसके बारे में ज़्यादा जानें बिलिंग को रूट करने का तरीका जानें.
ट्रैफ़िक के बारे में जानकारी देने वाली पॉलीलाइन, इसमें ट्रैफ़िक की स्थितियों के बारे में जानकारी होनी चाहिए ट्रैक किया जा सकता है. ट्रैफ़िक की स्थिति को गति के रूप में दिखाया जाता है कैटगरी (
NORMAL
,SLOW
,TRAFFIC_JAM
) किसी दिए गए इंटरवल पर लागू होती हैं का 3D मॉडल बनाया जा सकता है. ट्रैफ़िक के बारे में जानकारी देने वाली पॉलीलाइन के लिए किए गए अनुरोधों का बिल रास्तों की पसंदीदा दर. इसके लिए बिलिंग के बारे में ज़्यादा जानें रूट एपीआई. जानकारी के लिए, यह देखें पॉलीलाइन की क्वालिटी कॉन्फ़िगर करना
पॉलीलाइन के बारे में ज़्यादा जानकारी के लिए, इन्हें देखें:
इंटरैक्टिव पॉलीलाइन एन्कोडर यूटिलिटी यूज़र इंटरफ़ेस (यूआई) में कोड में बदली गई पॉलीलाइन बनाने या पॉलीलाइन को डिकोड करने की सुविधा देता है एक मैप. उदाहरण के लिए, इस उपयोगिता का इस्तेमाल करके, देखें.
रास्ते, पैर या सीढ़ी के लिए बेसिक पॉलीलाइन का अनुरोध करें
पॉलीलाइन को पॉलीलाइन (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_@@_@?" } } ] }
चूंकि इस अनुरोध में केवल एक उद्गम और एक गंतव्य है, इसलिए रास्ते में सिर्फ़ एक ही पैर है. इसलिए, पैर के लिए पॉलीलाइन और वाले रास्ते समान हैं.
अगर आप अनुरोध में एक इंटरमीडिएट वेपॉइंट जोड़ते हैं, तो रास्ते में दो पैर हैं:
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'
पॉलीलाइन की क्वालिटी कॉन्फ़िगर करें
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 के लिए Polyline सुविधाएं इस्तेमाल करें.
पॉलीलाइन रेंडरिंग का उदाहरण
Maps SDK टूल का इस्तेमाल करने वाले लोग, पसंद के मुताबिक मैपिंग तय कर सकते हैं स्पीड कैटगरी और पॉलीलाइन रेंडरिंग स्कीमा के बीच लॉजिक. इस तौर पर उदाहरण के लिए, कोई व्यक्ति "NORMAL" दिखाने का फ़ैसला ले सकता है जैसे कि चौड़ी नीले रंग की लाइन "धीमा" होने पर मैप उदाहरण के लिए, स्पीड को एक मोटी नारंगी रेखा के रूप में दिखाया जा सकता है.
नीचे दिए गए स्निपेट यहां से जियोडेसिक सेगमेंट के साथ मोटी नीली पॉलीलाइन जोड़ते हैं मेलबर्न से पर्थ. ज़्यादा जानकारी के लिए, यह देखें दिखने का तरीका अपनी पसंद के मुताबिक बनाना (Android के लिए) और 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