डी 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. में विभिन्न अनुरोध एपीआई पर चर्चा करेंगे।