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>

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