ComputeRoutes পদ্ধতি (REST) এবং ComputeRoutes পদ্ধতি (gRPC) উভয়ই প্রতিক্রিয়ার অংশ হিসাবে একটি পলিলাইন দ্বারা উপস্থাপিত রুট ফিরিয়ে দেয়। এই APIগুলি দুটি ধরণের পলিলাইন প্রদান করে:
বেসিক পলিলাইন (ডিফল্ট) , একটি রুট উপস্থাপন করে কিন্তু পলিলাইনে এম্বেড করা ট্রাফিক তথ্য ছাড়াই। যে অনুরোধগুলি একটি মৌলিক পলিলাইন ফেরত দেয় সেগুলি রুট বেসিক হারে বিল করা হয়৷ রুট API-এর জন্য বিলিং সম্পর্কে আরও জানুন ।
ট্রাফিক-সচেতন পলিলাইন , রুট বরাবর ট্র্যাফিক অবস্থা সম্পর্কে তথ্য ধারণ করে। পলিলাইনের একটি প্রদত্ত ব্যবধানে প্রযোজ্য গতি বিভাগের (
NORMAL,SLOW,TRAFFIC_JAM) পরিপ্রেক্ষিতে ট্র্যাফিক পরিস্থিতি প্রকাশ করা হয়৷ ট্রাফিক-সচেতন পলিলাইনের জন্য অনুরোধ রুট পছন্দের হারে বিল করা হয়। রুট API-এর জন্য বিলিং সম্পর্কে আরও জানুন । বিস্তারিত জানার জন্য, পলিলাইন মান কনফিগার করুন দেখুন
পলিলাইন সম্পর্কে আরও জানতে, দেখুন:
ইন্টারেক্টিভ পলিলাইন এনকোডার ইউটিলিটি আপনাকে একটি UI-তে এনকোড করা পলিলাইন তৈরি করতে দেয় বা মানচিত্রে প্রদর্শন করতে পলিলাইন ডিকোড করতে দেয়। উদাহরণস্বরূপ, নীচের কোড দ্বারা তৈরি একটি পলিলাইন ডিকোড করতে এই ইউটিলিটিটি ব্যবহার করুন।
একটি রুট, পা বা ধাপের জন্য একটি মৌলিক পলিলাইন অনুরোধ করুন
একটি পলিলাইন একটি পলিলাইন (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_WHEELERএtravelModeসেট করুন। অন্য কোনো ভ্রমণ মোডের জন্য অনুরোধ একটি ত্রুটি ফেরত.অনুরোধে হয়
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();