डी 3.जेएस - ज़ूमिंग एपीआई

ज़ूम करने से आपकी सामग्री को स्केल करने में मदद मिलती है। आप क्लिक-एंड-ड्रैग दृष्टिकोण का उपयोग करके किसी विशेष क्षेत्र पर ध्यान केंद्रित कर सकते हैं। इस अध्याय में, हम ज़ूमिंग एपीआई पर विस्तार से चर्चा करेंगे।

API को कॉन्फ़िगर करना

आप निम्न स्क्रिप्ट का उपयोग करके सीधे “d3js.org” से जूमिंग एपीआई को लोड कर सकते हैं।

<script src = "https://d3js.org/d3-color.v1.min.js"></script>
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-ease.v1.min.js"></script>
<script src = "https://d3js.org/d3-interpolate.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-timer.v1.min.js"></script>
<script src = "https://d3js.org/d3-transition.v1.min.js"></script>
<script src = "https://d3js.org/d3-drag.v1.min.js"></script>
<script src = "https://d3js.org/d3-zoom.v1.min.js"></script>

<body>
   <script>
   </script>
</body>

जूमिंग एपीआई तरीके

निम्नलिखित सबसे अधिक इस्तेमाल की जाने वाली जूमिंग एपीआई विधियों में से कुछ हैं।

  • d3.zoom()
  • zoom(selection)
  • zoom.transform (चयन, परिवर्तन)
  • zoom.translateBy (चयन, x, y)
  • zoom.translateTo (चयन, x, y)
  • zoom.scaleTo (चयन, के)
  • zoom.scaleBy (चयन, के)
  • zoom.filter([filter])
  • zoom.wheelDelta([delta])
  • zoom.extent([extent])
  • zoom.scaleExtent([extent])
  • zoom.translateExtent([extent])
  • zoom.clickDistance([distance])
  • zoom.duration([duration])
  • zoom.interpolate([interpolate])
  • zoom.on (टाइपनेम [श्रोता])

आइए इन सभी ज़ूमिंग एपीआई विधियों को संक्षेप में देखें।

d3.zoom ()

यह एक नया ज़ूम व्यवहार बनाता है। नीचे दी गई स्क्रिप्ट का उपयोग करके हम इसे एक्सेस कर सकते हैं।

<script>
   var zoom = d3.zoom();
</script>

ज़ूम (चयन)

इसका उपयोग चयनित तत्व पर ज़ूम परिवर्तन को लागू करने के लिए किया जाता है। उदाहरण के लिए, आप निम्न सिंटैक्स का उपयोग करके एक mousedown.zoom व्यवहार को तुरंत कर सकते हैं।

selection.call(d3.zoom().on("mousedown.zoom", mousedowned));

zoom.transform (चयन, परिवर्तन)

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

selection.call(zoom.transform, d3.zoomIdentity);

हम निम्नलिखित सिंटैक्स का उपयोग करके 1000 मिलीसेकंड के लिए पहचान परिवर्तन के ज़ूम परिवर्तन को भी रीसेट कर सकते हैं।

selection.transition().duration(1000).call(zoom.transform, d3.zoomIdentity);

zoom.translateBy (चयन, x, y)

इसका उपयोग x और y मानों द्वारा चयनित तत्वों के वर्तमान ज़ूम परिवर्तन का अनुवाद करने के लिए किया जाता है। आप संख्याओं के रूप में या संख्याओं के रूप में x और y अनुवाद मान निर्दिष्ट कर सकते हैं। यदि किसी फ़ंक्शन को चयनित तत्व के लिए आमंत्रित किया जाता है, तो यह DOM के लिए वर्तमान डेटा 'd' और इंडेक्स 'i' से होकर गुजरा है। एक नमूना कोड नीचे परिभाषित किया गया है।

zoom.translateBy(selection, x, y) {
   zoom.transform(selection, function() {
      return constrain(this.__zoom.translate(
         x = = = "function" ? x.apply(this, arguments) : x,
         y = = = "function" ? y.apply(this, arguments) : y
      );
   }
};

zoom.translateTo (चयन, x, y)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ूम परिवर्तन को x और y की निर्दिष्ट स्थिति में अनुवाद करने के लिए किया जाता है।

zoom.scaleTo (चयन, के)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ूम परिवर्तन को स्केल करने के लिए किया जाता है k। यहाँ,k एक स्केल फैक्टर है, जो संख्याओं या कार्यों के रूप में निर्दिष्ट है।

zoom.scaleTo = function(selection, k) {
   zoom.transform(selection, function() {
      k = = = "function" ? k.apply(this, arguments) : k;
   });
};

zoom.scaleBy (चयन, के)

इसका उपयोग चयनित तत्वों के वर्तमान ज़ून परिवर्तन को मापने के लिए किया जाता है k। यहाँ,k एक स्केल फैक्टर है, जो या तो संख्याओं के रूप में या फ़ंक्शंस के रूप में निर्दिष्ट होता है जो नंबर लौटाता है।

zoom.scaleBy = function(selection, k) {
   zoom.scaleTo(selection, function() {
      var k0 = this.__zoom.k,
      k1 = k = = = "function" ? k.apply(this, arguments) : k;
      return k0 * k1;
   });
};

zoom.filter ([फिल्टर])

इसका उपयोग ज़ूम व्यवहार के लिए निर्दिष्ट फ़ंक्शन को फ़िल्टर सेट करने के लिए किया जाता है। यदि फ़िल्टर निर्दिष्ट नहीं है, तो यह नीचे दिखाए अनुसार वर्तमान फ़िल्टर लौटाता है।

function filter() {
   return !d3.event.button;
}

zoom.wheelDelta ([डेल्टा])

का मूल्य Δव्हील डेल्टा फ़ंक्शन द्वारा लौटाया गया है। यदि डेल्टा निर्दिष्ट नहीं है, तो यह वर्तमान पहिया डेल्टा फ़ंक्शन लौटाता है।

zoom.extent ([हद])

इसका उपयोग निर्दिष्ट सरणी बिंदुओं की सीमा निर्धारित करने के लिए किया जाता है। यदि सीमा निर्दिष्ट नहीं है, तो यह वर्तमान सीमा अभिगमकर्ता को लौटाता है, जो कि [[0, 0], [चौड़ाई, ऊंचाई]] में चूक करता है, जहां चौड़ाई तत्व की चौड़ाई है और ऊंचाई इसकी क्लाइंट ऊंचाई है।

zoom.scaleExtent ([हद])

इसका उपयोग पैमाने की निर्दिष्ट संख्या के पैमाने को निर्धारित करने के लिए किया जाता है [k0, k1]। यहाँ,k0न्यूनतम अनुमत पैमाना कारक है। जबकि,k1अधिकतम स्वीकृत पैमाना कारक है। यदि सीमा निर्दिष्ट नहीं है, तो यह वर्तमान पैमाने की सीमा लौटाता है, जो चूक [0,,] के लिए है। नमूना कोड पर विचार करें जो नीचे परिभाषित किया गया है।

selection
   .call(zoom)
   .on("wheel", function() { d3.event.preventDefault(); });

उपयोगकर्ता पहले से ही, जब पैमाने के अनुरूप सीमा पर होता है, तो पहिया करके ज़ूम करने का प्रयास कर सकता है। यदि हम स्केल की परवाह किए बिना व्हील इनपुट पर स्क्रॉल को रोकना चाहते हैं, तो ब्राउज़र डिफ़ॉल्ट व्यवहार को रोकने के लिए व्हील इवेंट श्रोता को पंजीकृत करें।

zoom.translateExtent ([हद])

यदि सीमा निर्दिष्ट है, तो यह अनुवाद की सीमा निर्दिष्ट बिंदुओं तक निर्धारित करता है। यदि सीमा निर्दिष्ट नहीं है, तो यह वर्तमान अनुवाद सीमा को लौटाता है, जो [[-∞, -∞], [+ ∞, + ∞] में चूक करता है।

zoom.clickDistance ([दूरी])

इस पद्धति का उपयोग अधिकतम दूरी निर्धारित करने के लिए किया जाता है, जो ज़ूम करने योग्य क्षेत्र ऊपर और नीचे के बीच स्थानांतरित हो सकता है, जो बाद के क्लिक इवेंट को ट्रिगर करेगा।

zoom.duration ([अवधि])

इस पद्धति का उपयोग डबल-क्लिक पर ज़ूम ट्रांज़िशन के लिए अवधि को सेट करने के लिए किया जाता है और मिलीसेकंड की निर्दिष्ट संख्या पर डबल-टैप करें और ज़ूम व्यवहार लौटाता है। यदि अवधि निर्दिष्ट नहीं है, तो यह वर्तमान अवधि को लौटाता है, जो 250 मिलीसेकंड तक चूक जाता है, जिसे नीचे परिभाषित किया गया है।

selection
   .call(zoom)
   .on("dblclick.zoom", null);

zoom.interpolate ([लगाना])

इस विधि का उपयोग जूम ट्रांज़िशन के लिए निर्दिष्ट फ़ंक्शन के लिए प्रक्षेप करने के लिए किया जाता है। यदि इंटरपोल को निर्दिष्ट नहीं किया गया है, तो यह वर्तमान इंटरपोलेशन फैक्ट्री को लौटाता है, जो d3.interpolateZoom को डिफॉल्ट करता है।

zoom.on (टाइपनेम [श्रोता])

यदि श्रोता निर्दिष्ट किया जाता है, तो यह निर्धारित श्रोता के लिए ईवेंट श्रोता को सेट करता है और ज़ूम व्यवहार लौटाता है। टाइपनेम एक स्ट्रिंग है जिसमें व्हॉट्सएप द्वारा अलग किए गए एक या अधिक टाइपनाम होते हैं। प्रत्येक टाइपनेम एक प्रकार है, वैकल्पिक रूप से एक अवधि (।) और एक नाम, जैसे कि zoom.one और zoom.second। नाम कई श्रोताओं को एक ही प्रकार के लिए पंजीकृत होने की अनुमति देता है। यह प्रकार निम्नलिखित में से एक से होना चाहिए -

  • Start - ज़ूमिंग शुरू होने के बाद (जैसे कि मूसडाउन पर)।

  • Zoom - ज़ूम ट्रांसफ़ॉर्म में बदलाव के बाद (जैसे mousemove पर)।

  • End - ज़ूमिंग समाप्त होने के बाद (जैसे माउसअप पर)।

अगले अध्याय में, हम D3.js. में विभिन्न अनुरोध एपीआई पर चर्चा करेंगे।