D3.js - एपीआई खींच रहा है
खींचें और ड्रॉप d3.js. में सबसे परिचित अवधारणा में से एक है यह अध्याय विस्तार से और इसके तरीकों को विस्तार से बताता है।
इंस्टालेशन
हम निम्नलिखित स्क्रिप्ट का उपयोग करके सीधे एपीआई को खींच सकते हैं।
<script src = "https://d3js.org/d3-dispatch.v1.min.js"></script>
<script src = "https://d3js.org/d3-selection.v1.min.js"></script>
<script src = "https://d3js.org/d3-drag.v1.min.js"></script>
एपीआई तरीकों को खींचना
D3.js. में सबसे महत्वपूर्ण ड्रैगिंग एपीआई विधियों में से कुछ निम्नलिखित हैं
- d3.drag()
- drag(selection)
- drag.container([container])
- drag.filter([filter])
- drag.subject([subject])
- drag.clickDistance([distance])
- ड्रैग.ऑन (टाइपनेम, [श्रोता])
- d3.dragDisable(window)
- d3.dragEnable (विंडो [, noclick])
आइए अब हम इनमें से प्रत्येक को विस्तार से समझते हैं।
d3.drag ()
इस विधि का उपयोग एक नया खींचने के लिए किया जाता है। आप निम्न स्क्रिप्ट का उपयोग करके इस विधि को कॉल कर सकते हैं।
<script>
var drag = d3.drag();
</script>
खींचें (चयन)
इस पद्धति का उपयोग निर्दिष्ट चयन में ड्रैगिंग को लागू करने के लिए किया जाता है। आप इस फ़ंक्शन का उपयोग करके आह्वान कर सकते हैंselection.call। एक सरल उदाहरण नीचे परिभाषित किया गया है।
d3.select(".node").call(d3.drag().on("drag", mousemove));
यहां, चयनित तत्वों पर लागू ड्रैग व्यवहार चयन के माध्यम से है।
drag.container([container])
इसका उपयोग कंटेनर को खींचने के लिए निर्दिष्ट फ़ंक्शन में सेट करने के लिए किया जाता है। यदि कंटेनर निर्दिष्ट नहीं है, तो यह वर्तमान एक्सेसर को लौटाता है। कैनवस के साथ किसी भी ग्राफिकल तत्वों को खींचने के लिए, आप कंटेनर को खुद को फिर से परिभाषित कर सकते हैं। इसे नीचे परिभाषित किया गया है।
function container() {
return this;
}
drag.filter ([फिल्टर])
इसका उपयोग निर्दिष्ट फ़ंक्शन के लिए फ़िल्टर सेट करने के लिए किया जाता है। यदि फ़िल्टर निर्दिष्ट नहीं है, तो यह वर्तमान फ़िल्टर को नीचे परिभाषित के रूप में लौटाता है।
function filter() {
return !d3.event.button;
}
drag.subject ([विषय])
यह विषय को खींचने के लिए निर्दिष्ट फ़ंक्शन पर सेट करने के लिए उपयोग किया जाता है और नीचे परिभाषित किया गया है।
function subject(d) {
return d = = null ? {x: d3.event.x, y: d3.event.y} : d;
}
यहाँ, विषय वस्तु को खींचे जाने का प्रतिनिधित्व करता है। उदाहरण के लिए, यदि आप एसवीजी में आयत तत्वों को खींचना चाहते हैं, तो डिफ़ॉल्ट विषय आयत को घसीटे जाने का प्रमाण है।
drag.clickDistance ([दूरी])
इस विधि का उपयोग मूसडाउन और माउसअप ईवेंट को क्लिक करने के लिए अधिकतम दूरी तय करने के लिए किया जाता है। यदि दूरी निर्दिष्ट नहीं है, तो यह शून्य की ओर इशारा करता है।
ड्रैग.ऑन (टाइपनेम, [श्रोता])
इस विधि का उपयोग ड्रैगिंग के लिए निर्दिष्ट टाइपनेम के लिए ईवेंट श्रोता को सेट करने के लिए किया जाता है। टाइपनेम एक स्ट्रिंग है जिसमें व्हॉट्सएप द्वारा अलग किए गए एक या अधिक टाइपनाम होते हैं। प्रत्येक टाइपनेम एक प्रकार है, वैकल्पिक रूप से एक अवधि (।) और एक नाम, जैसे कि drag.one और drag.two। यह प्रकार निम्नलिखित में से एक होना चाहिए -
start - एक नया पॉइंटर शुरू करता है।
drag - एक सक्रिय सूचक drags।
end - निष्क्रिय एक सक्रिय सूचक।
d3.dragDisable (विंडो)
इस विधि का उपयोग ड्रैग और ड्रॉप चयन को निष्क्रिय करने के लिए किया जाता है। यह मूसडाउन ईवेंट कार्रवाई को रोकता है। अधिकांश चयनित ब्राउज़र डिफ़ॉल्ट रूप से इस क्रिया का समर्थन करते हैं। यदि समर्थित नहीं है, तो आप CSS प्रॉपर्टी को कोई भी सेट नहीं कर सकते।
d3.dragEnable (विंडो [, noclick])
इस पद्धति का उपयोग निर्दिष्ट विंडो स्थान पर ड्रैग और ड्रॉप चयन को सक्षम करने के लिए किया जाता है। इसका उपयोग माउसअप ईवेंट कार्रवाई को कॉल करने के लिए किया जाता है। यदि आप निर्दिष्ट करते हैं कि noclick मान सत्य है, तो ईवेंट क्लिक करें एक शून्य मिलीसेकंड समय सीमा समाप्त हो रही है।
ड्रैगिंग एपीआई - ड्रैग इवेंट्स
ड्रैग इवेंट सेट करने के लिए D3.event विधि का उपयोग किया जाता है। इसमें निम्नलिखित क्षेत्र शामिल हैं -
Target - यह ड्रैग व्यवहार का प्रतिनिधित्व करता है।
Type - यह एक स्ट्रिंग है और निम्नलिखित में से कोई भी एक हो सकता है- "स्टार्ट", "ड्रैग" या "एंड"।
Subject - खींचें विषय, drag.subject द्वारा परिभाषित किया गया है।
event.on (टाइपनेम, [श्रोता])
इवेंट ऑब्जेक्ट ड्रैगिंग करने के लिए event.on विधि को उजागर करता है। इसे निम्नानुसार परिभाषित किया गया है।
d3.event.on("drag", dragged).on("end", ended);