D3.js - Diagramme

Ein Graph ist ein zweidimensionaler flacher Raum, der als Rechteck dargestellt wird. Diagramme haben einen Koordinatenraum, in dem die Koordinaten x = 0 und y = 0 unten links liegen. Gemäß dem mathematischen kartesischen Koordinatenraum wachsen in Graphen die X-Koordinaten von links nach rechts und die Y-Koordinaten von unten nach oben.

Wenn wir über das Zeichnen eines Kreises mit x = 30 und y = 30 Koordinaten sprechen, gehen wir 30 Einheiten von links unten nach rechts und dann 30 Einheiten nach oben.

SVG-Koordinatenraum

Der SVG-Koordinatenraum funktioniert genauso wie ein mathematischer Diagrammkoordinatenraum, mit Ausnahme von zwei wichtigen Merkmalen:

  • Der SVG-Koordinatenraum hat x = 0 und y = 0 Koordinaten fallen oben links.
  • Im SVG-Koordinatenraum wächst die Y-Koordinate von oben nach unten.

SVG-Koordinatenraumdiagramm

Wenn wir über das Zeichnen eines Kreises mit x = 30 und y = 30 Koordinaten im SVG-Koordinatenraum sprechen, gehen wir 30 Einheiten von links oben nach rechts und dann 30 Einheiten nach oben. Es ist wie folgt definiert.

var svgContainer = d3
   .select("body")
   .append("svg")
   .attr("width", 200)
   .attr("height", 200);

Betrachten Sie das SVG-Element als Diagramm mit einer Breite von 200 Einheiten und einer Höhe von 200 Einheiten. Wir wissen jetzt, dass die X- und Y-Nullkoordinaten oben links liegen. Wir wissen jetzt auch, dass sich die Y-Koordinate mit zunehmendem Wachstum von oben nach unten in unserem Diagramm bewegt. Sie können die SVG-Elemente wie unten gezeigt formatieren.

var svgContainer = d3
   .select("body").append("svg")
   .attr("width", 200)
   .attr("height", 200)
   .style("border", "1px solid black");

Diagrammbeispiel

Betrachten wir ein Beispiel für das Liniendiagramm.

Line Graph- Ein Liniendiagramm wird verwendet, um den Wert von etwas im Laufe der Zeit zu visualisieren. Es werden zwei Variablen verglichen. Jede Variable wird entlang einer Achse dargestellt. Ein Liniendiagramm hat eine vertikale und eine horizontale Achse.

In diesem Beispieldiagramm können wir CSV-Dateidatensätze als Bevölkerungswachstum der indischen Staaten von 2006 bis 2017 verwenden. Lassen Sie uns zunächst eine erstellen data.csv um die Bevölkerungsaufzeichnungen zu zeigen.

Erstellen Sie eine neue CSV-Datei in Ihrem D3-Ordner -

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

Speichern Sie nun die Datei und führen Sie die folgenden Schritte aus, um ein Liniendiagramm in D3 zu zeichnen. Lassen Sie uns jeden Schritt im Detail durchgehen.

Step 1 - - Adding styles - Fügen wir dem einen Stil hinzu line Klasse mit dem unten angegebenen Code.

.line {
   fill: none;
   stroke: green;
   stroke-width: 5px;
}

Step 2 - - Define variables - Die SVG-Attribute sind unten definiert.

var margin = {top: 20, right: 20, bottom: 30, left: 50},
   width = 960 - margin.left - margin.right,
   height = 500 - margin.top - margin.bottom;

Hier definiert die erste Zeile die vier Ränder, die den Block umgeben, in dem sich das Diagramm befindet.

Step 3 - - Define line - Zeichnen Sie eine neue Linie mit der d3.line() Funktion, die unten gezeigt wird.

var valueline = d3.line()
   .x(function(d) { return x(d.year); })
   .y(function(d) { return y(d.population); });

Hier repräsentiert das Jahr die Daten in den X-Achsen-Datensätzen und die Grundgesamtheit bezieht sich auf die Daten auf der Y-Achse.

Step 4 - - Append SVG attributes - Fügen Sie SVG-Attribute und Gruppenelemente mit dem folgenden Code hinzu.

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 + ")");

Hier haben wir die Gruppenelemente angehängt und die Transformation angewendet.

Step 5 - - Read data - Jetzt können wir Daten aus unserem Datensatz lesen data.csv.

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

Hier ist die Datei data.csv nicht vorhanden, es wird ein Fehler ausgegeben.

Step 6 - - Format data - Formatieren Sie nun die Daten mit dem folgenden Code.

data.forEach(function(d) {
   d.year = d.year;
   d.population = +d.population;
});

Dieser obige Code stellt sicher, dass alle Werte, die aus der CSV-Datei gezogen werden, korrekt eingestellt und formatiert sind. Jede Zeile besteht aus zwei Werten - einem Wert für 'Jahr' und einem anderen Wert für 'Bevölkerung'. Die Funktion zieht zeilenweise Werte für 'Jahr' und 'Bevölkerung' heraus.

Step 7 - - Set scale range - Nach dem Formatieren der Daten können Sie den Skalierungsbereich für X und Y festlegen.

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 - Fügen Sie den Pfad und die Daten wie unten gezeigt hinzu.

svg.append("path").data([data])
   .attr("class", "line").attr("d", valueline);

Step 9 - - Add X-axis - Jetzt können Sie die X-Achse mit dem folgenden Code hinzufügen.

svg.append("g")
   .attr("transform", "translate(0," + height + ")")
   .call(d3.axisBottom(x));

Step 10 - - Add Y-axis - Wir können der Gruppe die Y-Achse wie unten gezeigt hinzufügen.

svg.append("g")
   .call(d3.axisLeft(y));

Step 11 - - Working Example- Der vollständige Code ist im folgenden Codeblock angegeben. Erstellen Sie eine einfache Webseitelinegraphs.html und fügen Sie die folgenden Änderungen hinzu.

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>

Fordern Sie nun den Browser an und wir sehen das folgende Ergebnis.