ChartjsとColorschemesでオシャレなグラフをプロットする

ChartJSでのグラフのプロット

chartjsは便利なプラグインですが、そのまま使用すると色が原色で見た目重視のWEBアプリケーションにそのまま使うのはちょっときついです。

ChartJSのグラフの色をオシャレにするには、BackgroundcolorをオシャレなRGB値に指定することで可能ですが、グラフが動的なものだと一々色合いを指定するのはコードが冗長になってしまいます。

というわけで一々RGB値を指定せずとも色合いを綺麗にしてくれるプラグイン的なものはないかと探していたら、「chartjs-plugin-colorschemes」という便利なプラグインを見つけたので紹介しておきます。

Chartjs.jsとchartjs-plugin-colorschemesでオシャレなグラフをプロット

↓がサンプルコードなります。

<script type="text/javascript" src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.7.3/Chart.min.js"></script>
<script src="https://unpkg.com/chartjs-plugin-colorschemes"></script>

<div style="position:absolute; top:60px; left:10px; width:500px; height:500px;">
<canvas id="myChart" width="400" height="400"></canvas>
</div>

<script>
    var ctx = document.getElementById('myChart');
    var myChart = new Chart(ctx, {
        type: 'line',
        data: {
            labels: ['Red', 'Blue', 'Yellow', 'Green', 'Purple', 'Orange'],
            datasets: [{
                label: 'line1',
                data: [2, 9, 3, 5, 2, 3],
                fill: false,
                borderWidth: 1
            },
            {
                label: 'line2',
                data: [22, 29, 23, 25, 22, 23],
                fill: false,
                borderWidth: 1
            },
            {
                label: 'line3',
                data: [12, 19, 13, 15, 12, 13],
                fill: false,
                borderWidth: 1
            },
            {
                label: 'line4',
                data: [112, 189, 103, 150, 120, 103],
                fill: false,
                borderWidth: 1
            },]
        },
        options: {
            plugins: {
                colorschemes: {
                    scheme: 'brewer.Paired12'
                }
            },
            scales: {
                yAxes: [{
                    ticks: {
                        beginAtZero: true
                    }
                }]
            }
        }
    });
</script>

参照:https://github.com/beginerSE/chartjs.js-Web-/tree/master

これをブラウザで表示すると↓のようなグラフがプロットできています

デフォルトだと線と軸の間が塗りつぶすので交差する複数の線をプロットすると気持ち悪いことになるのでそうならないように、引数でfill:false,を指定しています。これをしないと↓のようになります

beginAtZero: はtrueにするとグラフのy軸が0からになります。falseにすると勝手に設定されます。一応min:max:でy軸の範囲の設定も可能です。

:参考

https://qiita.com/nekojoker/items/d6a90b4654fafdc3418d
http://nagix.hatenablog.com/entry/2018/11/26/183950

プログラミングの独学はとても難しい


プログラミングは小学校の義務教育にも導入され始めており、これから社会人として生きていく上でプログラミングはもはや出来て当たり前、出来なれば論外というエクセルレベルの必須スキルになりつつあります。そしてそういう話を聞いて参考書なりを購入して独学でプログラミング勉強しようと思っている人も少なくないでしょう。しかしプログラミングを独学で勉強し始めようと思うものの



・「分からない箇所で詰まって挫折してしまった」

・「勉強する時間が足りない」

・「ネットの記事だと情報が断片的でよくわからない」

・「コードのエラーの原因が分からない」



という壁にぶち当たって、プログラミングの勉強を止めてしまう方が少なくありません。独学でプログラミングを勉強してる時間のほとんどはつまづいている時間です。実際僕も最初のころ独学でプログラミングを勉強していた頃はエラーの原因が分からず丸1日を不意にしてしまった・・・そんな苦い経験がありました。それで僕は一度はプログラミングの学習を諦めてしまいましたが、就活で現実を知る中で



「プログラミングを勉強して、いずれフリーランスとして自由な生き方がしたい」

「エンジニアとして若いうちから高収入を得たい」



という強い気持ちから一念発起して「侍エンジニアのwebサービスコース」に申し込み、プロのエンジニアの方に対面でマンツーマンでPythonによるWebサービス作り方とWeb技術の基本を教えてもらい、ようやくプログラミングが理解でき、今ではエンジニアとしてそこそこの暮らしができるようになりました。





侍エンジニアでは、とりあえずプログラミングやインターネットの基本を知っておきたい人から、HTML・cssなどでWebサイトやWebアプリを作ってみたい人やPythonを勉強してデータサイエンティストやAIエンジニアになりたい人まで幅広いニーズに応えた様々なコースが用意されています。



IT業界と言ってもエンジニアの仕事はプログラミング言語次第でサーバーから機械学習・ディープラーニングまで多種多様ですし、侍エンジニアの無料レッスン(カウンセリング)を受けてみて、自分のやりたいITの仕事は何なのか?を見つけるのがエンジニアへの第一歩になります。ちなみに今侍エンジニアの無料レッスンを受けると1000円分のAmazonギフト券がもらえるので、試しに受けてみるだけもお得です。


自分は半端に独学やオンラインスクールで勉強して金と時間を無駄にするくらいなら、リアルのプログラミングスクールに通ってしっかりプログラミングを勉強した方がいいと思います。ちなみに今、侍エンジニアに申し込むと、25歳以下の学生の方であれば、受講料が20%OFFになるので超お得です。


そして、プログラミングは大勢で授業を受けたり漫然とオンライン学習をするよりも自分が分からない箇所をピンポイントでプロの講師に直接質問して、ちゃんと納得するというスタイルの方がお金は確かに少し掛かりますが、独学で学ぶよりも絶対にモノになります。


シェアする

  • このエントリーをはてなブックマークに追加

フォローする

   侍エンジニア塾       
侍エンジニアの無料体験レッスンを予約する -->