रूट पॉलीलाइन के लिए अनुरोध करें

computeRoutes तरीका (REST) और ComputeRoutes तरीका (gRPC) दोनों ही पॉलीलाइन से दिखाए गए रूट को जवाब. ये एपीआई दो तरह की पॉलीलाइन दिखाते हैं:

  • बेसिक पॉलीलाइन (डिफ़ॉल्ट), रास्ते को दिखाता है, लेकिन ट्रैफ़िक के बिना पॉलीलाइन में एम्बेड की गई जानकारी. बेसिक पॉलीलाइन दिखाने वाले अनुरोध के लिए आपको रूट की बुनियादी दर के हिसाब से बिल भेजा जाता है. इसके बारे में ज़्यादा जानें बिलिंग को रूट करने का तरीका जानें.

  • ट्रैफ़िक के बारे में जानकारी देने वाली पॉलीलाइन, इसमें ट्रैफ़िक की स्थितियों के बारे में जानकारी होनी चाहिए ट्रैक किया जा सकता है. ट्रैफ़िक की स्थिति को गति के रूप में दिखाया जाता है कैटगरी (NORMAL, SLOW, TRAFFIC_JAM) किसी दिए गए इंटरवल पर लागू होती हैं का 3D मॉडल बनाया जा सकता है. ट्रैफ़िक के बारे में जानकारी देने वाली पॉलीलाइन के लिए किए गए अनुरोधों का बिल रास्तों की पसंदीदा दर. इसके लिए बिलिंग के बारे में ज़्यादा जानें रूट एपीआई. जानकारी के लिए, यह देखें पॉलीलाइन की क्वालिटी कॉन्फ़िगर करना

पॉलीलाइन के बारे में ज़्यादा जानकारी के लिए, इन्हें देखें:

रास्ते, पैर या सीढ़ी के लिए बेसिक पॉलीलाइन का अनुरोध करें

पॉलीलाइन को 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_@@_@?"
      }
    }
  ]
}

चूंकि इस अनुरोध में केवल एक उद्गम और एक गंतव्य है, इसलिए रास्ते में सिर्फ़ एक ही पैर है. इसलिए, पैर के लिए पॉलीलाइन और वाले रास्ते समान हैं.

अगर आप अनुरोध में एक इंटरमीडिएट वेपॉइंट जोड़ते हैं, तो रास्ते में दो पैर हैं:

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