বিমানবন্দরগুলি বড়, মাল্টি-টার্মিনাল কমপ্লেক্স এবং যথাসময়ে আগমন এবং প্রস্থানের জন্য সুনির্দিষ্ট নেভিগেশন গুরুত্বপূর্ণ। Google মানচিত্র জিওকোডিং API সাধারণত একটি স্থানাঙ্ক (অক্ষাংশ/দ্রাঘিমাংশ) ফেরত দেয় যা বেশিরভাগ ক্ষেত্রে বড় বিমানবন্দর কমপ্লেক্সের কেন্দ্রস্থল হবে। এই অ্যাপটি একটি ইন্টারেক্টিভ টুল যা ব্যবহারকারীদেরকে নির্দিষ্ট টার্মিনাল বা বিমানবন্দরের মধ্যে পিকআপ/ড্রপ-অফ পয়েন্টের মতো একটি বৃহত্তর জটিল স্থানের মধ্যে সুনির্দিষ্ট অবস্থানগুলি চিহ্নিত করতে এবং কল্পনা করতে সহায়তা করার জন্য বিশেষভাবে ডিজাইন করা হয়েছে।
এটি কীভাবে এটি অর্জন করে তা এখানে:
এয়ারপোর্ট/ভেন্যু সার্চ : ব্যবহারকারীরা Google Places স্বয়ংসম্পূর্ণ ইনপুট ব্যবহার করে একটি প্রধান অবস্থান (যেমন, "ইন্দিরা গান্ধী আন্তর্জাতিক বিমানবন্দর") অনুসন্ধান করে শুরু করে, যা ভারতে সীমাবদ্ধ।
উপ-অবস্থান আবিষ্কার : একবার একটি প্রাথমিক অবস্থান নির্বাচন করা হলে, স্ক্রিপ্টটি বিশদ আনার জন্য Google Places API ব্যবহার করে, গুরুত্বপূর্ণভাবে সেই স্থানের সাথে সম্পর্কিত যে কোনও তালিকাভুক্ত "সাব-গন্তব্যগুলি" অন্তর্ভুক্ত করে (যেমন টার্মিনাল 1, টার্মিনাল 3, নির্দিষ্ট গেট, ইত্যাদি, যদি Google-এর ডেটাতে পাওয়া যায়)।
ভিজ্যুয়াল ম্যাপিং : স্ক্রিপ্টটি জিওকোডিং API ব্যবহার করে প্রধান অবস্থান এবং এর উপ-গন্তব্যগুলির স্থানাঙ্কগুলি খুঁজে বের করতে।
তারপরে এটি প্রধান অবস্থান প্রদর্শন করে এবং প্রতিটি চিহ্নিত উপ-গন্তব্যের জন্য মানচিত্রে আলাদা, ক্লিকযোগ্য মার্কার (নীল বৃত্ত) রাখে।
সুনির্দিষ্ট শনাক্তকরণ : একটি সাব-গন্তব্য চিহ্নিতকারীতে ক্লিক করা এটিকে হাইলাইট করে (সবুজ হয়ে যায়) এবং একটি ইনফোউইন্ডো খোলে যার নাম এবং অন্যান্য উপলব্ধ বিবরণ (যেমন ঠিকানা বা প্রকার) দেখায়, ব্যবহারকারীকে নিশ্চিত করতে দেয় যে তারা সঠিক নির্দিষ্ট বিন্দু নির্বাচন করেছে। প্রাসঙ্গিক দৃশ্য : মানচিত্রটি স্বয়ংক্রিয়ভাবে তার দৃশ্য ( fitBounds
) সামঞ্জস্য করে যাতে সমস্ত প্রাসঙ্গিক মার্কার (প্রধান অবস্থান + উপ-গন্তব্যগুলি) স্পষ্টভাবে দৃশ্যমান হয় তা যাচাই করে।
বিমানবন্দর নেভিগেশন অ্যাপে Google মানচিত্র প্ল্যাটফর্ম APIs
এই নথিটি প্রদত্ত "বিমানবন্দরে নেভিগেট" ডেমো অ্যাপ্লিকেশনে ব্যবহৃত মূল Google Maps প্ল্যাটফর্ম API এবং তাদের পরামিতিগুলি ব্যাখ্যা করে৷ অ্যাপটি মানচিত্র প্রদর্শন, স্থান অনুসন্ধান, স্থানের বিস্তারিত তথ্য এবং উন্নত অবস্থানের অন্তর্দৃষ্টি প্রদানের জন্য বিভিন্ন পরিষেবার সুবিধা দেয়।
1. মানচিত্র সূচনা এবং প্রদর্শন
অ্যাপ্লিকেশনের ভিত্তি হল ইন্টারেক্টিভ মানচিত্র নিজেই।
- API ব্যবহার করা হয়েছে:
google.maps.Map
(Maps JavaScript API থেকে) - উদ্দেশ্য: ওয়েবপেজে ইন্টারেক্টিভ ম্যাপ তৈরি এবং প্রদর্শন করা।
- মূল পরামিতি:
-
center
: মানচিত্রের প্রাথমিক ভৌগলিক কেন্দ্র সংজ্ঞায়িত করে। এই অ্যাপে, এটি প্রাথমিকভাবে দিল্লির স্থানাঙ্কে সেট করা হয়েছে ({ lat: 28.461835685621395, lng: 77.05004035761647 }
)। -
zoom
: মানচিত্রের প্রাথমিক জুম স্তর সেট করে।DEFAULT_ZOOM_LEVEL
(15) একটি ক্লোজ-আপ দেখার জন্য ব্যবহার করা হয়। -
mapId
: Google ক্লাউড কনসোলে কনফিগার করা মানচিত্রের শৈলীর জন্য একটি অনন্য শনাক্তকারী৷
-
2. স্থান অনুসন্ধান এবং স্বয়ংসম্পূর্ণ
অনুসন্ধান বার কার্যকারিতা স্থান API দ্বারা চালিত হয়.
- API ব্যবহার করা হয়েছে:
google.maps.places.Autocomplete
(Maps JavaScript API-এর স্থান লাইব্রেরি থেকে) - উদ্দেশ্য: ভৌগলিক অনুসন্ধানের জন্য ভবিষ্যদ্বাণীপূর্ণ পাঠ্য সমাপ্তি প্রদান করে ব্যবহারকারীর প্রকার, বিমানবন্দরের মতো প্রাসঙ্গিক স্থানের পরামর্শ দেয়।
- মূল পরামিতি:
-
input
: HTML ইনপুট উপাদান (#search-input
) যেখানে ব্যবহারকারী তাদের প্রশ্ন টাইপ করে। -
componentRestrictions
: একটি নির্দিষ্ট দেশে অনুসন্ধান ফলাফল ফিল্টার করে। এখানে,{ country: 'in' }
ভারতে ফলাফল সীমাবদ্ধ করে। -
fields
: নির্বাচিত স্থানের জন্য ফেরত দেওয়া ডেটা ক্ষেত্রগুলি নির্দিষ্ট করে।['place_id']
প্রাথমিকভাবে ডেটা স্থানান্তর অপ্টিমাইজ করে স্থানের জন্য শুধুমাত্র অনন্য শনাক্তকারী পুনরুদ্ধার করতে ব্যবহৃত হয়।
-
- কিভাবে স্বয়ংসম্পূর্ণ ব্যবহার করবেন
// Initialize Autocomplete
const autocomplete = new google.maps.places.Autocomplete(input, {
componentRestrictions: { country: 'in' },
fields: ['place_id'],
});
// Add listener to the Autocomplete
autocomplete.addListener('place_changed', async () => {
const place = autocomplete.getPlace();
if (!place.place_id) {
return;
}
// Once a place is selected, fetch details
await getPlaceDetails(place.place_id);
});
3. বিস্তারিত স্থান তথ্য পুনরুদ্ধার করা এবং সাব-গন্তব্যগুলি পরিচালনা করা
স্বয়ংসম্পূর্ণ পরামর্শগুলি থেকে একটি স্থান নির্বাচন করা হলে, আরও ব্যাপক বিবরণ আনা হয়৷
- API ব্যবহার করা হয়েছে: Places API (
https://places.googleapis.com/v1/places/{placeId}
এ সরাসরিfetch
কলের মাধ্যমে) - উদ্দেশ্য: একটি নির্দিষ্ট স্থান সম্পর্কে সমৃদ্ধ বিশদ পুনরুদ্ধার করা, যার প্রদর্শনের নাম, ঠিকানা, প্রকারগুলি এবং গুরুত্বপূর্ণভাবে, এর
subDestinations
(যেমন, পৃথক টার্মিনাল বা বিমানবন্দরের মতো একটি বড় কমপ্লেক্সের মধ্যে গুরুত্বপূর্ণ এলাকা)। - ইউআরএলে মূল পরামিতি:
-
{placeId}
: নির্বাচিত স্থানের অনন্য শনাক্তকারী। -
fields
: পুনরুদ্ধার করার জন্য সঠিক ডেটা ক্ষেত্রগুলি নির্দিষ্ট করে। অ্যাপটিid
,displayName
,subDestinations
,types
এবংformattedAddress
অনুরোধ করে। খরচ নিয়ন্ত্রণ এবং শুধুমাত্র প্রয়োজনীয় তথ্য গ্রহণের জন্য এটি অত্যন্ত গুরুত্বপূর্ণ।
-
- একটি অবস্থান দেওয়া
subDestinations
কিভাবে পেতে
async function getPlaceDetails(placeId) {
// Construct the URL for the Places API (v1) details endpoint
// The 'fields' parameter is crucial for requesting subDestinations
const url = `https://places.googleapis.com/v1/places/${placeId}?key=YOUR_API_KEY&fields=id,displayName,subDestinations,types,formattedAddress`;
const response = await fetch(url);
const data = await response.json();
// Accessing subDestinations from the Places API response
if (data.subDestinations && data.subDestinations.length > 0) {
for (const subDestination of data.subDestinations) {
// Each subDestination object contains an 'id' and 'displayName'
console.log(`Sub-destination ID: ${subDestination.id}`);
console.log(`Sub-destination Name: ${subDestination.displayName?.text}`);
// This subDestination.id is then used in a geocoding call (as shown in section 4)
}
}
}
**Handling `subDestinations`:** When the Places API returns
`subDestinations`, the application initiates a process for each one:
1. **Geocoding:** It uses the `google.maps.Geocoder` to convert
each `subDestination.id` into its precise geographical coordinates
(`lat`, `lng`).
1. **Marker Placement:** A distinct marker is added to the map for
each sub-destination. These markers are styled with a blue circle icon
to differentiate them.
1. **Map Bounds Adjustment:** The `google.maps.LatLngBounds` object
is used to dynamically expand the map's view to encompass all retrieved
sub-destinations, verifying they are all visible within the current map
frame.
1. **Interactive Information Window:** A `click` listener is
attached to each sub-destination marker. When clicked, the marker's
icon changes to green, and an `InfoWindow` appears, displaying the
sub-destination's name, address, and types. This provides immediate,
detailed context to the user.
4. জিওকোডিং এবং রিভার্স জিওকোডিং: সাব-গন্তব্যগুলির জন্য বিশদ সংগ্রহ করা
অ্যাপ্লিকেশনটি দুটি প্রধান উদ্দেশ্যে জিওকোডিং ব্যবহার করে: স্থানের আইডিগুলিকে স্থানাঙ্কে রূপান্তর করা এবং স্থানাঙ্কগুলিকে অবস্থানের বিবরণে রূপান্তর করা৷ এই বিভাগটি বিশেষভাবে হাইলাইট করে যে কীভাবে জিওকোডিং ব্যবহার করা হয় উপ-গন্তব্য সম্পর্কে বিস্তারিত তথ্য পেতে।
- API ব্যবহার করা হয়েছে:
google.maps.Geocoder
(Maps JavaScript API থেকে) এবং Geocoding API (https://maps.googleapis.com/maps/api/geocode/json
এ সরাসরিfetch
কলের মাধ্যমে) - উদ্দেশ্য:
-
google.maps.Geocoder
: একটিplaceId
(স্বয়ংসম্পূর্ণ বা স্থান API থেকে প্রাপ্ত) ভৌগলিক স্থানাঙ্ক (lat
,lng
) এবং একটি ভিউপোর্টে রূপান্তর করতে ব্যবহৃত হয়, যা মানচিত্রটিকে নির্বাচিত স্থান এবং এর উপ-গন্তব্যগুলিতে সঠিকভাবে কেন্দ্র ও জুম করতে দেয়৷ - জিওকোডিং এপিআই (
fetch
): বিপরীত জিওকোডিং (মানুষ-পঠনযোগ্য ঠিকানায় অক্ষাংশ এবং দ্রাঘিমাংশে রূপান্তর করা) এবং রূপরেখা এবং নেভিগেশন পয়েন্ট তৈরির মতো উন্নত অবস্থানের ডেটা পুনরুদ্ধার করতে ব্যবহৃত হয়।
-
- মূল পরামিতি:
-
google.maps.Geocoder.geocode()
:-
placeId
: জিওকোডের জন্য স্থান আইডি। -
location
: বিপরীত জিওকোডিংয়ের জন্যLatLng
অবজেক্ট।
-
- জিওকোডিং API
fetch
কল:-
latlng
: বিপরীত জিওকোডিংয়ের জন্য অক্ষাংশ এবং দ্রাঘিমাংশ স্থানাঙ্ক। -
extra_computations=BUILDING_AND_ENTRANCES
: এই গুরুত্বপূর্ণ প্যারামিটারটি অতিরিক্ত ডেটার জন্য অনুরোধ করে, বিশেষত বিল্ডিং পায়ের ছাপ এবং প্রবেশদ্বার তথ্য, যা পরে বিল্ডিং আউটলাইন এবং নেভিগেশন পয়েন্টগুলি প্রদর্শন করতে ব্যবহৃত হয়।
-
-
আরও বিশদ (যেমন, অবস্থান, ফর্ম্যাট করা ঠিকানা, প্রকার) আনতে কীভাবে subDestination
আইডি ব্যবহার করবেন
function geocodeAndAddMarker(subDestination, bounds) {
return new Promise((resolve, reject) => {
const geocoder = new google.maps.Geocoder();
// Using the subDestination.id to geocode and get location details
geocoder.geocode({ placeId: subDestination.id }, (results, status) => {
if (status === "OK" && results[0]) {
const location = results[0].geometry.location;
const displayName = subDestination.displayName?.text || "Sub-destination";
const formattedAddress = results[0].formatted_address; // Further detail from Geocoding
const types = results[0].types; // Further detail from Geocoding
const marker = new google.maps.Marker({
map: map,
position: location,
title: displayName,
icon: {
path: google.maps.SymbolPath.CIRCLE,
fillColor: 'blue',
fillOpacity: 0.6,
strokeWeight: 0,
scale: 8
}
});
marker.addListener('click', () => {
marker.setIcon({
path: google.maps.SymbolPath.CIRCLE,
fillColor: 'green',
fillOpacity: 0.6,
strokeWeight: 0,
scale: 8
});
const infowindow = new google.maps.InfoWindow({
content: `<b>${displayName}</b><br><p>Address: ${formattedAddress}</p><p>Types: ${types.join(', ')}</p>`,
});
infowindow.open(map, marker);
});
bounds.extend(location);
resolve(true);
} else {
reject(new Error(`Geocoding failed for placeId: ${subDestination.id}`));
}
});
});
}
5. মার্কার প্রদর্শন করা হচ্ছে
মানচিত্রে নির্দিষ্ট অবস্থানগুলিকে হাইলাইট করতে মার্কার ব্যবহার করা হয়।
- API ব্যবহার করা হয়েছে:
google.maps.Marker
(Maps JavaScript API থেকে) এবংgoogle.maps.marker.AdvancedMarkerElement
সহgoogle.maps.marker.PinElement
(মানচিত্র জাভাস্ক্রিপ্ট API-এর মার্কার লাইব্রেরি থেকে) - উদ্দেশ্য:
-
google.maps.Marker
: প্রাথমিক টেনে নেওয়া যোগ্য মার্কার (যদিও প্রদত্ত কোডেdraggable
false
সেট করা হয়েছে, এটি এর ক্ষমতার অংশ) এবং ধারা 3-এ বর্ণিত মৌলিক উপ-গন্তব্য চিহ্নিতকারীর জন্য ব্যবহৃত হয়। -
AdvancedMarkerElement
এবংPinElement
: আরো দৃশ্যমানভাবে স্বতন্ত্র নেভিগেশন পয়েন্ট মার্কারগুলির জন্য ব্যবহৃত হয়, যা মার্কার পিনের কাস্টম স্টাইল করার অনুমতি দেয়।
-
- মূল পরামিতি:
-
position
:LatLng
স্থানাঙ্ক যেখানে মার্কার স্থাপন করা হবে। -
map
: মানচিত্রের উদাহরণ যেখানে মার্কার প্রদর্শিত হবে। -
title
: মার্কারের উপর ঘোরানোর সময় পাঠ্য প্রদর্শিত হয়। -
icon
:google.maps.Marker
এর জন্য কাস্টম আইকনকে অনুমতি দেয় (যেমন, কাস্টম রঙ সহgoogle.maps.SymbolPath.CIRCLE
)। -
content
:AdvancedMarkerElement
জন্য, এটি পূর্ব-স্টাইলযুক্ত পিনের জন্যPinElement
সহ কাস্টম HTML সামগ্রী এম্বেড করার অনুমতি দেয়। -
PinElement
পরামিতি:background
,borderColor
,glyphColor
, ভিজ্যুয়াল কাস্টমাইজেশনের জন্যscale
।
-
6. বিল্ডিং রূপরেখা প্রদর্শন করা
অ্যাপ্লিকেশনটি দৃশ্যত ভবনগুলির পদচিহ্ন উপস্থাপন করতে পারে।
- API ব্যবহার করা হয়েছে:
google.maps.Data
(মানচিত্র জাভাস্ক্রিপ্ট API থেকে) - উদ্দেশ্য: ভৌগলিক ডেটা প্রদর্শন করা, যেমন বিল্ডিং আউটলাইন (জিওকোডিং এপিআই এর
extra_computations
থেকে GeoJSONdisplay_polygon
হিসাবে ফিরে এসেছে)। - মূল পরামিতি:
-
map
: মানচিত্রের উদাহরণ যেখানে ডেটা স্তর প্রয়োগ করা হয়। -
style
: GeoJSON বৈশিষ্ট্যগুলির দৃশ্যমান উপস্থিতি সংজ্ঞায়িত করে (যেমন,strokeColor
,fillColor
,fillOpacity
)। -
addGeoJson()
: স্তরে GeoJSON ডেটা যোগ করার পদ্ধতি।
-
7. মানচিত্র সীমানা এবং জুম
মানচিত্র দৃশ্য যাচাই করা সমস্ত প্রাসঙ্গিক অবস্থানগুলিকে অন্তর্ভুক্ত করে।
- API ব্যবহার করা হয়েছে:
google.maps.LatLngBounds
(মানচিত্র জাভাস্ক্রিপ্ট API থেকে) - উদ্দেশ্য: ভৌগলিক পয়েন্টগুলির একটি সংগ্রহের জন্য মানচিত্রটির ভিউপোর্টকে গতিশীলভাবে সামঞ্জস্য করা (যেমন, প্রধান স্থান এবং এর সমস্ত উপ-গন্তব্য)।
- মূল পদ্ধতি:
-
extend(location)
: সীমার সাথে একটিLatLng
পয়েন্ট যোগ করে, প্রয়োজনে তাদের প্রসারিত করে। -
fitBounds(bounds)
:LatLngBounds
অবজেক্ট দ্বারা সংজ্ঞায়িত সমগ্র এলাকা প্রদর্শন করতে মানচিত্রের কেন্দ্র এবং জুম স্তর সামঞ্জস্য করে।
-
এই Google মানচিত্র প্ল্যাটফর্ম APIগুলিকে একত্রিত করে, অ্যাপ্লিকেশনটি স্থানগুলি অনুসন্ধান করার জন্য, তাদের বিশদ বিবরণ দেখার জন্য এবং উপ-গন্তব্য এবং নির্মাণের রূপরেখার মতো সম্পর্কিত ভৌগলিক তথ্যগুলিকে ভিজ্যুয়ালাইজ করার জন্য একটি ব্যাপক এবং ইন্টারেক্টিভ অভিজ্ঞতা প্রদান করে৷
বাস্তবায়নের বিবেচনা নোট করুন যে এটি সমস্ত বিমানবন্দর এলাকায় কাজ করে না এবং (বিমানবন্দর টার্মিনাল) ডেটা উপলব্ধতার সাপেক্ষে।
সম্পদ জিওকোডিং API স্থান API মানচিত্র জাভাস্ক্রিপ্ট API
লেখক: