রুট পলিলাইন অনুরোধ করুন

ComputeRoutes পদ্ধতি (REST) ​​এবং ComputeRoutes পদ্ধতি (gRPC) উভয়ই প্রতিক্রিয়ার অংশ হিসাবে একটি পলিলাইন দ্বারা উপস্থাপিত রুট ফিরিয়ে দেয়। এই APIগুলি দুটি ধরণের পলিলাইন প্রদান করে:

  • বেসিক পলিলাইন (ডিফল্ট) , একটি রুট উপস্থাপন করে কিন্তু পলিলাইনে এম্বেড করা ট্রাফিক তথ্য ছাড়াই। যে অনুরোধগুলি একটি মৌলিক পলিলাইন ফেরত দেয় সেগুলি রুট বেসিক হারে বিল করা হয়৷ রুট API-এর জন্য বিলিং সম্পর্কে আরও জানুন

  • ট্রাফিক-সচেতন পলিলাইন , রুট বরাবর ট্র্যাফিক অবস্থা সম্পর্কে তথ্য ধারণ করে। পলিলাইনের একটি প্রদত্ত ব্যবধানে প্রযোজ্য গতি বিভাগের ( NORMAL , SLOW , TRAFFIC_JAM ) পরিপ্রেক্ষিতে ট্র্যাফিক পরিস্থিতি প্রকাশ করা হয়৷ ট্রাফিক-সচেতন পলিলাইনের জন্য অনুরোধ রুট পছন্দের হারে বিল করা হয়। রুট 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 লাইনস্ট্রিং ফর্ম্যাট ব্যবহার করা হবে৷

উদাহরণস্বরূপ, অনুরোধের অংশে:

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 এ সেট করুন৷

  • DRIVE বা TWO_WHEELERtravelMode সেট করুন। অন্য কোনো ভ্রমণ মোডের জন্য অনুরোধ একটি ত্রুটি ফেরত.

  • অনুরোধে হয় 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 পর্যন্ত একই ছিল।

মানচিত্র SDK এর সাথে ট্রাফিক-সচেতন পলিলাইন রেন্ডার করুন

কাস্টম রঙ, স্ট্রোক এবং পলিলাইন স্ট্রেচ বরাবর প্যাটার্ন সহ Google মানচিত্র SDK-এর দেওয়া বিভিন্ন বৈশিষ্ট্যগুলি ব্যবহার করে আমরা মানচিত্রে ট্র্যাফিক সচেতন পলিলাইনগুলি প্রদর্শন করার সুপারিশ করি৷ পলিলাইন ব্যবহার সম্পর্কে আরও বিস্তারিত জানার জন্য, অ্যান্ড্রয়েডের জন্য পলিলাইন বৈশিষ্ট্য এবং iOS-এর জন্য পলিলাইন বৈশিষ্ট্যগুলি দেখুন৷

উদাহরণ পলিলাইন রেন্ডারিং

মানচিত্র SDK ব্যবহারকারীদের গতি বিভাগ এবং পলিলাইন রেন্ডারিং স্কিমাগুলির মধ্যে একটি কাস্টমাইজড ম্যাপিং যুক্তি সংজ্ঞায়িত করার সুযোগ রয়েছে৷ উদাহরণ স্বরূপ, কেউ মানচিত্রে "সাধারণ" গতি একটি ঘন নীল রেখা হিসাবে প্রদর্শন করার সিদ্ধান্ত নিতে পারে যখন "ধীর" গতি একটি ঘন কমলা রেখা হিসাবে প্রদর্শিত হতে পারে, উদাহরণস্বরূপ।

নিম্নলিখিত স্নিপেটগুলি মেলবোর্ন থেকে পার্থ পর্যন্ত জিওডেসিক অংশগুলির সাথে একটি ঘন নীল পলিলাইন যুক্ত করে। আরও তথ্যের জন্য, উপস্থিতি কাস্টমাইজ করা (অ্যান্ড্রয়েডের জন্য) এবং পলিলাইন কাস্টমাইজ করুন (iOS-এর জন্য) দেখুন।

অ্যান্ড্রয়েড

জাভা

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));

কোটলিন

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

উদ্দেশ্য-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;

সুইফট

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

সার্চ অ্যালং রুটের সাথে এনকোডেড পলিলাইন ব্যবহার করুন

একটি গণনা করা রুট বরাবর অনুসন্ধান করতে স্থান API পাঠ্য অনুসন্ধান ব্যবহার করুন৷ আপনি রুট এপিআই থেকে পাঠ্য অনুসন্ধান অনুরোধে একটি পূর্বনির্ধারিত রুটের এনকোডেড পলিলাইন পাস করেন। প্রতিক্রিয়া তারপরে অনুসন্ধানের মানদণ্ডের সাথে মেলে এবং নির্দিষ্ট রুটের কাছাকাছি অবস্থিত স্থানগুলিকে ধারণ করে৷ বিস্তারিত জানার জন্য, একটি রুট বরাবর অনুসন্ধান দেখুন।

উদাহরণস্বরূপ, উত্স এবং গন্তব্যের মধ্যে রুট বরাবর ক্যাফে ফেরত দিতে:

Node.js

const API_KEY = 'YOUR_API_KEY';
const routes_service = 'https://routes.googleapis.com/directions/v2:computeRoutes';
const textSearch_service = 'https://places.googleapis.com/v1/places:searchText';

function init(){ const routes_request = { "origin":{ "address": "1600 Amphitheatre Parkway, Mountain View, CA" }, "destination":{ "address": "24 Willie Mays Plaza, San Francisco, CA 94107" }, "travelMode": "DRIVE" }; const textSearch_request = { "textQuery": "cafe", "searchAlongRouteParameters": { "polyline": { "encodedPolyline": "" } } }; fetchResources(routes_service,routes_request).then(routes => { textSearch_request.searchAlongRouteParameters.polyline.encodedPolyline = routes.routes[0].polyline.encodedPolyline; fetchResources(textSearch_service,textSearch_request).then(places => { console.log(places); }); }); } async function fetchResources(resource,reqBody){ const response = await fetch(resource, { method: 'POST', body: JSON.stringify(reqBody), headers: { 'Content-Type': 'application/json', 'X-Goog-Api-Key': API_KEY, 'X-Goog-FieldMask': '*' } }); const responseJSON = await response.json(); return responseJSON; } init();