বিমানবন্দরে উন্নত ন্যাভিগেশন, বিমানবন্দরে উন্নত নেভিগেশন

ইমেজ

বিমানবন্দরগুলি বড়, মাল্টি-টার্মিনাল কমপ্লেক্স এবং যথাসময়ে আগমন এবং প্রস্থানের জন্য সুনির্দিষ্ট নেভিগেশন গুরুত্বপূর্ণ। 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 (যেমন, পৃথক টার্মিনাল বা বিমানবন্দরের মতো একটি বড় কমপ্লেক্সের মধ্যে গুরুত্বপূর্ণ এলাকা)।
  • ইউআরএলে মূল পরামিতি:
    1. {placeId} : নির্বাচিত স্থানের অনন্য শনাক্তকারী।
    2. 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 থেকে GeoJSON display_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

লেখক: