DC.js - बार चार्ट

बार चार्ट सबसे अधिक इस्तेमाल किए जाने वाले प्रकार के ग्राफ़ में से एक है और विभिन्न असतत श्रेणियों या समूहों के लिए संख्या, आवृत्ति या अन्य माप (उदाहरण के लिए) को प्रदर्शित करने और तुलना करने के लिए उपयोग किया जाता है। ग्राफ का निर्माण इस प्रकार किया जाता है कि विभिन्न पट्टियों की ऊँचाई या लम्बाई उस श्रेणी के आकार के समानुपाती होती है जिसका वे प्रतिनिधित्व करते हैं।

एक्स-एक्सिस (क्षैतिज अक्ष) में विभिन्न श्रेणियों का प्रतिनिधित्व होता है जिसका कोई पैमाना नहीं होता है। Y अक्ष (ऊर्ध्वाधर अक्ष) में एक पैमाना होता है और यह माप की इकाइयों को इंगित करता है। श्रेणियों की संख्या और लंबाई या जटिलता के आधार पर सलाखों को लंबवत या क्षैतिज रूप से खींचा जा सकता है।

बार चार्ट के तरीके

बार चार्ट बनाने के लिए आगे बढ़ने से पहले, हमें यह समझना चाहिए dc.barChartक्लास और उसके तरीके। Dc.barChart किसी चार्ट को आरेखित करने की बुनियादी कार्यक्षमता प्राप्त करने के लिए मिक्सिन्स का उपयोग करता है। Dc.barChart द्वारा उपयोग किए जाने वाले मिश्रण इस प्रकार हैं -

  • dc.stackMixin
  • dc.coordinateGridMixin

Dc.barChart का पूर्ण वर्ग आरेख इस प्रकार है -

Dc.barChart को उपरोक्त निर्दिष्ट मिश्रणों के सभी तरीके मिलते हैं। इसके अलावा, बार चार्ट बनाने के लिए इसके अपने तरीके भी हैं। उन्हें इस प्रकार समझाया गया है -

हमेशाउपयोग करना (दौर)

इस विधि का उपयोग सलाखों को केन्द्रित करने के लिए राउंडिंग सक्षम करने या नहीं करने के लिए किया जाता है।

बारपैडिंग ([पैड])

इस पद्धति का उपयोग बार आकार के एक अंश के रूप में सलाखों के बीच रिक्ति प्राप्त करने या स्थापित करने के लिए किया जाता है। संभावित पैडिंग मान 0-1 के बीच हैं।

केंद्रबार ([केंद्रबार])

इस पद्धति का उपयोग बार-अक्ष पर डेटा स्थिति के आसपास केंद्रित बार को सेट करने के लिए किया जाता है।

गैप ([गैप])

इस पद्धति का उपयोग सलाखों के बीच एक निश्चित अंतराल निर्धारित करने के लिए किया जाता है।

आउटरपैडिंग ([पैड])

इस पद्धति का उपयोग एक बाहरी बार चार्ट पर बाहरी पैडिंग को सेट करने के लिए किया जाता है।

एक बार चार्ट ड्रा करें

आइए हम डीसी में एक बार चार्ट बनाते हैं। ऐसा करने के लिए, हमें नीचे दिए गए चरणों का पालन करना चाहिए -

चरण 1: एक चर को परिभाषित करें

जैसा कि नीचे दिखाया गया है, हम एक चार्ट चर को परिभाषित करते हैं -

var chart = dc.barChart('#bar');

यहां, dc.barChart फ़ंक्शन को कंटेनर के साथ मैप किया गया है bar आईडी के रूप में।

चरण 2: डेटा पढ़ें

People.csv फ़ाइल से डेटा पढ़ें।

d3.csv("data/people.csv", function(errors, people) {
   var mycrossfilter = crossfilter(people);
}

यदि डेटा मौजूद नहीं है, तो यह एक त्रुटि देता है। अब, डेटा को क्रॉसफ़िल्टर को असाइन करें। इस उदाहरण के लिए, हम उन्हीं लोगों का उपयोग करेंगे। एससीवी फ़ाइल, जो निम्नानुसार दिखती है -

id,name,gender,DOB,MaritalStatus,CreditCardType
1,Damaris,Female,1973-02-18,false,visa-electron
2,Barbe,Female,1969-04-10,true,americanexpress
3,Belia,Female,1960-04-16,false,maestro
4,Leoline,Female,1995-01-19,true,bankcard
5,Valentine,Female,1992-04-16,false,
6,Rosanne,Female,1985-01-05,true,bankcard
7,Shalna,Female,1956-11-01,false,jcb
8,Mordy,Male,1990-03-27,true,china-unionpay
..................
..................
..................

चरण 3: एक आयु आयाम बनाएं

अब, नीचे दिखाए गए अनुसार आयु के लिए एक आयाम बनाएं -

var ageDimension = mycrossfilter.dimension(function(data) { 
   return ~~((Date.now() - new Date(data.DOB)) / (31557600000)) 
});

यहां, हमने क्रॉसफ़िल्टर डेटा से आयु को सौंपा। ~~ एक डबल बिटवेट ऑपरेटर नहीं है। यह के लिए एक तेजी से विकल्प के रूप में प्रयोग किया जाता हैMath.floor() समारोह।

अब, इसका उपयोग करके समूह बनाएं reduceCount() फ़ंक्शन जो नीचे दिखाया गया है -

var ageGroup = ageDimension.group().reduceCount();

चरण 4: एक चार्ट बनाएं

अब, नीचे दिए गए कोडिंग का उपयोग करके एक बार चार्ट बनाएं -

chart
   .width(800)
   .height(300)
   .x(d3.scale.linear().domain([15,70]))
   .brushOn(false)
   .yAxisLabel("Count")
   .xAxisLabel("Age")
   .dimension(ageDimension)
   .group(ageGroup)
   .on('renderlet', function(chart) {
      chart.selectAll('rect').on('click', function(d) {
         console.log('click!', d);
      });
   });

chart.render();

यहाँ,

  • चार्ट की चौड़ाई 800 और ऊंचाई 300 है।

  • D3.scale.linear फ़ंक्शन का उपयोग निर्दिष्ट डोमेन रेंज [15, 70] के साथ एक नया रैखिक स्केल बनाने के लिए किया जाता है।

  • अगला, हम ब्रशऑन मान को गलत पर सेट करते हैं।

  • हम y- अक्ष लेबल को आयु के रूप में गिनती और x- अक्ष लेबल के रूप में निर्दिष्ट करते हैं।

  • अंत में, आयु को आयु समूह समूह का उपयोग करके समूह बनाएं।

चरण 5: काम करने का उदाहरण

पूरी कोड सूची इस प्रकार है। एक वेब पेज बनाएँbar.html और इसमें निम्नलिखित परिवर्तन जोड़ें।

<html>
   <head>
      <title>DC Bar chart Sample</title>
      <link rel = "stylesheet" type = "text/css" href = "css/bootstrap.min.css">
      <link rel = "stylesheet" type = "text/css" href = "css/dc.css"/>

      <script src = "js/d3.js"></script>
      <script src = "js/crossfilter.js"></script>
      <script src = "js/dc.js"></script>
   </head>
   
   <body>
      <div>
         <div id = "bar"></div>
      </div>

      <script language = "javascript">
         var chart = dc.barChart('#bar');

         d3.csv("data/people.csv", function(errors, people) {
            var mycrossfilter = crossfilter(people);

            var ageDimension = mycrossfilter.dimension(function(data) { 
               return ~~((Date.now() - new Date(data.DOB)) / (31557600000)) 
            });
            var ageGroup = ageDimension.group().reduceCount();

            chart
               .width(800)
               .height(300)
               .x(d3.scale.linear().domain([15,70]))
               .brushOn(false)
               .yAxisLabel("Count")
               .xAxisLabel("Age")
               .dimension(ageDimension)
               .group(ageGroup)
               .on('renderlet', function(chart) {
                  chart.selectAll('rect').on('click', function(d) {
                     console.log('click!', d);
                  });
               });
            chart.render();
         });
      </script>
   </body>
</html>

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