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);