एयरपोर्ट बड़े होते हैं और उनमें कई टर्मिनल होते हैं. इसलिए, समय पर पहुंचने और जाने के लिए सटीक नेविगेशन बहुत ज़रूरी है. Google Maps Geocoding API आम तौर पर, अक्षांश/देशांतर वाला एक निर्देशांक दिखाता है. ज़्यादातर मामलों में, यह निर्देशांक एयरपोर्ट के बड़े कॉम्प्लेक्स का केंद्रक होता है. यह ऐप्लिकेशन एक इंटरैक्टिव टूल है. इसे खास तौर पर लोगों की मदद करने के लिए डिज़ाइन किया गया है. इसकी मदद से, लोग किसी बड़े कॉम्प्लेक्स जैसे कि एयरपोर्ट के अंदर मौजूद किसी खास टर्मिनल या पिकअप/ड्रॉप-ऑफ़ पॉइंट की सटीक जगह का पता लगा सकते हैं और उसे देख सकते हैं.
यह इस तरह से काम करता है:
हवाई अड्डा/जगह की खोज: उपयोगकर्ता किसी मुख्य जगह की खोज करके शुरुआत करते हैं. जैसे, "इंदिरा गांधी अंतरराष्ट्रीय हवाई अड्डा") के लिए, Google Places API की अपने-आप पूरी होने वाली सुविधा का इस्तेमाल किया जाता है. यह सुविधा सिर्फ़ भारत में उपलब्ध है.
उप-जगह की जानकारी: मुख्य जगह चुनने के बाद, स्क्रिप्ट Google Places API का इस्तेमाल करके जानकारी फ़ेच करती है. इसमें उस जगह से जुड़े "उप-डेस्टिनेशन" (जैसे, टर्मिनल 1, टर्मिनल 3, खास गेट वगैरह) की जानकारी शामिल होती है. हालांकि, यह जानकारी Google के डेटा में उपलब्ध होनी चाहिए.
विज़ुअल मैपिंग: यह स्क्रिप्ट, मुख्य जगह और उसकी उप-मंज़िलों के निर्देशांकों का पता लगाने के लिए, Geocoding API का इस्तेमाल करती है.
इसके बाद, यह मुख्य जगह और पहचाने गए हर उप-डेस्टिनेशन के लिए, मैप पर अलग-अलग क्लिक किए जा सकने वाले मार्कर (नीले सर्कल) दिखाता है.
सटीक पहचान: सब-डेस्टिनेशन मार्कर पर क्लिक करने से, वह हाइलाइट हो जाता है (हरा हो जाता है). साथ ही, एक InfoWindow खुलती है. इसमें सब-डेस्टिनेशन का नाम और अन्य उपलब्ध जानकारी (जैसे कि पता या टाइप) दिखती है. इससे उपयोगकर्ता यह पुष्टि कर पाता है कि उसने सही पॉइंट चुना है.
संदर्भ के हिसाब से व्यू: मैप, अपने व्यू (fitBounds
) को अपने-आप अडजस्ट करता है, ताकि सभी काम के मार्कर (मुख्य जगह + उप-मंज़िलें) साफ़ तौर पर दिखें.
Airport Navigation ऐप्लिकेशन में Google Maps Platform API
इस दस्तावेज़ में, Google Maps Platform के मुख्य एपीआई और उनके पैरामीटर के बारे में बताया गया है. इनका इस्तेमाल, "हवाई अड्डे पर नेविगेट करें" डेमो ऐप्लिकेशन में किया गया है. यह ऐप्लिकेशन, मैप दिखाने, जगह खोजने, जगह की पूरी जानकारी देने, और जगह की बेहतर इनसाइट देने के लिए कई सेवाओं का इस्तेमाल करता है.
1. मैप को शुरू करना और उसे डिसप्ले करना
ऐप्लिकेशन का मुख्य हिस्सा, इंटरैक्टिव मैप है.
- इस्तेमाल किया गया एपीआई:
google.maps.Map
(Maps JavaScript API से) - मकसद: इस कुकी का इस्तेमाल, वेबपेज पर इंटरैक्टिव मैप बनाने और उसे दिखाने के लिए किया जाता है.
- मुख्य पैरामीटर:
center
: इससे मैप के शुरुआती भौगोलिक केंद्र के बारे में पता चलता है. इस ऐप्लिकेशन में, इसे शुरू में दिल्ली के निर्देशांक ({ lat: 28.461835685621395, lng: 77.05004035761647 }
) पर सेट किया गया है.zoom
: इससे मैप के लिए ज़ूम करने का शुरुआती लेवल सेट किया जाता है.DEFAULT_ZOOM_LEVEL
(15) का इस्तेमाल क्लोज़-अप व्यू के लिए किया जाता है.mapId
: Google Cloud Console में कॉन्फ़िगर की गई मैप स्टाइल के लिए यूनीक आइडेंटिफ़ायर.
2. जगह के नाम से खोज करने और शुरुआती अक्षर लिखने पर पूरा नाम सुझाने की सुविधा
खोज बार की सुविधा, Places API की मदद से काम करती है.
- इस्तेमाल किया गया एपीआई:
google.maps.places.Autocomplete
(Maps JavaScript API की Places Library से) - मकसद: यह कुकी, उपयोगकर्ता के टाइप करते समय भौगोलिक खोजों के लिए टेक्स्ट पूरा करने की सुविधा देती है. साथ ही, हवाई अड्डों जैसी जगहों के सुझाव देती है.
- मुख्य पैरामीटर:
input
: यह एचटीएमएल इनपुट एलिमेंट (#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. जगह की पूरी जानकारी पाना और उप-गंतव्यों को मैनेज करना
अपने-आप पूरा होने वाले सुझावों में से किसी जगह को चुनने पर, उसके बारे में ज़्यादा जानकारी मिलती है.
- इस्तेमाल किया गया एपीआई: 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. जियोकोडिंग और रिवर्स जियोकोडिंग: उप-मंज़िलों की जानकारी पाना
यह ऐप्लिकेशन, जियोकोडिंग का इस्तेमाल दो मुख्य कामों के लिए करता है: जगह के आईडी को निर्देशांकों में बदलना और निर्देशांकों को जगह की जानकारी में वापस बदलना. इस सेक्शन में खास तौर पर यह बताया गया है कि सब-डेस्टिनेशन के बारे में ज़्यादा जानकारी पाने के लिए, जियोकोडिंग का इस्तेमाल कैसे किया जाता है.
- इस्तेमाल किया गया एपीआई: Maps JavaScript API से
google.maps.Geocoder
और Geocoding API (https://maps.googleapis.com/maps/api/geocode/json
को सीधेfetch
कॉल करके) - मकसद:
google.maps.Geocoder
: इसका इस्तेमाल,placeId
(ऑटोकंप्लीट या Places API से मिला) को भौगोलिक निर्देशांकों (lat
,lng
) और व्यूपोर्ट में बदलने के लिए किया जाता है. इससे मैप, चुनी गई जगह और उसके सब-डेस्टिनेशन पर सही तरीके से ज़ूम हो पाता है और बीच में आ जाता है.- Geocoding API (
fetch
): इसका इस्तेमाल रिवर्स जियोकोडिंग के लिए किया जाता है. रिवर्स जियोकोडिंग का मतलब है, अक्षांश और देशांतर को ऐसे पते में बदलना जिसे आसानी से पढ़ा जा सके. इसका इस्तेमाल, जगह की ज़्यादा जानकारी पाने के लिए भी किया जाता है. जैसे, बिल्डिंग की आउटलाइन और नेविगेशन पॉइंट.
- मुख्य पैरामीटर:
google.maps.Geocoder.geocode()
:placeId
: जियोकोड करने के लिए प्लेस आईडी.location
: रिवर्स जियोकोडिंग के लिएLatLng
ऑब्जेक्ट.
- Geocoding 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. मार्कर दिखाना
मार्कर का इस्तेमाल, मैप पर किसी खास जगह को हाइलाइट करने के लिए किया जाता है.
- इस्तेमाल किया गया एपीआई: Maps JavaScript API से
google.maps.Marker
औरgoogle.maps.marker.AdvancedMarkerElement
के साथ-साथ Maps JavaScript API की Marker Library सेgoogle.maps.marker.PinElement
- मकसद:
google.maps.Marker
: इसका इस्तेमाल, शुरुआती तौर पर ड्रैग किए जा सकने वाले मार्कर के लिए किया जाता है. हालांकि, दिए गए कोड मेंdraggable
कोfalse
पर सेट किया गया है, लेकिन यह इसकी क्षमता का हिस्सा है. इसका इस्तेमाल, सेक्शन 3 में बताए गए बुनियादी सब-डेस्टिनेशन मार्कर के लिए भी किया जाता है.AdvancedMarkerElement
औरPinElement
: इनका इस्तेमाल, नेविगेशन पॉइंट मार्कर को ज़्यादा विज़ुअल बनाने के लिए किया जाता है. इससे मार्कर के पिन को कस्टम स्टाइल में सेट किया जा सकता है.
- मुख्य पैरामीटर:
position
:LatLng
कोऑर्डिनेट, जहां मार्कर रखा जाएगा.map
: मैप का वह इंस्टेंस जिस पर मार्कर दिखेगा.title
: मार्कर पर कर्सर घुमाने पर दिखने वाला टेक्स्ट.icon
: इससेgoogle.maps.Marker
के लिए कस्टम आइकॉन इस्तेमाल किए जा सकते हैं (जैसे,google.maps.SymbolPath.CIRCLE
के साथ).content
:AdvancedMarkerElement
के लिए, इसकी मदद से कस्टम एचटीएमएल कॉन्टेंट एम्बेड किया जा सकता है. इसमें पहले से स्टाइल किए गए पिन के लिएPinElement
भी शामिल है.PinElement
पैरामीटर:background
,borderColor
,glyphColor
,scale
का इस्तेमाल करके विज़ुअल को पसंद के मुताबिक बनाया जा सकता है.
6. इमारतों की आउटलाइन दिखाना
यह ऐप्लिकेशन, इमारतों के फ़ुटप्रिंट को विज़ुअल तौर पर दिखा सकता है.
- इस्तेमाल किया गया एपीआई:
google.maps.Data
(Maps JavaScript API से) - मकसद: भौगोलिक डेटा दिखाना. जैसे, इमारतों की आउटलाइन (Geocoding API के
extra_computations
से GeoJSONdisplay_polygon
के तौर पर मिलता है). - मुख्य पैरामीटर:
map
: यह मैप का वह इंस्टेंस होता है जिस पर डेटा लेयर लागू की जाती है.style
: इससे GeoJSON सुविधाओं की विज़ुअल स्टाइल तय की जाती है (जैसे,strokeColor
,fillColor
,fillOpacity
).addGeoJson()
: लेयर में GeoJSON डेटा जोड़ने का तरीका.
7. मैप का दायरा और ज़ूम लेवल
पुष्टि करना कि मैप व्यू में सभी ज़रूरी जगहें शामिल हों.
- इस्तेमाल किया गया एपीआई:
google.maps.LatLngBounds
(Maps JavaScript API से) - मकसद: मैप के व्यूपोर्ट को डाइनैमिक तरीके से अडजस्ट करना, ताकि वह भौगोलिक पॉइंट के कलेक्शन (जैसे, मुख्य जगह और उसकी सभी उप-मंज़िलें) के हिसाब से फ़िट हो सके.
- मुख्य तरीके:
extend(location)
: यह बाउंड्री मेंLatLng
पॉइंट जोड़ता है. अगर ज़रूरी हो, तो उन्हें बड़ा करता है.fitBounds(bounds)
: यह मैप के सेंटर और ज़ूम लेवल को इस तरह से अडजस्ट करता है किLatLngBounds
ऑब्जेक्ट में तय की गई पूरी जगह दिख सके.
Google Maps Platform के इन एपीआई को मिलाकर, ऐप्लिकेशन लोगों को जगहों को खोजने, उनकी जानकारी देखने, और उनसे जुड़ी भौगोलिक जानकारी को विज़ुअलाइज़ करने का बेहतर और इंटरैक्टिव अनुभव देता है. जैसे, उप-मंज़िल और बिल्डिंग की आउटलाइन.
लागू करने से जुड़ी बातें ध्यान दें कि यह सुविधा, एयरपोर्ट के सभी इलाकों में काम नहीं करती. साथ ही, यह (एयरपोर्ट टर्मिनल) डेटा की उपलब्धता पर निर्भर करती है.
संसाधन Geocoding API Places API Maps Javascript API
लेखक: