D3.js - एसवीजी परिवर्तन

एसवीजी एकल एसवीजी आकार तत्व या एसवीजी तत्वों के समूह को बदलने के लिए विकल्प प्रदान करता है। एसवीजी ट्रांसफॉर्म सपोर्ट करता हैTranslate, Scale, Rotate तथा Skew। आइए इस अध्याय में परिवर्तन सीखें।

एसवीजी परिवर्तन का परिचय

एसवीजी एक नई विशेषता का परिचय देता है, transformपरिवर्तन का समर्थन करने के लिए। संभावित मूल्य निम्नलिखित में से एक या अधिक हैं,

  • Translate - यह दो विकल्प लेता है, tx एक्स-अक्ष के साथ अनुवाद को संदर्भित करता है और tyY- अक्ष के साथ अनुवाद को संदर्भित करता है। के लियेExample- अनुवाद (३० ३०)।

  • Rotate - यह तीन विकल्प लेता है, angle रोटेशन कोण को संदर्भित करता है, cx तथा cyएक्स और वाई अक्ष में रोटेशन के केंद्र को संदर्भित करता है। अगरcx तथा cyनिर्दिष्ट नहीं हैं, तो यह समन्वय प्रणाली की वर्तमान उत्पत्ति के लिए चूक है। के लियेExample - घुमाना (६०)।

  • Scale - यह दो विकल्प लेता है, sx एक्स-अक्ष के साथ स्केलिंग कारक को संदर्भित करता है और syY- अक्ष के साथ स्केलिंग कारक को संदर्भित करता है। यहाँ,sy वैकल्पिक है और यह मान लेता है sx, अगर यह निर्दिष्ट नहीं है। के लियेExample - स्केल (10)।

  • Skew (SkewX and SkewY)- यह एक ही विकल्प लेता है; skew-angleSkewX के लिए x- अक्ष के साथ कोण और SkewY के लिए y- अक्ष के साथ कोण को संदर्भित करता है। के लियेExample - तिरछा (20)।

अनुवाद के साथ एसवीजी आयत का एक उदाहरण, जिसका वर्णन इस प्रकार है -

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

   <body>
      <svg width = "300" height = "300">
         <rect x = "20" 
            y = "20"
            width = "60"
            height = "60"
            fill = "green"
            transform = "translate(30 30)">
         </rect>
      </svg>
   </body>
</html>

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

एक एसवीजी तत्व के लिए एक से अधिक परिवर्तन निर्दिष्ट किए जा सकते हैं जो अंतरिक्ष के रूप में अलगाव का उपयोग करते हैं। यदि एक से अधिक मान निर्दिष्ट किया गया है, तो परिवर्तन निर्दिष्ट क्रम में एक के बाद एक क्रमिक रूप से लागू किया जाएगा।

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

   <body>
      <svg width = "300" height = "300">
         <rect x = "20" 
            y = "20" 
            width = "60" 
            height = "60" 
            fill = "green" 
            transform = "translate(60 60) rotate(45)">
         </rect>
      </svg>
   </body>
</html>

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

परिवर्तन एसवीजी समूह तत्व के लिए भी लागू किया जा सकता है। यह एसवीजी में परिभाषित जटिल ग्राफिक्स को नीचे वर्णित रूपांतरित करने में सक्षम बनाता है।

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

   <body>
      <svg width = "300" height = "300">
         <g transform = "translate(60,60) rotate(30)">
            <rect x = "20" 
               y = "20" 
               width = "60" 
               height = "30" 
               fill = "green">
            </rect>
            <circle cx = "0" 
               cy = "0" 
               r = "30" 
               fill = "red"/>
         </g>
      </svg>
   </body>
</html>

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

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

एसवीजी छवि बनाने के लिए, परिवर्तन का उपयोग करके स्केल करने की कोशिश करें, और नीचे दिए गए चरणों का पालन करें।

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

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

</svg>

Step 2 - एक एसवीजी समूह बनाएं।

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

Step 3 - लंबाई 60 और ऊंचाई 30 की एक आयत बनाएं और इसे हरे रंग से भरें।

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

Step 4 - त्रिज्या 30 का एक चक्र बनाएं और इसे लाल रंग से भरें।

<svg width = "300" height = "300">
   <g>
      <rect x = "20" 
         y = "20" 
         width = "60" 
         height = "30" 
         fill = "green">
      </rect>
      <circle cx = "0" 
         cy = "0" 
         r = "30" 
         fill = "red"/>
   </g>
</svg>

Step 5 - एक रूपांतर विशेषता जोड़ें और अनुवाद जोड़ें और नीचे दिखाए अनुसार घुमाएँ।

<svg width = "300" height = "300">
   <g transform = "translate(60,60) rotate(30)">
      <rect x = "20" 
         y = "20" 
         width = "60" 
         height = "60" 
         fill = "green">
      </rect>
      <circle cx = "0" 
         cy = "0" 
         r = "30" 
         fill = "red"/>
   </g>
</svg>

Step 6 - एक HTML दस्तावेज़ बनाएं, "svg_transform_rotate_group.html" और ऊपर दिए गए SVG को नीचे बताए अनुसार एकीकृत करें।

<!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">
            <g transform = "translate(60,60) rotate(30)">
               <rect x = "20" 
                  y = "20" 
                  width = "60" 
                  height = "60" 
                  fill = "green">
               </rect>
               <circle cx = "0" 
                  cy = "0" 
                  r = "30" 
                  fill = "red"/>
            </g>
         </svg>
      </div>
   </body>
</html>

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

परिवर्तन का उपयोग करना

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 - एक एसवीजी समूह तत्व बनाएं और अनुवाद और विशेषताओं को सेट करें।

var group = svg.append("g").attr("transform", "translate(60, 60) rotate(30)");

Step 4 - एक एसवीजी आयत बनाएं और इसे समूह के अंदर जोड़ें।

var rect = group
   .append("rect")
   .attr("x", 20)
   .attr("y", 20)
   .attr("width", 60)
   .attr("height", 30)
   .attr("fill", "green")

Step 5 - एक एसवीजी सर्कल बनाएं और समूह के अंदर जोड़ें।

var circle = group
   .append("circle")
   .attr("cx", 0)
   .attr("cy", 0)
   .attr("r", 30)
   .attr("fill", "red")

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

<!DOCTYPE html>
<html lang = "en">
   <head>
      <title>SVG rectangle</title>
      <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);

            var group = svg.append("g")
               .attr("transform", "translate(60, 60) rotate(30)");
            
            var rect = group.append("rect")
               .attr("x", 20)
               .attr("y", 20)
               .attr("width", 60)
               .attr("height", 30)
               .attr("fill", "green")
            
            var circle = group
               .append("circle")
               .attr("cx", 0)
               .attr("cy", 0)
               .attr("r", 30)
               .attr("fill", "red")
         </script>
      </div>
   </body>
</html>

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

ट्रांसफॉर्म लाइब्रेरी

D3.js मैन्युअल रूप से ट्रांस्फ़ॉर्म विशेषताएँ बनाए बिना ट्रांसफ़ॉर्म प्रबंधित करने के लिए एक अलग लाइब्रेरी प्रदान करता है। यह सभी प्रकार के परिवर्तन को संभालने के लिए तरीके प्रदान करता है। कुछ विधियाँ हैंtransform(), translate(), scale(), rotate(), आदि आप शामिल कर सकते हैं d3-transform निम्नलिखित स्क्रिप्ट का उपयोग करके अपने वेबपेज में।

<script src = "http://d3js.org/d3.v4.min.js"></script>
<script src = "d3-transform.js"></script>

उपर्युक्त उदाहरण में, नीचे दिखाए अनुसार परिवर्तन कोड लिखा जा सकता है -

var my_transform = d3Transform()
   .translate([60, 60])
   .rotate(30);

var group = svg
   .append("g")
   .attr("transform", my_transform);