DC.js - Bagan Garis

Bagan garis digunakan untuk menampilkan informasi sebagai rangkaian titik data yang dihubungkan dengan garis lurus. Titik data mewakili dua nilai, satu diplot di sepanjang sumbu horizontal dan satu lagi di sepanjang sumbu vertikal. Misalnya, popularitas item makanan dapat digambarkan sebagai diagram garis sedemikian rupa sehingga item makanan tersebut direpresentasikan di sepanjang sumbu x dan popularitasnya ditampilkan di sepanjang sumbu y. Bab ini menjelaskan tentang diagram garis secara rinci.

Metode Diagram Garis

Sebelum melanjutkan menggambar diagram garis, kita harus memahami dc.lineChartkelas dan metodenya. Dc.lineChart menggunakan mixin untuk mendapatkan fungsionalitas dasar menggambar bagan. Mixins yang digunakan oleh dc.lineChart adalah sebagai berikut -

  • dc.stackMixin
  • dc.coordinateGridMixin

Diagram kelas lengkap dari dc.lineChart adalah sebagai berikut -

Dc.lineChart mendapatkan semua metode dari mixin yang ditentukan di atas serta memiliki metode sendiri untuk menggambar diagram garis. Mereka dijelaskan sebagai berikut.

dashStyle ([style])

Metode ini digunakan untuk mengatur gaya garis putus-putus untuk grafik garis.

dotRadius ([radius])

Metode ini digunakan untuk mendapatkan atau mengatur radius (dalam PX) untuk titik yang ditampilkan pada titik data. Ini didefinisikan sebagai berikut -

chart.dotRadius = function (radius) {
   if (!arguments.length) {
      return radius;
   }
};

interpolasi ([i])

Metode ini digunakan untuk mendapatkan atau mengatur interpolator untuk sebuah baris.

renderArea ([area])

Metode ini digunakan untuk mendapatkan atau mengatur area render.

renderDataPoints ([opsi])

Metode ini digunakan untuk membuat titik individu untuk setiap titik data.

ketegangan ([ketegangan])

Metode ini digunakan untuk mendapatkan atau mengatur tegangan untuk garis yang digambar. Itu dalam kisaran dari 0 hingga 1.

xyTipsOn ([xyTipsOn])

Metode ini digunakan untuk mengubah perilaku mouse dari satu titik data.

Gambar Diagram Garis

Mari kita menggambar diagram garis di DC. Untuk melakukan ini, kita perlu mengikuti langkah-langkah yang diberikan di bawah ini -

Langkah 1: Tentukan variabel

Mari kita definisikan variabel seperti yang ditunjukkan di bawah ini -

var chart = dc.lineChart('#line');

Di sini, fungsi dc.linechart dipetakan dengan wadah yang memiliki ekstensi id line.

Langkah 2: Baca datanya

Baca data dari people.csv file -

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

Di sini, jika kita menggunakan dataset yang sama people.csv, contoh file datanya adalah sebagai berikut -

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

...............
................
................

Langkah 3: Buat dimensi usia

Sekarang buat dimensi untuk usia seperti yang ditunjukkan di bawah ini -

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

Di sini, kami menetapkan usia dari data Crossfilter.

~~ adalah operator bitwise double NOT. Ini digunakan sebagai pengganti yang lebih cepat untukMath.floor() fungsi.

Sekarang, kelompokkan itu menggunakan reduceCount() fungsi, yang didefinisikan di bawah -

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

Langkah 4: Buat grafik

Sekarang, buat diagram garis menggunakan pengkodean yang diberikan di bawah ini -

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

Sini,

  • Lebar bagan 800 dan tinggi 300.

  • Fungsi d3.scale.linear digunakan untuk membangun skala linier baru dengan rentang domain yang ditentukan [15, 70].

  • Selanjutnya, kami mengatur brushOn nilai menjadi salah.

  • Kami menetapkan label sumbu y sebagai count dan label sumbu x sebagai age.

  • Terakhir, kelompokkan usia menggunakan ageGroup.

Langkah 5: Contoh kerja

Daftar kode lengkap ditampilkan di blok kode berikut. Buat halaman webline.html dan tambahkan perubahan berikut ke dalamnya.

<html>
   <head>
      <title>DC.js Line 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 = "line"></div>
      </div>

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

         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>

Sekarang, minta browser dan kita akan melihat respons berikut.