नियंत्रण

प्लैटफ़ॉर्म चुनें: Android iOS JavaScript

कंट्रोल के बारे में खास जानकारी

Maps JavaScript API की मदद से दिखाए गए मैप में यूज़र इंटरफ़ेस (यूआई) एलिमेंट होते हैं. इनकी मदद से, उपयोगकर्ता मैप के साथ इंटरैक्ट कर सकते हैं. इन एलिमेंट को कंट्रोल कहा जाता है. साथ ही, अपने ऐप्लिकेशन में इन कंट्रोल के वैरिएंट शामिल किए जा सकते हैं. इसके अलावा, कुछ भी किए बिना, Maps JavaScript API को कंट्रोल करने की सुविधा को मैनेज करने दिया जा सकता है.

नीचे दिए गए मैप में, Maps JavaScript API के ज़रिए दिखाए गए कंट्रोल का डिफ़ॉल्ट सेट दिखाया गया है:

यहां उन सभी कंट्रोल की सूची दी गई है जिनका इस्तेमाल आपके मैप में किया जा सकता है:

  • ज़ूम कंट्रोल में, मैप के ज़ूम लेवल को बदलने के लिए "+" और "-" बटन दिखते हैं. यह कंट्रोल, मैप के सबसे नीचे दाएं कोने में डिफ़ॉल्ट रूप से दिखता है.
  • कैमरा कंट्रोल में ज़ूम और पैन, दोनों कंट्रोल होते हैं. साथ ही, बीटा चैनल का इस्तेमाल करने पर, यह ज़ूम कंट्रोल की जगह डिफ़ॉल्ट रूप से दिखता है.
  • मैप टाइप कंट्रोल, ड्रॉप-डाउन या हॉरिज़ॉन्टल बटन बार स्टाइल में उपलब्ध है. इससे उपयोगकर्ता, मैप टाइप (ROADMAP, SATELLITE, HYBRID या TERRAIN) चुन सकता है. यह कंट्रोल, मैप के सबसे ऊपर बाएं कोने में डिफ़ॉल्ट रूप से दिखता है.
  • Street View कंट्रोल में एक पेगमैन आइकॉन होता है. इसे मैप पर खींचकर छोड़ने पर, Street View चालू हो जाता है. यह कंट्रोल, मैप के सबसे नीचे दाईं ओर डिफ़ॉल्ट रूप से दिखता है.
  • घुमाने की सुविधा, झुकी हुई इमेज वाले मैप के लिए, झुकाने और घुमाने के विकल्पों का कॉम्बिनेशन उपलब्ध कराती है. यह कंट्रोल, मैप के सबसे नीचे दाईं ओर डिफ़ॉल्ट रूप से दिखता है. ज़्यादा जानकारी के लिए, 45° इमेजरी देखें.
  • स्केल कंट्रोल, मैप स्केल एलिमेंट दिखाता है. यह कंट्रोल डिफ़ॉल्ट रूप से बंद रहता है.
  • फ़ुलस्क्रीन कंट्रोल की मदद से, मैप को फ़ुलस्क्रीन मोड में खोला जा सकता है. यह कंट्रोल, डेस्कटॉप और मोबाइल डिवाइसों पर डिफ़ॉल्ट रूप से चालू होता है. ध्यान दें: iOS पर, फ़ुलस्क्रीन मोड की सुविधा काम नहीं करती. इसलिए, iOS डिवाइसों पर फ़ुलस्क्रीन कंट्रोल नहीं दिखता.
  • कीबोर्ड शॉर्टकट कंट्रोल, मैप के साथ इंटरैक्ट करने के लिए, कीबोर्ड शॉर्टकट की सूची दिखाता है.

आपके पास इन मैप कंट्रोल को सीधे ऐक्सेस करने या उनमें बदलाव करने का विकल्प नहीं होता. इसके बजाय, मैप के MapOptions फ़ील्ड में बदलाव किया जाता है. इससे कंट्रोल के दिखने और प्रज़ेंटेशन पर असर पड़ता है. मैप को तुरंत बनाने (MapOptions का इस्तेमाल करके) के बाद, कंट्रोल के प्रज़ेंटेशन में बदलाव किया जा सकता है. इसके अलावा, मैप के विकल्पों में बदलाव करने के लिए, setOptions() को कॉल करके मैप में डाइनैमिक तौर पर बदलाव किया जा सकता है.

ये सभी कंट्रोल, डिफ़ॉल्ट रूप से चालू नहीं होते. डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) के व्यवहार और उसमें बदलाव करने के तरीके के बारे में जानने के लिए, नीचे डिफ़ॉल्ट यूज़र इंटरफ़ेस देखें.

डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई)

अगर मैप बहुत छोटा (200x200 पिक्सल) है, तो डिफ़ॉल्ट रूप से सभी कंट्रोल गायब हो जाते हैं. इस व्यवहार को बदला जा सकता है. इसके लिए, कंट्रोल को साफ़ तौर पर दिखने के लिए सेट करें. मैप में कंट्रोल जोड़ना लेख पढ़ें.

फ़ुलस्क्रीन कंट्रोल को छोड़कर, मोबाइल और डेस्कटॉप डिवाइसों पर कंट्रोल का व्यवहार और दिखावट एक जैसी होती है. कंट्रोल की सूची में बताया गया व्यवहार देखें.

इसके अलावा, कीबोर्ड को मैनेज करने की सुविधा सभी डिवाइसों पर डिफ़ॉल्ट रूप से चालू होती है.

डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) को बंद करना

आपके पास एपीआई के डिफ़ॉल्ट यूज़र इंटरफ़ेस (यूआई) बटन को पूरी तरह से बंद करने का विकल्प होता है. ऐसा करने के लिए, MapOptions ऑब्जेक्ट में मैप की disableDefaultUI प्रॉपर्टी को true पर सेट करें. यह प्रॉपर्टी, Maps JavaScript API के यूज़र इंटरफ़ेस (यूआई) कंट्रोल बटन को बंद कर देती है. हालांकि, इससे मुख्य मैप पर माउस जेस्चर या कीबोर्ड शॉर्टकट पर कोई असर नहीं पड़ता. इन्हें gestureHandling और keyboardShortcuts प्रॉपर्टी से कंट्रोल किया जाता है.

नीचे दिया गया कोड, यूज़र इंटरफ़ेस (यूआई) के बटन बंद कर देता है:

TypeScript

function initMap(): void {
  const map = new google.maps.Map(
    document.getElementById("map") as HTMLElement,
    {
      zoom: 4,
      center: { lat: -33, lng: 151 },
      disableDefaultUI: true,
    }
  );
}

declare global {
  interface Window {
    initMap: () => void;
  }
}
window.initMap = initMap;

JavaScript

function initMap() {
  const map = new google.maps.Map(document.getElementById("map"), {
    zoom: 4,
    center: { lat: -33, lng: 151 },
    disableDefaultUI: true,
  });
}

window.initMap = initMap;
उदाहरण देखें

सैंपल आज़माएं

मैप पर कंट्रोल जोड़ना

यूज़र इंटरफ़ेस (यूआई) के व्यवहार या कंट्रोल को हटाकर, जोड़कर या उनमें बदलाव करके, अपने इंटरफ़ेस को पसंद के मुताबिक बनाया जा सकता है. साथ ही, यह पक्का किया जा सकता है कि आने वाले समय में होने वाले अपडेट से इस व्यवहार में कोई बदलाव न हो. अगर आपको सिर्फ़ मौजूदा व्यवहार को जोड़ना या उसमें बदलाव करना है, तो आपको यह पक्का करना होगा कि आपके ऐप्लिकेशन में कंट्रोल साफ़ तौर पर जोड़ा गया हो.

कुछ कंट्रोल, मैप पर डिफ़ॉल्ट रूप से दिखते हैं. वहीं, कुछ कंट्रोल तब तक नहीं दिखेंगे, जब तक आपने उनका खास तौर पर अनुरोध न किया हो. मैप में कंट्रोल जोड़ने या हटाने के बारे में, यहां दिए गए MapOptions ऑब्जेक्ट के फ़ील्ड में बताया गया है. इन्हें दिखाने के लिए, उन्हें true पर सेट करें या छिपाने के लिए, false पर सेट करें:

{
  zoomControl: boolean,
  cameraControl: boolean,
  mapTypeControl: boolean,
  scaleControl: boolean,
  streetViewControl: boolean,
  rotateControl: boolean,
  fullscreenControl: boolean
}

अगर मैप का साइज़ 200x200 पिक्सल से छोटा है, तो डिफ़ॉल्ट रूप से सभी कंट्रोल गायब हो जाते हैं. इस व्यवहार को बदला जा सकता है. इसके लिए, कंट्रोल को साफ़ तौर पर दिखने के लिए सेट करें. उदाहरण के लिए, नीचे दी गई टेबल से पता चलता है कि मैप के साइज़ और zoomControl फ़ील्ड की सेटिंग के आधार पर, ज़ूम कंट्रोल दिख रहा है या नहीं:

मैप आकार zoomControl क्या यह दिख रहा है?
कोई भी false नहीं
कोई भी true हां
>= 200x200 पिक्सल undefined हां
< 200x200 पिक्सल undefined नहीं

इस उदाहरण में, मैप को ज़ूम कंट्रोल छिपाने और स्केल कंट्रोल दिखाने के लिए सेट किया गया है. ध्यान दें कि हम डिफ़ॉल्ट यूज़र इंटरफ़ेस को साफ़ तौर पर बंद नहीं करते. इसलिए, ये बदलाव डिफ़ॉल्ट यूज़र इंटरफ़ेस के व्यवहार में जोड़े जाते हैं.

TypeScript

function initMap(): void {
  const map = new google.maps.Map(
    document.getElementById("map") as HTMLElement,
    {
      zoom: 4,
      center: { lat: -33, lng: 151 },
      zoomControl: false,
      scaleControl: true,
    }
  );
}

declare global {
  interface Window {
    initMap: () => void;
  }
}
window.initMap = initMap;

JavaScript

function initMap() {
  const map = new google.maps.Map(document.getElementById("map"), {
    zoom: 4,
    center: { lat: -33, lng: 151 },
    zoomControl: false,
    scaleControl: true,
  });
}

window.initMap = initMap;
उदाहरण देखें

सैंपल आज़माएं

कंट्रोल करने के विकल्प

कई कंट्रोल कॉन्फ़िगर किए जा सकते हैं. इससे, उनके काम करने के तरीके या दिखने के तरीके में बदलाव किया जा सकता है. उदाहरण के लिए, मैप टाइप कंट्रोल, हॉरिज़ॉन्टल बार या ड्रॉप-डाउन मेन्यू के तौर पर दिख सकता है.

मैप बनाने के बाद, MapOptions ऑब्जेक्ट में मौजूद कंट्रोल के सही विकल्प फ़ील्ड में बदलाव करके, इन कंट्रोल में बदलाव किया जाता है.

उदाहरण के लिए, मैप टाइप कंट्रोल में बदलाव करने के विकल्प, mapTypeControlOptions फ़ील्ड में दिखाए जाते हैं. मैप टाइप कंट्रोल, इनमें से किसी एक style विकल्प में दिख सकता है:

  • google.maps.MapTypeControlStyle.HORIZONTAL_BAR, कंट्रोल के ऐरे को हॉरिज़ॉन्टल बार में बटन के तौर पर दिखाता है, जैसा कि Google Maps पर दिखाया गया है.
  • google.maps.MapTypeControlStyle.DROPDOWN_MENU एक बटन वाला कंट्रोल दिखाता है. इससे ड्रॉप-डाउन मेन्यू का इस्तेमाल करके, मैप का टाइप चुना जा सकता है.
  • google.maps.MapTypeControlStyle.DEFAULT, स्क्रीन के साइज़ के हिसाब से डिफ़ॉल्ट तरीके से काम करता है. यह तरीका, एपीआई के आने वाले वर्शन में बदल सकता है.

ध्यान दें कि अगर आपने कंट्रोल के किसी विकल्प में बदलाव किया है, तो आपको MapOptions की सही वैल्यू को true पर सेट करके, कंट्रोल को साफ़ तौर पर चालू करना चाहिए. उदाहरण के लिए, DROPDOWN_MENU स्टाइल दिखाने के लिए मैप टाइप कंट्रोल सेट करने के लिए, MapOptions ऑब्जेक्ट में यह कोड इस्तेमाल करें:

  ...
  mapTypeControl: true,
  mapTypeControlOptions: {
    style: google.maps.MapTypeControlStyle.DROPDOWN_MENU
  }
  ...

नीचे दिए गए उदाहरण में, कंट्रोल की डिफ़ॉल्ट पोज़िशन और स्टाइल बदलने का तरीका बताया गया है.

TypeScript

// You can set control options to change the default position or style of many
// of the map controls.

function initMap(): void {
  const map = new google.maps.Map(
    document.getElementById("map") as HTMLElement,
    {
      zoom: 4,
      center: { lat: -33, lng: 151 },
      mapTypeControl: true,
      mapTypeControlOptions: {
        style: google.maps.MapTypeControlStyle.DROPDOWN_MENU,
        mapTypeIds: ["roadmap", "terrain"],
      },
    }
  );
}

declare global {
  interface Window {
    initMap: () => void;
  }
}
window.initMap = initMap;

JavaScript

// You can set control options to change the default position or style of many
// of the map controls.
function initMap() {
  const map = new google.maps.Map(document.getElementById("map"), {
    zoom: 4,
    center: { lat: -33, lng: 151 },
    mapTypeControl: true,
    mapTypeControlOptions: {
      style: google.maps.MapTypeControlStyle.DROPDOWN_MENU,
      mapTypeIds: ["roadmap", "terrain"],
    },
  });
}

window.initMap = initMap;
उदाहरण देखें

सैंपल आज़माएं

आम तौर पर, मैप बनाने के बाद कंट्रोल कॉन्फ़िगर किए जाते हैं. हालांकि, Map के setOptions() तरीके को कॉल करके, कंट्रोल के नए विकल्पों को पास करके, कंट्रोल के प्रज़ेंटेशन में डाइनैमिक तौर पर बदलाव किया जा सकता है.

कंट्रोल में बदलाव करना

मैप के MapOptions ऑब्जेक्ट में मौजूद फ़ील्ड की मदद से मैप बनाते समय, कंट्रोल के प्रज़ेंटेशन की जानकारी दी जाती है. इन फ़ील्ड के बारे में यहां बताया गया है:

  • zoomControl, ज़ूम कंट्रोल को चालू या बंद करता है. डिफ़ॉल्ट रूप से, यह कंट्रोल दिखता है और मैप के सबसे नीचे दाईं ओर दिखता है. zoomControlOptions फ़ील्ड से, इस कंट्रोल के लिए इस्तेमाल किए जाने वाले ZoomControlOptions के बारे में भी पता चलता है.
  • cameraControl कैमरे के कंट्रोल को चालू/बंद करता है. यह कंट्रोल, बीटा चैनल का इस्तेमाल करने वाले मैप पर डिफ़ॉल्ट रूप से दिखता है. cameraControlOptions फ़ील्ड से यह भी पता चलता है कि इस कंट्रोल के लिए, CameraControlOptions का इस्तेमाल करना है.
  • mapTypeControl, मैप टाइप कंट्रोल को चालू/बंद करता है इससे उपयोगकर्ता, मैप टाइप (जैसे, मैप और सैटलाइट) के बीच टॉगल कर सकता है. डिफ़ॉल्ट रूप से, यह कंट्रोल दिखता है और यह मैप के सबसे ऊपर बाएं कोने में दिखता है. mapTypeControlOptions फ़ील्ड, इस कंट्रोल के लिए इस्तेमाल किए जाने वाले MapTypeControlOptions के बारे में भी बताता है.
  • streetViewControl, पेगमैन कंट्रोल को चालू/बंद करता है जिससे उपयोगकर्ता Street View पैनोरमा को चालू कर सकता है. डिफ़ॉल्ट रूप से, यह कंट्रोल दिखता है और यह मैप के सबसे नीचे दाईं ओर दिखता है. streetViewControlOptions फ़ील्ड, इस कंट्रोल के लिए इस्तेमाल किए जाने वाले StreetViewControlOptions के बारे में भी बताता है.
  • rotateControl, 45° के ओरिएंटेशन वाली इमेज को कंट्रोल करने के लिए, रोटेट कंट्रोल को चालू/बंद करता है. डिफ़ॉल्ट रूप से, कंट्रोल की मौजूदगी का पता, मौजूदा ज़ूम और जगह पर दिए गए मैप टाइप के लिए, 45° वाली इमेज के मौजूद होने या न होने से चलता है. मैप के rotateControlOptions को सेट करके, कंट्रोल के व्यवहार में बदलाव किया जा सकता है. इससे, इस्तेमाल किए जाने वाले RotateControlOptions की जानकारी मिलती है. अगर 45° वाली कोई इमेज उपलब्ध नहीं है, तो कंट्रोल नहीं दिखेगा.
  • scaleControl, स्केल कंट्रोल को चालू/बंद करता है. इससे मैप का स्केल पता चलता है. डिफ़ॉल्ट रूप से, यह कंट्रोल नहीं दिखता. चालू होने पर, यह हमेशा मैप के सबसे नीचे दाएं कोने में दिखेगा. scaleControlOptions, इस कंट्रोल के लिए इस्तेमाल किए जाने वाले ScaleControlOptions के बारे में भी बताता है.
  • fullscreenControl, मैप को फ़ुलस्क्रीन मोड में खोलने वाले कंट्रोल को चालू/बंद करता है. यह कंट्रोल, डिफ़ॉल्ट रूप से डेस्कटॉप और Android डिवाइसों पर चालू होता है. चालू होने पर, यह कंट्रोल मैप के सबसे ऊपर दाईं ओर दिखता है. fullscreenControlOptions, इस कंट्रोल के लिए इस्तेमाल किए जाने वाले FullscreenControlOptions के बारे में भी बताता है.

ध्यान दें कि शुरुआत में बंद किए गए कंट्रोल के लिए, विकल्प तय किए जा सकते हैं.

कंट्रोल पोज़िशनिंग

कंट्रोल के ज़्यादातर विकल्पों में एक position प्रॉपर्टी (ControlPosition टाइप की) होती है. इससे पता चलता है कि कंट्रोल को मैप पर कहां रखना है. इन कंट्रोल की पोज़िशन तय नहीं होती. इसके बजाय, एपीआई कंट्रोल को बेहतर तरीके से व्यवस्थित करेगा. इसके लिए, वह उन्हें मैप के मौजूदा एलिमेंट या अन्य कंट्रोल के आस-पास, तय सीमाओं (जैसे कि मैप का साइज़) के हिसाब से फ़्लो करेगा.

ध्यान दें: इस बात की कोई गारंटी नहीं दी जा सकती कि मुश्किल लेआउट के लिए, कंट्रोल ओवरलैप न हों. हालांकि, एपीआई उन्हें बेहतर तरीके से व्यवस्थित करने की कोशिश करेगा.

कंट्रोल की ये पोज़िशन इस्तेमाल की जा सकती हैं:

  • TOP_CENTER से पता चलता है कि कंट्रोल को मैप के सबसे ऊपरी हिस्से में, बिल्कुल बीच में रखा जाना चाहिए.
  • TOP_LEFT से पता चलता है कि कंट्रोल को मैप के सबसे ऊपर बाईं ओर रखा जाना चाहिए. साथ ही, कंट्रोल के किसी भी सब-एलिमेंट को सबसे ऊपर बीच में "फ़्लो" किया जाना चाहिए.
  • TOP_RIGHT से पता चलता है कि कंट्रोल को मैप के सबसे ऊपर दाईं ओर रखा जाना चाहिए. साथ ही, कंट्रोल के किसी भी सब-एलिमेंट को सबसे ऊपर बीच में "फ़्लो" किया जाना चाहिए.
  • LEFT_TOP से पता चलता है कि कंट्रोल को मैप के सबसे ऊपर बाईं ओर, लेकिन किसी भी TOP_LEFT एलिमेंट के नीचे रखा जाना चाहिए.
  • RIGHT_TOP से पता चलता है कि कंट्रोल को मैप के सबसे ऊपर दाईं ओर, TOP_RIGHT एलिमेंट के नीचे रखा जाना चाहिए.
  • LEFT_CENTER से पता चलता है कि कंट्रोल को मैप की बाईं ओर, TOP_LEFT और BOTTOM_LEFT के बीच में रखा जाना चाहिए.
  • RIGHT_CENTER से पता चलता है कि कंट्रोल को मैप की दाईं ओर, TOP_RIGHT और BOTTOM_RIGHT के बीच के सेंटर में रखा जाना चाहिए.
  • LEFT_BOTTOM से पता चलता है कि कंट्रोल को मैप के सबसे नीचे बाईं ओर, लेकिन किसी भी BOTTOM_LEFT एलिमेंट के ऊपर रखा जाना चाहिए.
  • RIGHT_BOTTOM से पता चलता है कि कंट्रोल को मैप के सबसे नीचे दाईं ओर, लेकिन किसी भी BOTTOM_RIGHT एलिमेंट के ऊपर रखा जाना चाहिए.
  • BOTTOM_CENTER से पता चलता है कि कंट्रोल को मैप के सबसे नीचे, बीच में रखा जाना चाहिए.
  • BOTTOM_LEFT से पता चलता है कि कंट्रोल को मैप के सबसे नीचे बाईं ओर रखा जाना चाहिए. साथ ही, कंट्रोल के किसी भी सब-एलिमेंट को सबसे नीचे बीच में "फ़्लो" किया जाना चाहिए.
  • BOTTOM_RIGHT से पता चलता है कि कंट्रोल को मैप के सबसे नीचे दाईं ओर रखा जाना चाहिए. साथ ही, कंट्रोल के किसी भी सब-एलिमेंट को सबसे नीचे बीच में "फ़्लो" किया जाना चाहिए.

ध्यान दें कि ये पोज़िशन, यूज़र इंटरफ़ेस (यूआई) के उन एलिमेंट की पोज़िशन से मेल खा सकती हैं जिनके प्लेसमेंट में बदलाव नहीं किया जा सकता. जैसे, कॉपीराइट और 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> एलिमेंट में रखें, ताकि आप अपने कंट्रोल को एक यूनिट के तौर पर मैनेज कर सकें. हम इस डिज़ाइन पैटर्न का इस्तेमाल, नीचे दिए गए सैंपल में करेंगे.

आकर्षक कंट्रोल डिज़ाइन करने के लिए, सीएसएस और डीओएम स्ट्रक्चर के बारे में कुछ जानकारी होनी चाहिए. यहां दिया गया कोड, बटन एलिमेंट बनाने के लिए एक फ़ंक्शन दिखाता है. यह फ़ंक्शन, मैप को शिकागो के बीच में दिखाने के लिए पैन करता है.

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;
}

कस्टम कंट्रोल से इवेंट मैनेज करना

किसी कंट्रोल के काम के होने के लिए, यह ज़रूरी है कि वह असल में कुछ करता हो. यह कंट्रोल क्या करता है, यह आपके ऊपर है. कंट्रोल, उपयोगकर्ता के इनपुट पर प्रतिक्रिया दे सकता है या Map की स्थिति में हुए बदलावों पर प्रतिक्रिया दे सकता है.

उपयोगकर्ता के इनपुट का जवाब देने के लिए, addEventListener() का इस्तेमाल करें. यह काम करने वाले डीओएम इवेंट को मैनेज करता है. यहां दिया गया कोड स्निपेट, ब्राउज़र के 'click' इवेंट के लिए एक लिसनर जोड़ता है. ध्यान दें कि यह इवेंट, मैप से नहीं, बल्कि डीओएम से मिलता है.

// 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 एट्रिब्यूट का इस्तेमाल करें.

पोज़िशनिंग के लिए कस्टम कंट्रोल

कस्टम कंट्रोल को मैप पर सही जगह पर रखा जाता है. इसके लिए, उन्हें Map ऑब्जेक्ट की controls प्रॉपर्टी में सही जगह पर रखा जाता है. इस प्रॉपर्टी में, google.maps.ControlPositions का एक कलेक्शन होता है. मैप में कस्टम कंट्रोल जोड़ने के लिए, ControlPosition में Node (आम तौर पर <div>) जोड़ें. (इन पोज़िशन के बारे में जानकारी पाने के लिए, ऊपर पोज़िशन कंट्रोल करना देखें.)

हर ControlPosition, उस पोज़िशन में दिखाए गए कंट्रोल का एक MVCArray सेव करता है. इसलिए, जब कंट्रोल जोड़े जाते हैं या किसी पोज़िशन से हटाए जाते हैं, तो एपीआई उन कंट्रोल को अपडेट कर देगा.

एपीआई, index प्रॉपर्टी के क्रम के हिसाब से हर पोज़िशन पर कंट्रोल डालता है. कम इंडेक्स वाले कंट्रोल पहले डाले जाते हैं. उदाहरण के लिए, BOTTOM_RIGHT पोज़िशन पर मौजूद दो कस्टम कंट्रोल, इस इंडेक्स के क्रम के हिसाब से व्यवस्थित किए जाएंगे. इसमें इंडेक्स की कम वैल्यू को प्राथमिकता दी जाएगी. डिफ़ॉल्ट रूप से, सभी कस्टम कंट्रोल, एपीआई के डिफ़ॉल्ट कंट्रोल डालने के बाद डाले जाते हैं. इस व्यवहार को बदला जा सकता है. इसके लिए, कंट्रोल की index प्रॉपर्टी को नेगेटिव वैल्यू पर सेट करें. पसंद के मुताबिक बनाए गए कंट्रोल, लोगो की बाईं ओर या कॉपीराइट की दाईं ओर नहीं रखे जा सकते.

यहां दिया गया कोड, एक नया कस्टम कंट्रोल बनाता है (इसका कंस्ट्रक्टर नहीं दिखाया गया है) और इसे मैप में TOP_RIGHT पोज़िशन पर जोड़ता है.

var map = new google.maps.Map(document.getElementById('map'), mapOptions);

// 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);

// Add the control to the map at a designated control position
// by pushing it on the position's array. This code will
// implicitly add the control to the DOM, through the Map
// object. You should not attach the control manually.
map.controls[google.maps.ControlPosition.TOP_CENTER].push(centerControlDiv);

कस्टम कंट्रोल का उदाहरण

यहां दिया गया कंट्रोल आसान है (हालांकि, यह खास तौर पर काम का नहीं है). इसमें ऊपर दिखाए गए पैटर्न को जोड़ा गया है. यह कंट्रोल, मैप को किसी डिफ़ॉल्ट जगह पर केंद्रित करके, 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 map: google.maps.Map;

const chicago: google.maps.LatLngLiteral = { lat: 41.85, lng: -87.65 };

/**
 * The CenterControl adds a control to the map that recenters the map on
 * Chicago.
 */
class CenterControl {
  private map_: google.maps.Map;
  private center_: google.maps.LatLng;
  constructor(
    controlDiv: HTMLElement,
    map: google.maps.Map,
    center: google.maps.LatLngLiteral
  ) {
    this.map_ = map;
    // Set the center property upon construction
    this.center_ = new google.maps.LatLng(center);
    controlDiv.style.clear = "both";

    // Set CSS for the control border
    const goCenterUI = document.createElement("button");

    goCenterUI.id = "goCenterUI";
    goCenterUI.title = "Click to recenter the map";
    controlDiv.appendChild(goCenterUI);

    // Set CSS for the control interior
    const goCenterText = document.createElement("div");

    goCenterText.id = "goCenterText";
    goCenterText.innerHTML = "Center Map";
    goCenterUI.appendChild(goCenterText);

    // Set CSS for the setCenter control border
    const setCenterUI = document.createElement("button");

    setCenterUI.id = "setCenterUI";
    setCenterUI.title = "Click to change the center of the map";
    controlDiv.appendChild(setCenterUI);

    // Set CSS for the control interior
    const setCenterText = document.createElement("div");

    setCenterText.id = "setCenterText";
    setCenterText.innerHTML = "Set Center";
    setCenterUI.appendChild(setCenterText);

    // Set up the click event listener for 'Center Map': Set the center of
    // the map
    // to the current center of the control.
    goCenterUI.addEventListener("click", () => {
      const currentCenter = this.center_;

      this.map_.setCenter(currentCenter);
    });

    // Set up the click event listener for 'Set Center': Set the center of
    // the control to the current center of the map.
    setCenterUI.addEventListener("click", () => {
      const newCenter = this.map_.getCenter()!;

      if (newCenter) {
        this.center_ = newCenter;
      }
    });
  }
}

function initMap(): void {
  map = new google.maps.Map(document.getElementById("map") as HTMLElement, {
    zoom: 12,
    center: chicago,
  });

  // Create the DIV to hold the control and call the CenterControl()
  // constructor passing in this DIV.
  const centerControlDiv = document.createElement("div");
  const control = new CenterControl(centerControlDiv, map, chicago);

  // @ts-ignore
  centerControlDiv.index = 1;
  centerControlDiv.style.paddingTop = "10px";
  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 };

/**
 * The CenterControl adds a control to the map that recenters the map on
 * Chicago.
 */
class CenterControl {
  map_;
  center_;
  constructor(controlDiv, map, center) {
    this.map_ = map;
    // Set the center property upon construction
    this.center_ = new google.maps.LatLng(center);
    controlDiv.style.clear = "both";

    // Set CSS for the control border
    const goCenterUI = document.createElement("button");

    goCenterUI.id = "goCenterUI";
    goCenterUI.title = "Click to recenter the map";
    controlDiv.appendChild(goCenterUI);

    // Set CSS for the control interior
    const goCenterText = document.createElement("div");

    goCenterText.id = "goCenterText";
    goCenterText.innerHTML = "Center Map";
    goCenterUI.appendChild(goCenterText);

    // Set CSS for the setCenter control border
    const setCenterUI = document.createElement("button");

    setCenterUI.id = "setCenterUI";
    setCenterUI.title = "Click to change the center of the map";
    controlDiv.appendChild(setCenterUI);

    // Set CSS for the control interior
    const setCenterText = document.createElement("div");

    setCenterText.id = "setCenterText";
    setCenterText.innerHTML = "Set Center";
    setCenterUI.appendChild(setCenterText);
    // Set up the click event listener for 'Center Map': Set the center of
    // the map
    // to the current center of the control.
    goCenterUI.addEventListener("click", () => {
      const currentCenter = this.center_;

      this.map_.setCenter(currentCenter);
    });
    // Set up the click event listener for 'Set Center': Set the center of
    // the control to the current center of the map.
    setCenterUI.addEventListener("click", () => {
      const newCenter = this.map_.getCenter();

      if (newCenter) {
        this.center_ = newCenter;
      }
    });
  }
}

function initMap() {
  map = new google.maps.Map(document.getElementById("map"), {
    zoom: 12,
    center: chicago,
  });

  // Create the DIV to hold the control and call the CenterControl()
  // constructor passing in this DIV.
  const centerControlDiv = document.createElement("div");
  const control = new CenterControl(centerControlDiv, map, chicago);

  // @ts-ignore
  centerControlDiv.index = 1;
  centerControlDiv.style.paddingTop = "10px";
  map.controls[google.maps.ControlPosition.TOP_CENTER].push(centerControlDiv);
}

window.initMap = initMap;
उदाहरण देखें

सैंपल आज़माएं