डी 3.जेएस - पथ एपीआई
राक्टेंगल्स, सर्कल्स, एलिप्स, पॉलीलाइन, पॉलीगॉन, स्ट्रेट लाइन्स और कर्व्स को खींचने के लिए पथ का उपयोग किया जाता है। एसवीजी पथ एक आकृति की रूपरेखा का प्रतिनिधित्व करता है जिसे स्ट्रिप्ड, भरा, क्लिपिंग पथ के रूप में इस्तेमाल किया जा सकता है, या तीनों का कोई संयोजन। यह अध्याय पथ एपीआई के बारे में विस्तार से बताता है।
पथ कॉन्फ़िगर करना
आप नीचे स्क्रिप्ट का उपयोग करके पथ एपीआई को कॉन्फ़िगर कर सकते हैं।
<script src = "https://d3js.org/d3-path.v1.min.js"></script>
<script>
</script>
पथ एपीआई तरीके
कुछ सबसे अधिक इस्तेमाल किए जाने वाले पथ एपीआई तरीकों को संक्षेप में निम्नानुसार वर्णित किया गया है।
d3.path() - इस विधि का उपयोग एक नया रास्ता बनाने के लिए किया जाता है।
path.moveTo(x, y) - इस पद्धति का उपयोग निर्दिष्ट x और y मानों को स्थानांतरित करने के लिए किया जाता है।
path.closePath() - इस विधि का उपयोग वर्तमान पथ को बंद करने के लिए किया जाता है।
path.lineTo(x, y) - इस पद्धति का उपयोग वर्तमान बिंदु से परिभाषित x, y मानों तक की रेखा बनाने के लिए किया जाता है।
path.quadraticCurveTo(cpx, cpy, x, y) - इस पद्धति का उपयोग वर्तमान बिंदु से निर्दिष्ट बिंदु तक द्विघात वक्र को खींचने के लिए किया जाता है।
path.bezierCurveTo(cpx1, cpy1, cpx2, cpy2, x, y) - इस विधि का उपयोग वर्तमान बिंदु से निर्दिष्ट बिंदु तक बीज़ियर वक्र को खींचने के लिए किया जाता है।
path.arcTo(x1, y1, x2, y2, radius) - इस पद्धति का उपयोग वर्तमान बिंदु से एक निर्दिष्ट बिंदु (X1, y1) के लिए एक गोलाकार चाप को खींचने और निर्दिष्ट बिंदुओं (X1, y1) और (x2, y2) के बीच की रेखा को समाप्त करने के लिए किया जाता है।
path.arc(x, y, radius, startAngle, endAngle[, anticlockwise])- इस पद्धति का उपयोग निर्दिष्ट केंद्र (x, y), त्रिज्या, प्रारंभ और अंत में एक परिपत्र चाप को खींचने के लिए किया जाता है। यदि एंटीक्लॉकवाइज वैल्यू सत्य है तो आर्क को एंटिक्लॉकवाइज दिशा में खींचा जाता है, अन्यथा इसे क्लॉकवाइज दिशा में खींचा जाता है।
path.rect(x, y, w, h)- इस विधि का उपयोग केवल चार बिंदुओं (x, y), (x + w, y), (x + w, y + h), (x, y + h) वाले नए उप पथ बनाने के लिए किया जाता है। इन चार बिंदुओं के साथ सीधी रेखाएं जुड़ी होती हैं जो उपपथ को बंद के रूप में चिह्नित करती हैं। संदर्भ के समतुल्य। सही है और एसवीजी के "लिनेटो" कमांड का उपयोग करता है।
path.toString() - एसवीजी के पथ डेटा विनिर्देश के अनुसार इस पथ का स्ट्रिंग प्रतिनिधित्व लौटाता है।
उदाहरण
पथ एपीआई का उपयोग करके डी 3 में एक सरल रेखा बनाते हैं। एक वेबपेज बनाएंlinepath.html और इसमें निम्नलिखित परिवर्तन जोड़ें।
<!DOCTYPE html>
<meta charset = "UTF-8">
<head>
<title>SVG path line Generator</title>
</head>
<style>
path {
fill: green;
stroke: #aaa;
}
</style>
<body>
<svg width = "600" height = "100">
<path transform = "translate(200, 0)" />
</svg>
<script src = "https://d3js.org/d3.v4.min.js"></script>
<script>
var data = [[0, 20], [50, 30], [100, 50], [200, 60], [300, 90]];
var lineGenerator = d3.line();
var pathString = lineGenerator(data);
d3.select('path').attr('d', pathString);
</script>
</body>
</html>
अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित परिणाम देखेंगे।