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

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

खास जानकारी

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

डिफ़ॉल्ट सेटिंग

यहां दिया गया मैप, मैप के साथ इंटरैक्शन के लिए डिफ़ॉल्ट सेटिंग दिखाता है. इसे सिर्फ़ zoom और center विकल्प तय करके इंस्टैंशिएट किया गया है.

इस मैप का कोड यहां दिया गया है.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
});

जेस्चर हैंडलिंग को कंट्रोल करना

जब कोई उपयोगकर्ता, मैप वाले पेज को स्क्रोल करता है, तो स्क्रोल करने की कार्रवाई से अनजाने में मैप ज़ूम हो सकता है. gestureHandling मैप विकल्प का इस्तेमाल करके, इस सेटिंग को कंट्रोल किया जा सकता है.

gestureHandling: cooperative

यहां दिए गए मैप में, gestureHandling विकल्प को cooperative पर सेट किया गया है. इससे उपयोगकर्ता, मैप को ज़ूम या पैन किए बिना, पेज को सामान्य तरीके से स्क्रोल कर सकता है. उपयोगकर्ता, ज़ूम कंट्रोल पर क्लिक करके मैप को ज़ूम कर सकते हैं. टचस्क्रीन वाले डिवाइसों के लिए, वे मैप पर दो उंगलियों से मूवमेंट करके भी ज़ूम और पैन कर सकते हैं.

इस मैप का कोड यहां दिया गया है.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
  gestureHandling: "cooperative",
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
  gestureHandling: "cooperative",
});

सैंपल देखें

gestureHandling: auto

पेज पर सबसे ऊपर मौजूद मैप में gestureHandling विकल्प नहीं है. इसलिए, इसका व्यवहार, gestureHandling को cooperative पर सेट करके बनाए गए पिछले मैप जैसा ही है. इसकी वजह यह है कि इस पेज पर मौजूद सभी मैप, <iframe> में हैं. gestureHandling की डिफ़ॉल्ट वैल्यू auto, greedy और cooperative के बीच स्विच करती है. यह इस बात पर निर्भर करता है कि मैप, <iframe> में है या नहीं.

मैप, <iframe> में है व्यवहार
हां cooperative
नहीं greedy

gestureHandling: greedy

यहां gestureHandling को greedy पर सेट करके बनाया गया मैप दिया गया है. यह मैप, cooperative के उलट, सभी टच जेस्चर और स्क्रोल इवेंट पर प्रतिक्रिया करता है.

gestureHandling: none

gestureHandling विकल्प को none पर भी सेट किया जा सकता है. इससे मैप पर जेस्चर की सुविधा बंद हो जाती है.

पैन और ज़ूम करने की सुविधा बंद करना

मैप को पैन और ज़ूम करने की सुविधा पूरी तरह से बंद करने के लिए, दो विकल्प, gestureHandling और zoomControl, शामिल किए जाने चाहिए.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
  gestureHandling: "none",
  zoomControl: false,
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
  gestureHandling: "none",
  zoomControl: false,
});

यहां दिए गए मैप में, ऊपर दिए गए कोड में gestureHandling और zoomControl के कॉम्बिनेशन को दिखाया गया है.

मैप की सीमाओं और ज़ूम करने की सुविधा को सीमित करना

ऐसा हो सकता है कि आपको जेस्चर और ज़ूम कंट्रोल की अनुमति देनी हो, लेकिन मैप को किसी खास सीमा या कम से कम और ज़्यादा से ज़्यादा ज़ूम तक सीमित रखना हो. ऐसा करने के लिए, आप restriction, minZoom, और maxZoom विकल्प सेट कर सकते हैं. यहां दिए गए कोड और मैप में, इन विकल्पों को दिखाया गया है.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
  minZoom: zoom - 3,
  maxZoom: zoom + 3,
  restriction: {
    latLngBounds: {
      north: -10,
      south: -40,
      east: 160,
      west: 100,
    },
  },
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
  minZoom: zoom - 3,
  maxZoom: zoom + 3,
  restriction: {
    latLngBounds: {
      north: -10,
      south: -40,
      east: 160,
      west: 100,
    },
  },
});