D3.js - एसवीजी का परिचय

एसवीजी का मतलब है Scalable Vector Graphics। एसवीजी एक XML- आधारित वेक्टर ग्राफिक्स प्रारूप है। यह लाइन्स, रेक्टैंगल्स, सर्कल्स, एलिप्स इत्यादि विभिन्न आकृतियों को आकर्षित करने के लिए विकल्प प्रदान करता है। इसलिए, SVG के साथ विज़ुअलाइज़ेशन को डिजाइन करने से आपको अधिक शक्ति और लचीलापन मिलता है।

एसवीजी की विशेषताएं

एसवीजी की कुछ मुख्य विशेषताएं इस प्रकार हैं -

  • एसवीजी एक वेक्टर आधारित छवि प्रारूप है और यह पाठ-आधारित है।
  • SVG HTML की संरचना में समान है।
  • एसवीजी को एक के रूप में दर्शाया जा सकता है Document object model
  • एसवीजी गुणों को विशेषताओं के रूप में निर्दिष्ट किया जा सकता है।
  • एसवीजी की उत्पत्ति (0, 0) के सापेक्ष पूर्ण स्थिति होनी चाहिए।
  • एसवीजी को HTML दस्तावेज़ में शामिल किया जा सकता है।

एक न्यूनतम उदाहरण

आइए हम एक न्यूनतम एसवीजी छवि बनाएं और इसे HTML दस्तावेज़ में शामिल करें।

Step 1 - एक एसवीजी छवि बनाएं और चौड़ाई को 300 पिक्सेल और ऊंचाई को 300 पिक्सेल के रूप में सेट करें।

<svg width = "300" height = "300">

</svg>

यहां ही svgटैग में एक एसवीजी छवि शुरू होती है और इसमें विशेषताओं के रूप में चौड़ाई और ऊंचाई होती है। एसवीजी प्रारूप की डिफ़ॉल्ट इकाई हैpixel

Step 2 - (100, 100) से शुरू होने वाली रेखा बनाएं और (200, 100) पर समाप्त होकर रेखा के लिए लाल रंग निर्धारित करें।

<line x1 = "100" y1 = "100" x2 = "200" y2 = "200" 
   style = "stroke:rgb(255,0,0);stroke-width:2"/>

यहां ही line टैग एक रेखा और उसकी विशेषताएँ खींचता है x1, y1 प्रारंभिक बिंदु को संदर्भित करता है और x2, y2अंत बिंदु को संदर्भित करता है। शैली विशेषता रंग और लाइन की मोटाई का उपयोग करती हैstroke और यह stroke-width शैलियों।

  • x1 - यह पहले बिंदु का x- समन्वय है।

  • y1 - यह पहले बिंदु का y- समन्वय है।

  • x2 - यह दूसरे बिंदु का x- समन्वय है।

  • y2 - यह दूसरे बिंदु का y- समन्वय है।

  • stroke - लाइन का रंग।

  • stroke-width - लाइन की मोटाई।

Step 3 - एक HTML दस्तावेज़, “svg_line.html” बनाएँ और उपरोक्त एसवीजी को एकीकृत करें जैसा कि नीचे दिखाया गया है -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         body { font-family: Arial; }
      </style>
   </head>

   <body>
      <div id = "svgcontainer">
         <svg width = "300" height = "300">
            <line x1 = "100" y1 = "100" 
               x2 = "200" y2 = "200" style = "stroke:rgb(255,0,0);
               stroke-width:2"/>
         </svg>
      </div>
      <p></p>
      <p></p>
   </body>
</html>

उपरोक्त कार्यक्रम निम्नलिखित परिणाम देगा।

SVG D3.js का उपयोग करना

D3.js का उपयोग करके SVG बनाने के लिए, नीचे दिए गए चरणों का पालन करें।

Step 1 - एसवीजी छवि को रखने के लिए एक कंटेनर बनाएं जैसा कि नीचे दिया गया है।

<div id = "svgcontainer"></div>

Step 2- एसवीजी कंटेनर सिलेक्ट () मेथड का इस्तेमाल करके सिलेक्ट करें और एपेंड () मेथड के जरिए एसवीजी एलिमेंट को इंजेक्ट करें। एट्री () और स्टाइल () विधियों का उपयोग करके विशेषताओं और शैलियों को जोड़ें।

var width = 300;
var height = 300;
var svg = d3.select("#svgcontainer")
   .append("svg").attr("width", width).attr("height", height);

Step 3 - इसी तरह, जोड़ें line अंदर का तत्व svg तत्व जैसा कि नीचे दिखाया गया है।

svg.append("line")
   .attr("x1", 100)
   .attr("y1", 100)
   .attr("x2", 200) 
   .attr("y2", 200)
   .style("stroke", "rgb(255,0,0)")
   .style("stroke-width", 2);

पूरा कोड इस प्रकार है -

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
      <style>
         body { font-family: Arial; }
      </style>
   </head>

   <body>
      <div id = "svgcontainer">
      </div>
      <script language = "javascript">
         var width = 300;
         var height = 300;
         var svg = d3.select("#svgcontainer")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         svg.append("line")
            .attr("x1", 100)
            .attr("y1", 100)
            .attr("x2", 200)
            .attr("y2", 200)
            .style("stroke", "rgb(255,0,0)")
            .style("stroke-width", 2);
      </script>
   </body>
</html>

उपरोक्त कोड निम्न परिणाम देता है।

आयत तत्व

एक आयत द्वारा दर्शाया गया है <rect> नीचे दिखाए अनुसार टैग।

<rect x = "20" y = "20" width = "300" height = "300"></rect>

आयत की विशेषताएँ इस प्रकार हैं -

  • x - यह आयत के ऊपरी-बाएँ कोने का x- समन्वय है।

  • y - यह आयत के ऊपरी-बाएँ कोने का y-निर्देशांक है।

  • width - यह आयत की चौड़ाई को दर्शाता है।

  • height - यह आयत की ऊंचाई को दर्शाता है।

एसवीजी में एक सरल आयत को नीचे समझाया गया है।

<svg width = "300" height = "300">
   <rect x = "20" y = "20" width = "300" height = "300" fill = "green"></rect>
</svg>

उसी आयत को नीचे वर्णित रूप से गतिशील रूप से बनाया जा सकता है।

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div id = "svgcontainer"></div>
      <script>
         var width = 300;
         var height = 300;
         //Create SVG element
         var svg = d3.select("#svgcontainer")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         //Create and append rectangle element
         svg.append("rect")
            .attr("x", 20)
            .attr("y", 20)
            .attr("width", 200)
            .attr("height", 100)
            .attr("fill", "green");
      </script>
   </body>
</html>

उपरोक्त कोड निम्नलिखित परिणाम देगा।

वृत्त तत्व

एक सर्कल द्वारा दर्शाया गया है <circle> नीचे दिए गए अनुसार टैग।

<circle cx = "200" cy = "50" r = "20"/>

सर्कल की विशेषताएं इस प्रकार हैं -

  • cx - यह वृत्त के केंद्र का x- समन्वय है।

  • cy - यह वृत्त के केंद्र का y- समन्वय है।

  • r - यह वृत्त की त्रिज्या को दर्शाता है।

एसवीजी में एक सरल चक्र नीचे वर्णित है।

<svg width = "300" height = "300">
   <circle cx = "200" cy = "50" r = "20" fill = "green"/>
</svg>

उसी सर्कल को गतिशील रूप से बनाया जा सकता है जैसा कि नीचे वर्णित है।

<!DOCTYPE html>
<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div id = "svgcontainer"></div>
      <script>
         var width = 300;
         var height = 300;
         //Create SVG element
         var svg = d3.select("#svgcontainer")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         //Append circle 
         svg.append("circle")
            .attr("cx", 200)
            .attr("cy", 50)
            .attr("r", 20)
            .attr("fill", "green");
      </script>
   </body>
</html>

उपरोक्त कोड निम्नलिखित परिणाम देगा।

दीर्घवृत्त तत्व

एसवीजी एलिप्से तत्व का प्रतिनिधित्व करता है <ellipse> नीचे दिए गए अनुसार टैग।

<ellipse cx = "200" cy = "50" rx = "100" ry = "50"/>

एक दीर्घवृत्त की विशेषताएं इस प्रकार हैं -

  • cx - यह दीर्घवृत्त के केंद्र का x- समन्वय है।

  • cy - यह दीर्घवृत्त के केंद्र का y- समन्वय है।

  • rx - यह वृत्त का x त्रिज्या है।

  • ry - यह वृत्त का y त्रिज्या है।

एसवीजी में एक सरल दीर्घवृत्त नीचे वर्णित है।

<svg width = "300" height = "300">
   <ellipse cx = "200" cy = "50" rx = "100" ry = "50" fill = "green" />
</svg>

उसी दीर्घवृत्त को गतिशील रूप से नीचे बनाया जा सकता है,

<html>
   <head>
      <script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
   </head>

   <body>
      <div id = "svgcontainer"></div>
      <script>
         var width = 300;
         var height = 300;
         var svg = d3.select("#svgcontainer")
            .append("svg")
            .attr("width", width)
            .attr("height", height);
         svg.append("ellipse")
            .attr("cx", 200)
            .attr("cy", 50)
            .attr("rx", 100)
            .attr("ry", 50)
            .attr("fill", "green")
      </script>
   </body>
</html>

उपरोक्त कोड निम्नलिखित परिणाम देगा।