DC.js - Balkendiagramm

Balkendiagramme sind eine der am häufigsten verwendeten Diagrammtypen und werden zum Anzeigen und Vergleichen der Anzahl, Häufigkeit oder anderer Kennzahlen (z. B. Mittelwerte) für verschiedene diskrete Kategorien oder Gruppen verwendet. Das Diagramm ist so aufgebaut, dass die Höhen oder Längen der verschiedenen Balken proportional zur Größe der Kategorie sind, die sie darstellen.

Die x-Achse (die horizontale Achse) repräsentiert die verschiedenen Kategorien ohne Skalierung. Die y-Achse (die vertikale Achse) hat eine Skala, die die Maßeinheiten angibt. Die Balken können je nach Anzahl der Kategorien und Länge oder Komplexität der Kategorie entweder vertikal oder horizontal gezeichnet werden.

Balkendiagrammmethoden

Bevor wir ein Balkendiagramm zeichnen, sollten wir das verstehen dc.barChartKlasse und ihre Methoden. Das dc.barChart verwendet Mixins, um die grundlegenden Funktionen zum Zeichnen eines Diagramms zu erhalten. Die vom dc.barChart verwendeten Mixins lauten wie folgt:

  • dc.stackMixin
  • dc.coordinateGridMixin

Das vollständige Klassendiagramm des dc.barChart lautet wie folgt:

Das dc.barChart ruft alle Methoden der oben angegebenen Mixins ab. Darüber hinaus verfügt es über eigene Methoden zum Zeichnen des Balkendiagramms. Sie werden wie folgt erklärt -

alwaysUseRounding ([rund])

Diese Methode wird verwendet, um abzurufen oder festzulegen, ob die Rundung aktiviert ist, wenn die Balken zentriert sind.

barPadding ([pad])

Diese Methode wird verwendet, um den Abstand zwischen Balken als Bruchteil der Balkengröße abzurufen oder festzulegen. Die möglichen Füllwerte liegen zwischen 0-1.

centerBar ([centerBar])

Mit dieser Methode wird der Balken festgelegt, der um die Datenposition auf der x-Achse zentriert ist.

Lücke ([Lücke])

Diese Methode wird verwendet, um einen festen Spalt zwischen den Stäben einzustellen.

OuterPadding ([Pad])

Diese Methode wird verwendet, um die äußere Auffüllung in einem Ordnungsbalkendiagramm festzulegen.

Zeichnen Sie ein Balkendiagramm

Zeichnen wir ein Balkendiagramm in DC. Um dies zu tun, sollten wir die folgenden Schritte ausführen -

Schritt 1: Definieren Sie eine Variable

Definieren wir eine Diagrammvariable wie unten gezeigt -

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

Hier wird die Funktion dc.barChart einem Container mit zugeordnet bar als die id.

Schritt 2: Lesen Sie die Daten

Lesen Sie Daten aus der Datei people.csv.

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

Wenn die Daten nicht vorhanden sind, wird ein Fehler zurückgegeben. Weisen Sie nun die Daten Crossfilter zu. In diesem Beispiel verwenden wir dieselbe people.csv-Datei, die wie folgt aussieht:

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
..................
..................
..................

Schritt 3: Erstellen Sie eine Altersdimension

Erstellen Sie nun eine Dimension für das Alter wie unten gezeigt -

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

Hier haben wir das Alter aus den Crossfilter-Daten zugewiesen. Das ~~ ist ein doppelter NICHT bitweiser Operator. Es wird als schnellerer Ersatz für die verwendetMath.floor() Funktion.

Gruppieren Sie es jetzt mit dem reduceCount() Funktion, die unten gezeigt wird -

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

Schritt 4: Erstellen Sie ein Diagramm

Erstellen Sie nun ein Balkendiagramm mit der unten angegebenen Codierung -

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

Hier,

  • Die Diagrammbreite beträgt 800 und die Höhe 300.

  • Mit der Funktion d3.scale.linear wird eine neue lineare Skala mit dem angegebenen Domänenbereich erstellt [15, 70].

  • Als nächstes setzen wir den Pinsel-Wert auf false.

  • Wir weisen die Beschriftung der y-Achse als Anzahl und die Beschriftung der x-Achse als Alter zu.

  • Gruppieren Sie abschließend das Alter mit der Funktion ageGroup.

Schritt 5: Arbeitsbeispiel

Die vollständige Codeliste lautet wie folgt. Erstellen Sie eine Webseitebar.html und fügen Sie die folgenden Änderungen hinzu.

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

Fordern Sie jetzt den Browser an und wir sehen die folgende Antwort.