कंट्रोल के बारे में खास जानकारी
Maps JavaScript API की मदद से दिखाए गए मैप में यूज़र इंटरफ़ेस (यूआई) एलिमेंट होते हैं. इनकी मदद से, उपयोगकर्ता मैप के साथ इंटरैक्ट कर सकते हैं. इन एलिमेंट को कंट्रोल कहा जाता है. अपने ऐप्लिकेशन में इन कंट्रोल के अलग-अलग वर्शन शामिल किए जा सकते हैं. इसके अलावा, आपके पास कुछ न करने का विकल्प भी है. ऐसे में, Maps JavaScript API सभी कंट्रोल के व्यवहार को मैनेज करेगा.
इस मैप में, Maps JavaScript API की मदद से दिखाए जाने वाले कंट्रोल का डिफ़ॉल्ट सेट दिखाया गया है:
ऊपर बाईं ओर से घड़ी की सुई की दिशा में: मैप टाइप, फ़ुलस्क्रीन, कैमरा, Street View, कीबोर्ड शॉर्टकट.
यहां उन सभी कंट्रोल की सूची दी गई है जिनका इस्तेमाल मैप में किया जा सकता है:
- मैप टाइप कंट्रोल, ड्रॉप-डाउन या हॉरिज़ॉन्टल बटन बार स्टाइल में उपलब्ध होता है. इससे उपयोगकर्ता को मैप टाइप (
ROADMAP,SATELLITE,HYBRIDयाTERRAIN) चुनने की सुविधा मिलती है. यह कंट्रोल, मैप के सबसे ऊपर बाएं कोने में डिफ़ॉल्ट रूप से दिखता है. - फ़ुलस्क्रीन कंट्रोल की मदद से, मैप को फ़ुलस्क्रीन मोड में खोला जा सकता है. यह कंट्रोल, डेस्कटॉप और मोबाइल डिवाइसों पर डिफ़ॉल्ट रूप से चालू होता है. ध्यान दें: iOS पर फ़ुलस्क्रीन सुविधा काम नहीं करती. इसलिए, iOS डिवाइसों पर फ़ुलस्क्रीन कंट्रोल नहीं दिखता.
- कैमरा कंट्रोल सुविधा में, ज़ूम करने के साथ-साथ पैन करने के कंट्रोल भी मिलते हैं.
- Street View कंट्रोल में पेगमैन आइकॉन होता है. इसे मैप पर खींचकर Street View की सुविधा चालू की जा सकती है. यह कंट्रोल, मैप के सबसे नीचे दाईं ओर डिफ़ॉल्ट रूप से दिखता है.
- घुमाने का कंट्रोल, 3D इमेज वाले मैप के लिए झुकाने और घुमाने के विकल्पों का कॉम्बिनेशन उपलब्ध कराता है. यह कंट्रोल, मैप के सबसे नीचे दाईं ओर डिफ़ॉल्ट रूप से दिखता है. ज़्यादा जानकारी के लिए, 3D व्यू की खास जानकारी देखें.
- स्केल कंट्रोल, मैप स्केल एलिमेंट दिखाता है. यह कंट्रोल डिफ़ॉल्ट रूप से बंद होता है.
- कीबोर्ड शॉर्टकट कंट्रोल में, मैप के साथ इंटरैक्ट करने के लिए कीबोर्ड शॉर्टकट की सूची दिखती है.
इन मैप कंट्रोल को सीधे तौर पर ऐक्सेस या उनमें बदलाव नहीं किया जा सकता. इसके बजाय, मैप के MapOptions फ़ील्ड में बदलाव करें. इससे कंट्रोल के दिखने और प्रज़ेंटेशन पर असर पड़ता है. अपने मैप को इंस्टैंशिएट करते समय (सही MapOptions के साथ), कंट्रोल प्रज़ेंटेशन को अडजस्ट किया जा सकता है. इसके अलावा, मैप के विकल्पों को बदलने के लिए setOptions() को कॉल करके, मैप में डाइनैमिक तरीके से बदलाव किया जा सकता है.
इनमें से कुछ कंट्रोल, डिफ़ॉल्ट रूप से चालू नहीं होते. डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) के व्यवहार और इसे बदलने के तरीके के बारे में जानने के लिए, नीचे डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) देखें.
डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई)
अगर मैप बहुत छोटा (200x200 पिक्सल) है, तो डिफ़ॉल्ट रूप से सभी कंट्रोल गायब हो जाते हैं. कंट्रोल को दिखने के लिए साफ़ तौर पर सेट करके, इस डिफ़ॉल्ट सेटिंग को बदला जा सकता है. मैप में कंट्रोल जोड़ना लेख पढ़ें.
मोबाइल और डेस्कटॉप डिवाइसों पर, कंट्रोल का व्यवहार और दिखने का तरीका एक जैसा होता है. हालांकि, फ़ुलस्क्रीन कंट्रोल अलग होता है. इसके बारे में कंट्रोल की सूची में बताया गया है.
इसके अलावा, कीबोर्ड हैंडलिंग की सुविधा सभी डिवाइसों पर डिफ़ॉल्ट रूप से चालू होती है.
डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) बंद करना
ऐसा हो सकता है कि आपको एपीआई के डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) बटन को पूरी तरह से बंद करना हो. इसके लिए, मैप की disableDefaultUI प्रॉपर्टी (MapOptions ऑब्जेक्ट में मौजूद) को true पर सेट करें. इस प्रॉपर्टी की मदद से, Maps JavaScript API के किसी भी यूज़र इंटरफ़ेस (यूआई) कंट्रोल बटन को बंद किया जा सकता है. हालांकि, इससे बेस मैप पर माउस के जेस्चर या कीबोर्ड शॉर्टकट पर कोई असर नहीं पड़ता. इन्हें क्रमशः gestureHandling और keyboardShortcuts प्रॉपर्टी से कंट्रोल किया जाता है.
नीचे दिया गया कोड, यूज़र इंटरफ़ेस (यूआई) बटन बंद कर देता है:
TypeScript
innerMap.setOptions({ // Disable the default UI. disableDefaultUI: true, });
JavaScript
innerMap.setOptions({ // Disable the default UI. disableDefaultUI: true, });
सैंपल आज़माएं
मैप में कंट्रोल जोड़ना
आपको यूज़र इंटरफ़ेस (यूआई) के व्यवहार या कंट्रोल को हटाकर, जोड़कर या बदलकर, इंटरफ़ेस को अपनी पसंद के मुताबिक बनाना पड़ सकता है. साथ ही, यह पक्का करना पड़ सकता है कि आने वाले अपडेट से, यूज़र इंटरफ़ेस (यूआई) के व्यवहार में बदलाव न हो. अगर आपको सिर्फ़ मौजूदा व्यवहार को जोड़ना या उसमें बदलाव करना है, तो आपको यह पक्का करना होगा कि कंट्रोल को आपके ऐप्लिकेशन में साफ़ तौर पर जोड़ा गया हो.
कुछ कंट्रोल, मैप पर डिफ़ॉल्ट रूप से दिखते हैं. वहीं, कुछ कंट्रोल तब तक नहीं दिखते, जब तक उनके लिए खास तौर पर अनुरोध न किया जाए. मैप में कंट्रोल जोड़ने या हटाने के बारे में, यहां दिए गए MapOptions ऑब्जेक्ट के फ़ील्ड में बताया गया है. इन फ़ील्ड को true पर सेट करके, कंट्रोल दिखाए जा सकते हैं या false पर सेट करके, उन्हें छिपाया जा सकता है:
{ cameraControl: boolean, mapTypeControl: boolean, scaleControl: boolean, streetViewControl: boolean, rotateControl: boolean, fullscreenControl: boolean }
अगर मैप 200x200 पिक्सल से छोटा है, तो डिफ़ॉल्ट रूप से सभी कंट्रोल गायब हो जाते हैं.
कंट्रोल को दिखने के लिए साफ़ तौर पर सेट करके, इस डिफ़ॉल्ट सेटिंग को बदला जा सकता है. उदाहरण के लिए, यहां दी गई टेबल में दिखाया गया है कि मैप के साइज़ और cameraControl फ़ील्ड की सेटिंग के आधार पर, कैमरा कंट्रोल दिखता है या नहीं:
| मैप आकार | cameraControl |
क्या यह दिख रहा है? |
|---|---|---|
| कोई भी | false |
नहीं |
| कोई भी | true |
हां |
| >= 200x200 पिक्सल | undefined |
हां |
| < 200x200 पिक्सल | undefined |
नहीं |
यहां दिए गए उदाहरण में, मैप को इस तरह सेट किया गया है कि कैमरा कंट्रोल छिपा रहे और स्केल कंट्रोल दिखे. ध्यान दें कि हम डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) को साफ़ तौर पर बंद नहीं करते. इसलिए, ये बदलाव डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) के व्यवहार में जुड़ जाते हैं.
TypeScript
innerMap.setOptions({ cameraControl: false, scaleControl: true, });
JavaScript
innerMap.setOptions({ cameraControl: false, scaleControl: true, });
सैंपल आज़माएं
कंट्रोल करने के विकल्प
कई कंट्रोल को कॉन्फ़िगर किया जा सकता है. इससे आपको उनके व्यवहार में बदलाव करने या उनके दिखने के तरीके को बदलने की अनुमति मिलती है. उदाहरण के लिए, मैप टाइप कंट्रोल, हॉरिज़ॉन्टल बार या ड्रॉप-डाउन मेन्यू के तौर पर दिख सकता है.
मैप बनाते समय, MapOptions ऑब्जेक्ट में मौजूद कंट्रोल के विकल्प फ़ील्ड में बदलाव करके, इन कंट्रोल में बदलाव किया जाता है.
उदाहरण के लिए, मैप टाइप कंट्रोल में बदलाव करने के विकल्पों को mapTypeControlOptions फ़ील्ड में दिखाया गया है. मैप टाइप कंट्रोल, इनमें से किसी एक style विकल्प में दिख सकता है:
google.maps.MapTypeControlStyle.HORIZONTAL_BAR, कंट्रोल के ऐरे को हॉरिज़ॉन्टल बार में बटन के तौर पर दिखाता है. जैसा कि Google Maps पर दिखाया गया है.google.maps.MapTypeControlStyle.DROPDOWN_MENUमें एक बटन कंट्रोल दिखता है. इससे ड्रॉप-डाउन मेन्यू का इस्तेमाल करके, मैप का टाइप चुना जा सकता है.google.maps.MapTypeControlStyle.DEFAULTमें डिफ़ॉल्ट व्यवहार दिखता है. यह स्क्रीन के साइज़ पर निर्भर करता है और API के आने वाले वर्शन में बदल सकता है.
ध्यान दें कि अगर आपने किसी कंट्रोल के विकल्पों में बदलाव किया है, तो आपको कंट्रोल को साफ़ तौर पर चालू करना होगा. इसके लिए, MapOptions की वैल्यू को true पर सेट करें. उदाहरण के लिए, मैप टाइप कंट्रोल को DROPDOWN_MENU स्टाइल में दिखाने के लिए, MapOptions ऑब्जेक्ट में इस कोड का इस्तेमाल करें:
... mapTypeControl: true, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.DROPDOWN_MENU } ...
यहां दिए गए उदाहरण में, कंट्रोल की डिफ़ॉल्ट जगह और स्टाइल बदलने का तरीका बताया गया है.
TypeScript
innerMap.setOptions({ mapTypeControl: true, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.DROPDOWN_MENU, mapTypeIds: [ google.maps.MapTypeId.ROADMAP, google.maps.MapTypeId.TERRAIN, ], position: google.maps.ControlPosition.TOP_CENTER, }, });
JavaScript
innerMap.setOptions({ mapTypeControl: true, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.DROPDOWN_MENU, mapTypeIds: [ google.maps.MapTypeId.ROADMAP, google.maps.MapTypeId.TERRAIN, ], position: google.maps.ControlPosition.TOP_CENTER, }, });
सैंपल आज़माएं
आम तौर पर, मैप बनाते समय कंट्रोल कॉन्फ़िगर किए जाते हैं. हालांकि,
Map के setOptions() तरीके को कॉल करके, कंट्रोल के प्रज़ेंटेशन में डाइनैमिक तरीके से बदलाव किया जा सकता है.
इसके लिए, आपको कंट्रोल के नए विकल्प पास करने होंगे.
कंट्रोल में बदलाव करना
मैप के MapOptions ऑब्जेक्ट में मौजूद फ़ील्ड का इस्तेमाल करके मैप बनाते समय, कंट्रोल के प्रज़ेंटेशन के बारे में बताया जाता है. इन फ़ील्ड के बारे में यहां बताया गया है:
cameraControl, कैमरे के कंट्रोल को चालू/बंद करता है. इसकी मदद से उपयोगकर्ता, मैप को ज़ूम और पैन कर सकता है. यह कंट्रोल, डिफ़ॉल्ट रूप से सभी मैप पर दिखता है.cameraControlOptionsफ़ील्ड में, इस कंट्रोल के लिए इस्तेमाल किए जाने वालेCameraControlOptionsके बारे में भी बताया जाता है.mapTypeControl, मैप टाइप कंट्रोल को चालू/बंद करता है. इसकी मदद से, उपयोगकर्ता मैप टाइप (जैसे कि मैप और सैटलाइट) के बीच टॉगल कर सकता है. डिफ़ॉल्ट रूप से, यह कंट्रोल दिखता है और मैप के सबसे ऊपर बाएं कोने में दिखता है.mapTypeControlOptionsफ़ील्ड, इस कंट्रोल के लिए इस्तेमाल किए जाने वालेMapTypeControlOptionsके बारे में भी बताता है.streetViewControl, पेगमैन कंट्रोल को चालू/बंद करता है. इसकी मदद से उपयोगकर्ता, Street View पैनोरमा चालू कर सकता है. डिफ़ॉल्ट रूप से, यह कंट्रोल दिखता है और मैप के सबसे नीचे दाईं ओर दिखता है.streetViewControlOptionsफ़ील्ड, इस कंट्रोल के लिए इस्तेमाल किए जाने वालेStreetViewControlOptionsके बारे में भी बताता है.rotateControlइस विकल्प की मदद से, 3D इमेज के ओरिएंटेशन को कंट्रोल करने के लिए, रोटेट कंट्रोल को चालू/बंद किया जा सकता है. डिफ़ॉल्ट रूप से, कंट्रोल के दिखने या न दिखने का फ़ैसला, मौजूदा ज़ूम लेवल और जगह के हिसाब से, दिए गए मैप टाइप के लिए 3D इमेज के मौजूद होने या न होने के आधार पर किया जाता है. मैप केrotateControlOptionsको सेट करके, कंट्रोल के व्यवहार में बदलाव किया जा सकता है. इससे यह तय किया जा सकता है किRotateControlOptionsका इस्तेमाल किया जाए. यह कंट्रोल सिर्फ़ 3D बेस मैप पर दिखेगा.scaleControl, स्केल कंट्रोल को चालू/बंद करता है. यह कंट्रोल, मैप का स्केल दिखाता है. डिफ़ॉल्ट रूप से, यह कंट्रोल नहीं दिखता. चालू होने पर, यह मैप के सबसे नीचे दाएं कोने में हमेशा दिखेगा.scaleControlOptions, इस कंट्रोल के लिए इस्तेमाल किए जाने वालेScaleControlOptionsके बारे में भी बताता है.fullscreenControl, मैप को फ़ुलस्क्रीन मोड में खोलने वाले कंट्रोल को चालू या बंद करता है. यह कंट्रोल, डेस्कटॉप और Android डिवाइसों पर डिफ़ॉल्ट रूप से चालू होता है. यह सुविधा चालू होने पर, कंट्रोल मैप में सबसे ऊपर दाईं ओर दिखता है.fullscreenControlOptions, इस कंट्रोल के लिए इस्तेमाल किए जाने वालेFullscreenControlOptionsके बारे में भी बताता है.
ध्यान दें कि शुरू में बंद किए गए कंट्रोल के लिए, विकल्प तय किए जा सकते हैं.
कंट्रोल की पोज़िशनिंग
ज़्यादातर कंट्रोल विकल्पों में position प्रॉपर्टी (ControlPosition टाइप की) होती है. इससे पता चलता है कि मैप पर कंट्रोल को कहां रखना है. इन कंट्रोल की पोज़िशन तय नहीं होती. इसके बजाय, API दिए गए कंस्ट्रेंट (जैसे कि मैप का साइज़) के हिसाब से, मैप के मौजूदा एलिमेंट या अन्य कंट्रोल के आस-पास कंट्रोल को स्मार्ट तरीके से लेआउट करेगा.
कंट्रोल पोज़िशन दो तरह की होती हैं: लेगसी और लॉजिकल. लॉजिकल वैल्यू का इस्तेमाल करने का सुझाव दिया जाता है, ताकि बाएं से दाएं (एलटीआर) और दाएं से बाएं (आरटीएल), दोनों तरह के लेआउट कॉन्टेक्स्ट को अपने-आप सपोर्ट किया जा सके. रेफ़रंस गाइड देखें.
यहां दी गई टेबल में, एलटीआर और आरटीएल कॉन्टेक्स्ट में कंट्रोल की जा सकने वाली पोज़िशन दिखाई गई हैं.
बाएं से दाएं की ओर टेक्स्ट की स्थितियां
| जगह (बाएं से दाएं के हिसाब से) | लॉजिकल कॉन्स्टेंट (सुझाया गया) | लेगसी कॉन्स्टेंट |
|---|---|---|
| सबसे ऊपर बाईं ओर | BLOCK_START_INLINE_START |
TOP_LEFT |
| ऊपर बीच में | BLOCK_START_INLINE_CENTER |
TOP_CENTER |
| सबसे ऊपर दाईं ओर | BLOCK_START_INLINE_END |
TOP_RIGHT |
| सबसे ऊपर, बाईं ओर | INLINE_START_BLOCK_START |
LEFT_TOP |
| बाईं ओर बीच में | INLINE_START_BLOCK_CENTER |
LEFT_CENTER |
| सबसे नीचे बाईं ओर | INLINE_START_BLOCK_END |
LEFT_BOTTOM |
| दाईं ओर सबसे ऊपर | INLINE_END_BLOCK_START |
RIGHT_TOP |
| दाईं ओर बीच में | INLINE_END_BLOCK_CENTER |
RIGHT_CENTER |
| सबसे नीचे दाईं ओर | INLINE_END_BLOCK_END |
RIGHT_BOTTOM |
| सबसे नीचे बाईं ओर | BLOCK_END_INLINE_START |
BOTTOM_LEFT |
| सबसे नीचे बीच में | BLOCK_END_INLINE_CENTER |
BOTTOM_CENTER |
| सबसे नीचे दाईं ओर | BLOCK_END_INLINE_END |
BOTTOM_RIGHT |
दाएं से बाएं की ओर टेक्स्ट वाले विज्ञापन
| जगह (दाएं से बाएं के हिसाब से) | लॉजिकल कॉन्स्टेंट (सुझाया गया) | लेगसी कॉन्स्टेंट |
|---|---|---|
| सबसे ऊपर दाईं ओर | BLOCK_START_INLINE_START |
TOP_RIGHT |
| ऊपर बीच में | BLOCK_START_INLINE_CENTER |
TOP_CENTER |
| सबसे ऊपर बाईं ओर | BLOCK_START_INLINE_END |
TOP_LEFT |
| दाईं ओर सबसे ऊपर | INLINE_START_BLOCK_START |
RIGHT_TOP |
| दाईं ओर बीच में | INLINE_START_BLOCK_CENTER |
RIGHT_CENTER |
| सबसे नीचे दाईं ओर | INLINE_START_BLOCK_END |
RIGHT_BOTTOM |
| सबसे ऊपर, बाईं ओर | INLINE_END_BLOCK_START |
LEFT_TOP |
| बाईं ओर बीच में | INLINE_END_BLOCK_CENTER |
LEFT_CENTER |
| सबसे नीचे बाईं ओर | INLINE_END_BLOCK_END |
LEFT_BOTTOM |
| सबसे नीचे दाईं ओर | BLOCK_END_INLINE_START |
BOTTOM_RIGHT |
| सबसे नीचे बीच में | BLOCK_END_INLINE_CENTER |
BOTTOM_CENTER |
| सबसे नीचे बाईं ओर | BLOCK_END_INLINE_END |
BOTTOM_LEFT |
मैप को एलटीआर और आरटीएल मोड के बीच टॉगल करने के लिए, लेबल पर क्लिक करें.
ध्यान दें कि ये जगहें, यूज़र इंटरफ़ेस (यूआई) एलिमेंट की उन जगहों से मेल खा सकती हैं जिनमें बदलाव नहीं किया जा सकता. जैसे, कॉपीराइट और Google का लोगो. ऐसे मामलों में, कंट्रोल हर पोज़िशन के लिए बताए गए लॉजिक के हिसाब से दिखेंगे. साथ ही, वे बताई गई पोज़िशन के आस-पास दिखेंगे. जटिल लेआउट की वजह से, यह गारंटी नहीं दी जा सकती कि कंट्रोल ओवरलैप नहीं होंगे. हालांकि, एपीआई उन्हें बेहतर तरीके से व्यवस्थित करने की कोशिश करेगा.
यहां दिए गए उदाहरण में, सभी कंट्रोल चालू किए गए बेसिक मैप को अलग-अलग जगहों पर दिखाया गया है.
TypeScript
function initMap(): void { const map = new google.maps.Map( document.getElementById("map") as HTMLElement, { zoom: 12, center: { lat: -28.643387, lng: 153.612224 }, mapTypeControl: true, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.TOP_CENTER, }, zoomControl: true, zoomControlOptions: { position: google.maps.ControlPosition.LEFT_CENTER, }, scaleControl: true, streetViewControl: true, streetViewControlOptions: { position: google.maps.ControlPosition.LEFT_TOP, }, fullscreenControl: true, } ); } declare global { interface Window { initMap: () => void; } } window.initMap = initMap;
JavaScript
function initMap() { const map = new google.maps.Map(document.getElementById("map"), { zoom: 12, center: { lat: -28.643387, lng: 153.612224 }, mapTypeControl: true, mapTypeControlOptions: { style: google.maps.MapTypeControlStyle.HORIZONTAL_BAR, position: google.maps.ControlPosition.TOP_CENTER, }, zoomControl: true, zoomControlOptions: { position: google.maps.ControlPosition.LEFT_CENTER, }, scaleControl: true, streetViewControl: true, streetViewControlOptions: { position: google.maps.ControlPosition.LEFT_TOP, }, fullscreenControl: true, }); } window.initMap = initMap;
सैंपल आज़माएं
कस्टम कंट्रोल
मौजूदा एपीआई कंट्रोल की स्टाइल और पोज़िशन में बदलाव करने के साथ-साथ, उपयोगकर्ता के साथ इंटरैक्शन को मैनेज करने के लिए, अपने कंट्रोल बनाए जा सकते हैं. कंट्रोल, स्थिर विजेट होते हैं. ये मैप के ऊपर, तय की गई पोज़िशन पर दिखते हैं. ये ओवरले से अलग होते हैं, जो मैप के साथ मूव करते हैं. आसान शब्दों में कहें, तो कंट्रोल एक <div> एलिमेंट होता है. इसकी पोज़िशन मैप पर तय होती है. यह उपयोगकर्ता को कुछ यूज़र इंटरफ़ेस (यूआई) दिखाता है. साथ ही, यह उपयोगकर्ता या मैप के साथ इंटरैक्शन को मैनेज करता है. आम तौर पर, यह काम इवेंट हैंडलर के ज़रिए किया जाता है.
अपनी पसंद के मुताबिक कंट्रोल बनाने के लिए, कुछ नियमों का पालन करना ज़रूरी है. हालांकि, यहां दिए गए दिशा-निर्देशों का पालन करना सबसे सही तरीका हो सकता है:
- कंट्रोल एलिमेंट दिखाने के लिए, सही सीएसएस तय करें.
- मैप प्रॉपर्टी में बदलाव या उपयोगकर्ता इवेंट (उदाहरण के लिए,
'click'इवेंट) के लिए इवेंट हैंडलर के ज़रिए, उपयोगकर्ता या मैप के साथ इंटरैक्शन को मैनेज करें. - कंट्रोल को होल्ड करने के लिए,
<div>एलिमेंट बनाएं. इसके बाद, इस एलिमेंट कोMapकीcontrolsप्रॉपर्टी में जोड़ें.
इनमें से हर एक के बारे में यहां बताया गया है.
कस्टम कंट्रोल बनाना
आपके पास यह तय करने का विकल्प होता है कि आपको अपने हिसाब से कंट्रोल कैसे करना है. आम तौर पर, हमारा सुझाव है कि आप अपने सभी कंट्रोल प्रज़ेंटेशन को एक ही <div> एलिमेंट में रखें, ताकि आप अपने कंट्रोल को एक यूनिट के तौर पर इस्तेमाल कर सकें. हम नीचे दिए गए सैंपल में इस डिज़ाइन पैटर्न का इस्तेमाल करेंगे.
आकर्षक कंट्रोल डिज़ाइन करने के लिए, सीएसएस और डीओएम स्ट्रक्चर के बारे में कुछ जानकारी होना ज़रूरी है. नीचे दिए गए कोड के उदाहरणों में, एलान वाले एचटीएमएल और प्रोग्राम के हिसाब से काम करने वाले तरीकों का इस्तेमाल करके, कस्टम कंट्रोल जोड़ने का तरीका बताया गया है.
डिक्लेरेटिव सीएसएस
यहां दी गई सीएसएस स्टाइल, डिफ़ॉल्ट कंट्रोल के लुक के मुताबिक होती हैं. नीचे दिए गए दोनों उदाहरणों के साथ इन स्टाइल का इस्तेमाल करें:
.streetview-toggle-button { align-items: center; background: white; border: none; border-radius: 2px; box-shadow: 0 1px 4px -1px rgba(0, 0, 0, 0.3); color: rgb(86, 86, 86); cursor: pointer; display: flex; font-family: Roboto, Arial, sans-serif; font-size: 18px; font-weight: 400; height: 40px; justify-content: center; margin: 10px 0; padding: 0 17px; } .streetview-toggle-button:hover { background: #f4f4f4; color: #000; }
डिक्लेरेटिव एचटीएमएल
इन कोड स्निपेट में, कस्टम कंट्रोल को डिक्लेरेटिव तरीके से बनाने का तरीका बताया गया है.
एचटीएमएल में, container आईडी वाले DIV का इस्तेमाल कंट्रोल को पोज़िशन करने के लिए किया जाता है. यह gmp-map एलिमेंट में नेस्ट किया जाता है और बटन को DIV में जोड़ा जाता है. slot एट्रिब्यूट को control-inline-start-block-start पर सेट किया जाता है, ताकि कंट्रोल को मैप के सबसे ऊपर बाएं कोने में पोज़िशन किया जा सके.
<gmp-map
center="41.027748173921374, -92.41852445367961"
zoom="13"
map-id="DEMO_MAP_ID">
<div id="container" slot="control-inline-start-block-start">
<input type="button"
id="streetview-toggle-button"
class="button"
value="Click this button" />
</div>
</gmp-map>JavaScript में, getElementById() का इस्तेमाल DIV और बटन ढूंढने के लिए किया जाता है. साथ ही, बटन में इवेंट लिसनर जोड़ा जाता है और बटन को DIV में जोड़ा जाता है.
// Create a DIV to attach the control UI to the Map. const container = document.getElementById("container"); // Get the control button from the HTML page. const controlButton = document.getElementById("streetview-toggle-button"); // Add a click event listener. controlButton.addEventListener("click", () => { window.alert("You clicked the button!"); }); // Add the control to the DIV. container.append(controlButton);
प्रोग्राम के हिसाब से JavaScript
इस कोड स्निपेट में, प्रोग्राम के हिसाब से बटन कंट्रोल बनाने का तरीका दिखाया गया है. सीएसएस स्टाइल के बारे में ऊपर बताया गया है.
// Create a DIV to attach the control UI to the Map. const container = document.getElementById("container"); // Position the control in the top left corner of the map. container.slot = "control-block-start-inline-start"; // Create the control. const controlButton = document.createElement("button"); controlButton.classList.add("streetview-toggle-button"); controlButton.textContent = "Click this button"; controlButton.type = "button"; // Add a click event listener. controlButton.addEventListener("click", () => { window.alert("You clicked the button!"); }); // Add the control to the DIV. container.append(controlButton);
कस्टम कंट्रोल से इवेंट मैनेज करना
किसी कंट्रोल के काम का होने के लिए, यह ज़रूरी है कि वह कुछ काम करे. कंट्रोल क्या करता है, यह आप पर निर्भर करता है. कंट्रोल, उपयोगकर्ता के इनपुट के हिसाब से काम कर सकता है. इसके अलावा, यह Map की स्थिति में होने वाले बदलावों के हिसाब से भी काम कर सकता है.
उपयोगकर्ता के इनपुट का जवाब देने के लिए, addEventListener() का इस्तेमाल करें. यह सपोर्ट किए गए डीओएम इवेंट को हैंडल करता है. नीचे दिया गया कोड स्निपेट, ब्राउज़र के 'click' इवेंट के लिए एक लिसनर जोड़ता है. ध्यान दें कि यह इवेंट, मैप से नहीं, बल्कि DOM से मिला है.
// Setup the click event listener: set the map to center on Chicago var chicago = {lat: 41.850, lng: -87.650}; controlButton.addEventListener('click', () => { map.setCenter(chicago); });
कस्टम कंट्रोल को ऐक्सेस करने की सुविधा चालू करना
यह पक्का करने के लिए कि कंट्रोल को कीबोर्ड इवेंट मिले और वे स्क्रीन रीडर को सही तरीके से दिखें:
- बटन, फ़ॉर्म एलिमेंट, और लेबल के लिए हमेशा नेटिव एचटीएमएल एलिमेंट का इस्तेमाल करें. नेटिव कंट्रोल को होल्ड करने के लिए, सिर्फ़ DIV एलिमेंट का इस्तेमाल करें. DIV को कभी भी इंटरैक्टिव यूज़र इंटरफ़ेस (यूआई) एलिमेंट के तौर पर इस्तेमाल न करें.
- यूआई एलिमेंट के बारे में जानकारी देने के लिए, सही जगह पर
labelएलिमेंट,titleएट्रिब्यूट याaria-labelएट्रिब्यूट का इस्तेमाल करें.
कस्टम कंट्रोल की पोज़िशन
कस्टम कंट्रोल को सही जगह पर रखने के लिए, slot एट्रिब्यूट का इस्तेमाल करें.
इन पोज़िशन के बारे में जानकारी पाने के लिए, ऊपर दिया गया कंट्रोल की पोज़िशन तय करना लेख पढ़ें.
हर ControlPosition, उस पोज़िशन में दिखाए गए कंट्रोल का MVCArray सेव करता है. इस वजह से, जब किसी कंट्रोल को इस जगह पर जोड़ा या हटाया जाता है, तो एपीआई के ज़रिए कंट्रोल को अपडेट कर दिया जाता है.
नीचे दिए गए कोड से एक नया कस्टम कंट्रोल बनाया जाता है. इसका कंस्ट्रक्टर नहीं दिखाया गया है. साथ ही, इसे मैप में BLOCK_START_INLINE_END पोज़िशन (एलटीआर कॉन्टेक्स्ट में सबसे ऊपर दाईं ओर) में जोड़ा जाता है.
// Create a DIV to attach the control UI to the Map.
const centerControlDiv = document.createElement("div");
// Create the control. This code calls a function that
// creates a new instance of a button control.
const centerControl = createCenterControl(map);
// Append the control to the DIV.
centerControlDiv.appendChild(centerControl);
// Push the control to the BLOCK_START_INLINE_END position.
innerMap.controls[google.maps.ControlPosition.BLOCK_START_INLINE_END].push(centerControlDiv);कस्टम कंट्रोल के लिए, एलान के तौर पर पोज़िशन सेट करने के लिए, एचटीएमएल में slot एट्रिब्यूट सेट करें:
<gmp-map center="30.72851568848909, -81.54675994068873" zoom="12">
<div slot="control-block-start-inline-end">
<!-- Control HTML -->
</div>
</gmp-map>कस्टम कंट्रोल का उदाहरण
यहां दिया गया कंट्रोल आसान है, लेकिन यह ज़्यादा काम का नहीं है. इसमें ऊपर दिखाए गए पैटर्न को एक साथ इस्तेमाल किया गया है. यह कंट्रोल, DOM 'click' इवेंट पर प्रतिक्रिया देता है. इसके तहत, मैप को किसी डिफ़ॉल्ट जगह पर सेंटर किया जाता है:
TypeScript
let map: google.maps.Map; const chicago = { lat: 41.85, lng: -87.65 }; /** * Creates a control that recenters the map on Chicago. */ function createCenterControl(map) { const controlButton = document.createElement('button'); // Set CSS for the control. controlButton.style.backgroundColor = '#fff'; controlButton.style.border = '2px solid #fff'; controlButton.style.borderRadius = '3px'; controlButton.style.boxShadow = '0 2px 6px rgba(0,0,0,.3)'; controlButton.style.color = 'rgb(25,25,25)'; controlButton.style.cursor = 'pointer'; controlButton.style.fontFamily = 'Roboto,Arial,sans-serif'; controlButton.style.fontSize = '16px'; controlButton.style.lineHeight = '38px'; controlButton.style.margin = '8px 0 22px'; controlButton.style.padding = '0 5px'; controlButton.style.textAlign = 'center'; controlButton.textContent = 'Center Map'; controlButton.title = 'Click to recenter the map'; controlButton.type = 'button'; // Setup the click event listeners: simply set the map to Chicago. controlButton.addEventListener('click', () => { map.setCenter(chicago); }); return controlButton; } function initMap() { map = new google.maps.Map(document.getElementById('map') as HTMLElement, { zoom: 12, center: chicago, }); // Create the DIV to hold the control. const centerControlDiv = document.createElement('div'); // Create the control. const centerControl = createCenterControl(map); // Append the control to the DIV. centerControlDiv.appendChild(centerControl); map.controls[google.maps.ControlPosition.TOP_CENTER].push(centerControlDiv); } declare global { interface Window { initMap: () => void; } } window.initMap = initMap;
JavaScript
let map; const chicago = { lat: 41.85, lng: -87.65 }; /** * Creates a control that recenters the map on Chicago. */ function createCenterControl(map) { const controlButton = document.createElement("button"); // Set CSS for the control. controlButton.style.backgroundColor = "#fff"; controlButton.style.border = "2px solid #fff"; controlButton.style.borderRadius = "3px"; controlButton.style.boxShadow = "0 2px 6px rgba(0,0,0,.3)"; controlButton.style.color = "rgb(25,25,25)"; controlButton.style.cursor = "pointer"; controlButton.style.fontFamily = "Roboto,Arial,sans-serif"; controlButton.style.fontSize = "16px"; controlButton.style.lineHeight = "38px"; controlButton.style.margin = "8px 0 22px"; controlButton.style.padding = "0 5px"; controlButton.style.textAlign = "center"; controlButton.textContent = "Center Map"; controlButton.title = "Click to recenter the map"; controlButton.type = "button"; // Setup the click event listeners: simply set the map to Chicago. controlButton.addEventListener("click", () => { map.setCenter(chicago); }); return controlButton; } function initMap() { map = new google.maps.Map(document.getElementById("map"), { zoom: 12, center: chicago, }); // Create the DIV to hold the control. const centerControlDiv = document.createElement("div"); // Create the control. const centerControl = createCenterControl(map); // Append the control to the DIV. centerControlDiv.appendChild(centerControl); map.controls[google.maps.ControlPosition.TOP_CENTER].push(centerControlDiv); } window.initMap = initMap;
सैंपल आज़माएं
कंट्रोल में राज्य जोड़ना
कंट्रोल, स्थिति को भी सेव कर सकते हैं. यहां दिया गया उदाहरण, पहले दिखाए गए उदाहरण से मिलता-जुलता है. हालांकि, इस कंट्रोल में "होम सेट करें" बटन जोड़ा गया है. इससे कंट्रोल को नई होम लोकेशन पर सेट किया जा सकता है. हम ऐसा करने के लिए, कंट्रोल में एक home_ प्रॉपर्टी बनाते हैं, ताकि इस स्थिति को सेव किया जा सके. साथ ही, हम उस स्थिति के लिए गेटर और सेटर उपलब्ध कराते हैं.
TypeScript
let innerMap; const mapElement = document.querySelector('gmp-map') as google.maps.MapElement; let center: google.maps.LatLngLiteral = { lat: 41.85, lng: -87.65 }; async function initMap() { (await google.maps.importLibrary('maps')) as google.maps.MapsLibrary; innerMap = mapElement.innerMap; // Get the button UI elements. const setCenterButton = document.getElementById('btnCenterMap') as HTMLInputElement; const resetCenterButton = document.getElementById('btnSetCenter') as HTMLInputElement; // Set up the click event listener for the 'Center Map' button. Set the map // to the currently stored center. setCenterButton.addEventListener('click', () => { const currentCenter = center; innerMap.setCenter(currentCenter); }); // Set up the click event listener for 'Set Center': Set the center of // the control to the current center of the map. resetCenterButton.addEventListener('click', () => { const newCenter = innerMap.getCenter(); if (newCenter) { center = newCenter; } }); } initMap();
JavaScript
let innerMap; const mapElement = document.querySelector('gmp-map'); let center = { lat: 41.85, lng: -87.65 }; async function initMap() { (await google.maps.importLibrary('maps')); innerMap = mapElement.innerMap; // Get the button UI elements. const setCenterButton = document.getElementById('btnCenterMap'); const resetCenterButton = document.getElementById('btnSetCenter'); // Set up the click event listener for the 'Center Map' button. Set the map // to the currently stored center. setCenterButton.addEventListener('click', () => { const currentCenter = center; innerMap.setCenter(currentCenter); }); // Set up the click event listener for 'Set Center': Set the center of // the control to the current center of the map. resetCenterButton.addEventListener('click', () => { const newCenter = innerMap.getCenter(); if (newCenter) { center = newCenter; } }); } initMap();