D3.js - कार्य उदाहरण

आइए इस अध्याय में एक एनिमेटेड बार चार्ट का प्रदर्शन करें। इस उदाहरण के लिए, हम डेटा रिकॉर्ड्स का उपयोग करते हैं। जनसंख्या रिकॉर्ड के पिछले अध्याय में डेटासेट के रूप में उपयोग किया जाता है और एक एनिमेटेड बार चार्ट उत्पन्न करता है।

ऐसा करने के लिए, हमें निम्नलिखित चरण करने होंगे -

Step 1 - Apply styles - नीचे दिए गए कोडिंग का उपयोग करके सीएसएस शैलियों को लागू करें।

<style>
   .bar {
      fill: green;
   }
   
   .highlight {
      fill: red;
   }
   
   .title {
      fill: blue;
      font-weight: bold;
   }
</style>

Step 2 - Define variables - नीचे स्क्रिप्ट का उपयोग करके एसवीजी विशेषताओं को परिभाषित करते हैं।

<script>
   var svg = d3.select("svg"), margin = 200,
   width = svg.attr("width") - margin,
   height = svg.attr("height") - margin;
</script>

Step 3 - Append text - अब, पाठ जोड़ें और नीचे कोडिंग का उपयोग करके परिवर्तन लागू करें।

svg.append("text")
   .attr("transform", "translate(100,0)")
   .attr("x", 50)
   .attr("y", 50)
   .attr("font-size", "20px")
   .attr("class", "title")
   .text("Population bar chart")

Step 4 - Create scale range- इस चरण में, हम एक स्केल रेंज बना सकते हैं और समूह तत्वों को जोड़ सकते हैं। इसे नीचे परिभाषित किया गया है।

var x = d3.scaleBand().range([0, width]).padding(0.4),
   y = d3.scaleLinear()
      .range([height, 0]);
   var g = svg.append("g")
      .attr("transform", "translate(" + 100 + "," + 100 + ")");

Step 5 - Read data - हम पहले ही बना चुके हैं data.csvहमारे पिछले उदाहरणों में फ़ाइल करें। वही फाइल, जिसका हमने यहां उपयोग किया है।

year,population
2006,40
2008,45
2010,48
2012,51
2014,53
2016,57
2017,62

अब, नीचे दिए गए कोड का उपयोग करके उपरोक्त फ़ाइल पढ़ें।

d3.csv("data.csv", function(error, data) {
   if (error) {
      throw error;
   }

Step 6 - Set domain - अब, नीचे दिए गए कोडिंग का उपयोग करके डोमेन सेट करें।

x.domain(data.map(function(d) { return d.year; }));
y.domain([0, d3.max(data, function(d) { return d.population; })]);

Step 7 - Add X-axis- अब, आप एक्स-अक्ष को परिवर्तन में जोड़ सकते हैं। इसे नीचे दिखाया गया है।

g.append("g")
   .attr("transform", "translate(0," + height + ")")
   .call(d3.axisBottom(x)).append("text")
   .attr("y", height - 250).attr("x", width - 100)
   .attr("text-anchor", "end").attr("font-size", "18px")
   .attr("stroke", "blue").text("year");

Step 8 - Add Y-axis - नीचे दिए गए कोड का उपयोग करके परिवर्तन में Y- अक्ष जोड़ें।

g.append("g")
   .append("text").attr("transform", "rotate(-90)")
   .attr("y", 6).attr("dy", "-5.1em")
   .attr("text-anchor", "end").attr("font-size", "18px")
   .attr("stroke", "blue").text("population");

Step 9 - Append group elements - अब, समूह तत्वों को संलग्न करें और नीचे परिभाषित वाई-अक्ष में परिवर्तन लागू करें।

g.append("g")
   .attr("transform", "translate(0, 0)")
   .call(d3.axisLeft(y))

Step 10 - Select the bar class - अब, नीचे परिभाषित के रूप में बार वर्ग के सभी तत्वों का चयन करें।

g.selectAll(".bar")
   .data(data).enter()
   .append("rect")
   .attr("class", "bar")
   .on("mouseover", onMouseOver) 
   .on("mouseout", onMouseOut)
   .attr("x", function(d) { return x(d.year); })
   .attr("y", function(d) { return y(d.population); })
   .attr("width", x.bandwidth())
   .transition()
   .ease(d3.easeLinear)
   .duration(200)
   .delay(function (d, i) {
      return i * 25;
   })
   .attr("height", function(d) { return height - y(d.population); });
});

यहां, हमने माउसआउट और माउसओवर के लिए श्रोता को एनीमेशन प्रदर्शन के लिए जोड़ा। यह एनीमेशन पर लागू होता है, जब माउस एक विशेष पट्टी पर घूमता है और इसके बाहर जाता है। इन कार्यों को निम्नलिखित चरण में समझाया गया है।

.ease(d3.easeLinear)फ़ंक्शन का उपयोग एनीमेशन में स्पष्ट गति करने के लिए किया जाता है। यह 200 की अवधि के साथ धीमे-धीमे और धीमी गति वाली गति को संसाधित करता है। विलंब का उपयोग करके गणना की जा सकती है -

.delay(function (d, i) {
   return i * 25;
})

Step 11 - Mouseover event handler function - नीचे दिखाए गए अनुसार माउस इवेंट को संभालने के लिए एक माउसओवर इवेंट हैंडलर बनाएं।

function onMouseOver(d, i) {
   d3.select(this)
      .attr('class', 'highlight');
   d3.select(this)
      .transition()
      .duration(200)
      .attr('width', x.bandwidth() + 5)
      .attr("y", function(d) { return y(d.population) - 10; })
      .attr("height", function(d) { return height - y(d.population) + 10; });
   g.append("text")
      .attr('class', 'val') 
   
   .attr('x', function() {
      return x(d.year);
   })
   
   .attr('y', function() {
      return y(d.value) - 10;
   })
}

यहां, माउसओवर इवेंट में, हम बार की चौड़ाई और ऊँचाई और चयनित बार के रंग को लाल करना चाहते हैं। रंग के लिए, हमने एक वर्ग 'हाइलाइट' जोड़ा है, जो चयनित बार का रंग बदलकर लाल कर देता है।

200 मिलीसेकंड की अवधि के लिए बार में एक संक्रमण कार्य। जब हम बार की चौड़ाई 5px और ऊंचाई 10px बढ़ाते हैं, तो पिछली चौड़ाई और बार की नई चौड़ाई और ऊँचाई से संक्रमण 200 मिलीसेकंड की अवधि के लिए होगा।

आगे, हमने बार को एक नए 'y' मान की गणना की, ताकि बार नई ऊंचाई मान के कारण बार विकृत न हो।

Step 12 - Mouseout event handler function- आइए हम एक माउस ईवेंट हैंडल करने के लिए माउसआउट ईवेंट हैंडलर बनाएं। इसे नीचे परिभाषित किया गया है।

function onMouseOut(d, i) {
   d3.select(this).attr('class', 'bar');
   
   d3.select(this)
      .transition()     
      .duration(400).attr('width', x.bandwidth())
      .attr("y", function(d) { return y(d.population); })
      .attr("height", function(d) { return height - y(d.population); });
   
   d3.selectAll('.val')
      .remove()
}

यहां, माउसआउट इवेंट में, हम उन चयन सुविधाओं को हटाना चाहते हैं, जिन्हें हमने माउसओवर इवेंट में लागू किया था। इसलिए, हम बार वर्ग को मूल 'बार' वर्ग में वापस लाते हैं और चयनित बार की मूल चौड़ाई और ऊंचाई को पुनर्स्थापित करते हैं और मूल मान के लिए y मान को पुनर्स्थापित करते हैं।

d3.selectAll(‘.val’).remove() फ़ंक्शन का उपयोग बार चयन के दौरान हमारे द्वारा जोड़े गए पाठ मान को निकालने के लिए किया जाता है।

Step 13 - Working Example- पूरा कार्यक्रम निम्नलिखित कोड ब्लॉक में दिया गया है। एक वेबपेज बनाएंanimated_bar.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<!DOCTYPE html>
<html>
   <head>
      <style>
         .bar {
            fill: green;
         }
        
         .highlight {
            fill: red;
         }
         
         .title {
            fill: blue;
            font-weight: bold;
         }
      </style>
      <script src = "https://d3js.org/d3.v4.min.js"></script>
      <title> Animated bar chart </title>
   </head>

   <body>
      <svg width = "500" height = "500"></svg>
      <script>
         var svg = d3.select("svg"),
         margin = 200, width = svg.attr("width") - margin,
         height = svg.attr("height") - margin;
         
         svg.append("text")
            .attr("transform", "translate(100,0)")
            .attr("x", 50).attr("y", 50)
            .attr("font-size", "20px")
            .attr("class", "title")
            .text("Population bar chart")
            
         var x = d3.scaleBand().range([0, width]).padding(0.4),
         y = d3.scaleLinear().range([height, 0]);
            
         var g = svg.append("g")
            .attr("transform", "translate(" + 100 + "," + 100 + ")");

         d3.csv("data.csv", function(error, data) {
            if (error) {
               throw error;
            }
               
            x.domain(data.map(function(d) { return d.year; }));
            y.domain([0, d3.max(data, function(d) { return d.population; })]);
                     
            g.append("g")
               .attr("transform", "translate(0," + height + ")")
               .call(d3.axisBottom(x))
               .append("text")
               .attr("y", height - 250)
               .attr("x", width - 100)
               .attr("text-anchor", "end")
               .attr("font-size", "18px")
               .attr("stroke", "blue").text("year");
               
            g.append("g")
               .append("text")
               .attr("transform", "rotate(-90)")
               .attr("y", 6)
               .attr("dy", "-5.1em")
               .attr("text-anchor", "end")
               .attr("font-size", "18px")
               .attr("stroke", "blue")
               .text("population");
                         
            g.append("g")
               .attr("transform", "translate(0, 0)")
               .call(d3.axisLeft(y))

            g.selectAll(".bar")
               .data(data)
               .enter()
               .append("rect")
               .attr("class", "bar")
               .on("mouseover", onMouseOver) 
               .on("mouseout", onMouseOut)   
               .attr("x", function(d) { return x(d.year); })
               .attr("y", function(d) { return y(d.population); })
               .attr("width", x.bandwidth()).transition()
               .ease(d3.easeLinear).duration(200)
               .delay(function (d, i) {
                  return i * 25;
               })
                  
            .attr("height", function(d) { return height - y(d.population); });
         });
          
          
         function onMouseOver(d, i) {
            d3.select(this)
            .attr('class', 'highlight');
               
            d3.select(this)
               .transition()     
               .duration(200)
               .attr('width', x.bandwidth() + 5)
               .attr("y", function(d) { return y(d.population) - 10; })
               .attr("height", function(d) { return height - y(d.population) + 10; });
              
            g.append("text")
               .attr('class', 'val')
               .attr('x', function() {
                  return x(d.year);
               })
               
            .attr('y', function() {
               return y(d.value) - 10;
            })
         }
          
         function onMouseOut(d, i) {
             
            d3.select(this)
               .attr('class', 'bar');
            
            d3.select(this)
               .transition()     
               .duration(200)
               .attr('width', x.bandwidth())
               .attr("y", function(d) { return y(d.population); })
               .attr("height", function(d) { return height - y(d.population); });
            
            d3.selectAll('.val')
               .remove()
         }
      </script>
   </body>
</html>

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

यदि हम किसी भी बार का चयन करते हैं, तो इसे लाल रंग में हाइलाइट किया जाएगा। डी 3 एक सामान्य-उद्देश्य वाली विज़ुअलाइज़ेशन लाइब्रेरी है जो डेटा को सूचना, दस्तावेज़, तत्वों आदि में बदलने से संबंधित है, और अंततः विज़ुअलाइज़ेशन बनाने में मदद करता है।