डी 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>

अब, ब्राउज़र का अनुरोध करें और हम निम्नलिखित परिणाम देखेंगे।