D3.js - रेखांकन
एक ग्राफ एक 2-आयामी सपाट स्थान है जिसे एक आयत के रूप में दर्शाया गया है। रेखांकन में एक समन्वित स्थान होता है जहां x = 0 और y = 0 निर्देशांक बाईं ओर नीचे की ओर आते हैं। गणितीय कार्टेशियन समन्वित स्थान के अनुसार, ग्राफ़ में X समन्वय बाएं से दाएं बढ़ता है और Y समन्वय नीचे से ऊपर की ओर बढ़ता है।
जब हम x = 30 और y = 30 निर्देशांक के साथ एक वृत्त खींचने के बारे में बात करते हैं, तो हम 30 इकाइयों को नीचे से दाईं ओर और फिर हम 30 इकाइयों को ऊपर जाते हैं।
एसवीजी समन्वय अंतरिक्ष
एसवीजी कोऑर्डिनेट स्पेस उसी तरह से काम करता है जिस तरह से एक गणितीय ग्राफ अंतरिक्ष कार्यों का समन्वय करता है, दो महत्वपूर्ण विशेषताओं को छोड़कर -
- एसवीजी कोऑर्डिनेट स्पेस में x = 0 और y = 0 निर्देशांक हैं जो बाईं ओर सबसे ऊपर हैं।
- एसवीजी कोऑर्डिनेट स्पेस में वाई समन्वय ऊपर से नीचे तक बढ़ रहा है।
एसवीजी समन्वय अंतरिक्ष ग्राफ
जब हम SVG कोऑर्डिनेट स्पेस में x = 30 और y = 30 निर्देशांक के साथ एक वृत्त खींचने की बात करते हैं, तो हम 30 इकाइयों को ऊपर से दाईं ओर और फिर हम 30 इकाइयों को ऊपर जाते हैं। इसे निम्नानुसार परिभाषित किया गया है।
var svgContainer = d3
.select("body")
.append("svg")
.attr("width", 200)
.attr("height", 200);
गौर करें, ग्राफ के रूप में एसवीजी तत्व 200 यूनिट चौड़ा और 200 यूनिट लंबा होता है। अब हम जानते हैं कि X और Y शून्य निर्देशांक शीर्ष पर हैं। अब हम यह भी जानते हैं कि जैसे जैसे Y समन्वय बढ़ता है, यह हमारे ग्राफ के ऊपर से नीचे की ओर बढ़ेगा। आप एसवीजी तत्वों को नीचे दिखाए अनुसार स्टाइल कर सकते हैं।
var svgContainer = d3
.select("body").append("svg")
.attr("width", 200)
.attr("height", 200)
.style("border", "1px solid black");
ग्राफ उदाहरण
आइए हम रेखा ग्राफ का एक उदाहरण मानते हैं।
Line Graph- समय के साथ किसी चीज़ के मूल्य की कल्पना करने के लिए एक लाइन ग्राफ का उपयोग किया जाता है। यह दो चरों की तुलना करता है। प्रत्येक चर को एक अक्ष के साथ प्लॉट किया जाता है। एक रेखा ग्राफ में एक ऊर्ध्वाधर अक्ष और एक क्षैतिज अक्ष होता है।
इस उदाहरण के ग्राफ में, हम csv फ़ाइल रिकॉर्ड को भारतीय राज्य जनसंख्या वृद्धि वर्ष 2006 से 2017 के रूप में ले सकते हैं। आइए पहले हम एक बनाते हैं data.csv जनसंख्या रिकॉर्ड दिखाने के लिए।
अपने D3 फोल्डर में एक नई सीएसवी फाइल बनाएं -
year,population
2006,40
2008,45
2010,48
2012,51
2014,53
2016,57
2017,62
अब, फ़ाइल को सहेजें और डी 3 में एक रेखा ग्राफ खींचने के लिए निम्न चरणों का पालन करें। आइए प्रत्येक चरण के बारे में विस्तार से जानें।
Step 1 - Adding styles - हमें एक शैली जोड़ते हैं line नीचे दिए गए कोड का उपयोग करके वर्ग।
.line {
fill: none;
stroke: green;
stroke-width: 5px;
}
Step 2 - Define variables - एसवीजी विशेषताओं को नीचे परिभाषित किया गया है।
var margin = {top: 20, right: 20, bottom: 30, left: 50},
width = 960 - margin.left - margin.right,
height = 500 - margin.top - margin.bottom;
यहां, पहली पंक्ति चार मार्जिन को परिभाषित करती है, जो उस ब्लॉक को घेरती है जहां ग्राफ तैनात है।
Step 3 - Define line - का उपयोग करके एक नई रेखा खींचें d3.line() फ़ंक्शन, जो नीचे दिखाया गया है।
var valueline = d3.line()
.x(function(d) { return x(d.year); })
.y(function(d) { return y(d.population); });
यहां, वर्ष एक्स-एक्सिस रिकॉर्ड में डेटा का प्रतिनिधित्व करता है और जनसंख्या वाई-अक्ष में डेटा को संदर्भित करती है।
Step 4 - Append SVG attributes - एसवीजी विशेषताओं और समूह तत्वों को नीचे दिए गए कोड का उपयोग करके जोड़ें।
var svg = d3.select("body").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g").attr("transform",
"translate(" + margin.left + "," + margin.top + ")");
यहां, हमने समूह तत्वों को जोड़ दिया है और परिवर्तन को लागू किया है।
Step 5 - Read data - अब, हम अपने डेटासेट से डेटा पढ़ सकते हैं data.csv।
d3.csv("data.csv", function(error, data) {
if (error) throw error;
}
यहाँ, data.csv मौजूद नहीं है, यह एक त्रुटि फेंकता है।
Step 6 - Format data - अब, नीचे दिए गए कोड का उपयोग करके डेटा को प्रारूपित करें।
data.forEach(function(d) {
d.year = d.year;
d.population = +d.population;
});
यह उपरोक्त कोड सुनिश्चित करता है कि csv फ़ाइल से निकाले गए सभी मान सेट किए गए हैं और सही ढंग से स्वरूपित किए गए हैं। प्रत्येक पंक्ति में दो मान होते हैं - एक मान 'वर्ष' के लिए और दूसरा मान 'जनसंख्या' के लिए। फ़ंक्शन एक वर्ष में 'वर्ष' और 'जनसंख्या' की एक पंक्ति के मानों को निकाल रहा है।
Step 7 - Set scale range - डेटा फॉर्मेट होने के बाद, आप X और Y के लिए स्केल रेंज सेट कर सकते हैं।
x.domain(d3.extent(data, function(d) { return d.year; }));
y.domain([0, d3.max(data, function(d) { return d.population; })]);
Step 8 - Append path - नीचे दिखाए अनुसार पथ और डेटा को जोड़ें।
svg.append("path").data([data])
.attr("class", "line").attr("d", valueline);
Step 9 - Add X-axis - अब, आप नीचे दिए गए कोड का उपयोग करके एक्स-एक्सिस जोड़ सकते हैं।
svg.append("g")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(x));
Step 10 - Add Y-axis - हम नीचे दिखाए गए अनुसार Y- अक्ष को समूह में जोड़ सकते हैं।
svg.append("g")
.call(d3.axisLeft(y));
Step 11 - Working Example- पूरा कोड निम्नलिखित कोड ब्लॉक में दिया गया है। एक साधारण वेबपेज बनाएंlinegraphs.html और इसमें निम्नलिखित परिवर्तन जोड़ें।
graph.html
<!DOCTYPE html>
<html>
<head>
<script type = "text/javascript" src = "https://d3js.org/d3.v4.min.js"></script>
<style>
.line {
fill: none;
stroke: green;
stroke-width: 5px;
}
</style>
</head>
<body>
<script>
// set the dimensions and margins of the graph
var margin = {top: 20, right: 20, bottom: 30, left: 50},
width = 960 - margin.left - margin.right,
height = 500 - margin.top - margin.bottom;
// set the ranges
var x = d3.scaleTime().range([0, width]);
var y = d3.scaleLinear().range([height, 0]);
// define the line
var valueline = d3.line()
.x(function(d) { return x(d.year); })
.y(function(d) { return y(d.population); });
// append the svg obgect to the body of the page
// appends a 'group' element to 'svg'
// moves the 'group' element to the top left margin
var svg = d3.select("body").append("svg")
.attr("width", width + margin.left + margin.right)
.attr("height", height + margin.top + margin.bottom)
.append("g").attr("transform",
"translate(" + margin.left + "," + margin.top + ")");
// Get the data
d3.csv("data.csv", function(error, data) {
if (error) throw error;
// format the data
data.forEach(function(d) {
d.year = d.year;
d.population = +d.population;
});
// Scale the range of the data
x.domain(d3.extent(data, function(d) { return d.year; }));
y.domain([0, d3.max(data, function(d) { return d.population; })]);
// Add the valueline path.
svg.append("path")
.data([data])
.attr("class", "line")
.attr("d", valueline);
// Add the X Axis
svg.append("g")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(x));
// Add the Y Axis
svg.append("g")
.call(d3.axisLeft(y));
});
</script>
</body>
</html>
अब ब्राउज़र का अनुरोध करें और हम निम्नलिखित परिणाम देखेंगे।