2016-04-28 30 views
3

点が負のときは、Line Chart.jsの塗りの色(内部領域)を変更する必要があります。Chart.js線、負の点の異なる塗りつぶしの色

コードはシンプルで基本的なものです:私はこの結果を取得しようとしている

$(document).ready(function(){ 

    var ctx = $("#myChart").get(0).getContext("2d"); 

    var data = { 
     labels: ["January", "February", "March", "April", "May", "June", "July"], 
     datasets: [ 
      { 
       label: "My First dataset", 
       //fillColor : "rgba(60,91,87,1)", 
       // String - the color to fill the area under the line with if fill is true 
       backgroundColor: "rgba(75,192,192,0.4)", 
       strokeColor : "rgba(60,91,87,1)", 
       pointColor : "rgba(60,91,87,1)", 
       pointStrokeColor : "#58606d", 
       // The actual data 
       data: [65, 59, 80, -81, 56, 55, -40], 

       // String - If specified, binds the dataset to a certain y-axis. If not specified, the first y-axis is used. First id is y-axis-0 
       yAxisID: "y-axis-0", 
      } 
     ] 
    }; 

    var options = { 
     scales: { 
      yAxes: [{ 
       display: true, 
       ticks: { 
        suggestedMin: 0, // minimum will be 0, unless there is a lower value. 
        // OR // 
        beginAtZero: true // minimum value will be 0. 
       } 
      }] 
     } 
    }; 

    var myLineChart = new Chart(ctx, { 
     type: 'line', 
     data: data, 
     options: options 
    }); 

// myLineChart.data.datasets[0].metaDataset._points[3]._model.backgroundColor = "red"; 
// if (myLineChart.datasets[0].points[4].value < 0) { 
// myLineChart.datasets[0].points[4].fillColor = "red"; 
// myLineChart.update(); 
// } 
}) 

enter image description here

+0

私が知る限り、Chartではこれを行うことはできません。 1行には1つの色(詳細については1つの色のセット)しかありません。 – Pointy

答えて

4

あなたはこれを行うには、折れ線グラフを拡張することができます。


プレビュー

enter image description here


スクリプト

Chart.defaults.NegativeTransparentLine = Chart.helpers.clone(Chart.defaults.line); 
Chart.controllers.NegativeTransparentLine = Chart.controllers.line.extend({ 
    update: function() { 
     // get the min and max values 
     var min = Math.min.apply(null, this.chart.data.datasets[0].data); 
     var max = Math.max.apply(null, this.chart.data.datasets[0].data); 
     var yScale = this.getScaleForId(this.getDataset().yAxisID); 

     // figure out the pixels for these and the value 0 
     var top = yScale.getPixelForValue(max); 
     var zero = yScale.getPixelForValue(0); 
     var bottom = yScale.getPixelForValue(min); 

     // build a gradient that switches color at the 0 point 
     var ctx = this.chart.chart.ctx; 
     var gradient = ctx.createLinearGradient(0, top, 0, bottom); 
     var ratio = Math.min((zero - top)/(bottom - top), 1); 
     gradient.addColorStop(0, 'rgba(75,192,192,0.4)'); 
     gradient.addColorStop(ratio, 'rgba(75,192,192,0.4)'); 
     gradient.addColorStop(ratio, 'rgba(0,0,0,0)'); 
     gradient.addColorStop(1, 'rgba(0,0,0,0)'); 
     this.chart.data.datasets[0].backgroundColor = gradient; 

     return Chart.controllers.line.prototype.update.apply(this, arguments); 
    } 
}); 

、その後

... 
var myLineChart = new Chart(ctx, { 
    type: 'NegativeTransparentLine', 
    data: { 
    ... 

フィドル - http://jsfiddle.net/g2r2q5Lu/

+0

それは私が探しているものです!ありがとうございました! – user3831881

+0

最初に気付かない場合のクイックポインタとして、これは実際には一般的なもので、底部の透明な色だけではありません。あなたがする必要があるのは、異なる第2の色を選ぶことだけです。たとえば、トップグリーンとボトムレッドを行うことができます。 これは非常にクールです! –

4

取得するには@potatopeelings上記あなたがyAxisIDを追加する必要がありchart.js 2.5.xではで動作するようにコード: 'Y軸-0'へあなたのデータセットは以下の通りです。

var myLineChart = new Chart(ctx, { 
    type: 'NegativeTransparentLine', 
    data: { 
    labels: ["January", "February", "March", "April", "May", "June", "July"], 
    datasets: [{ 
     yAxisID : 'y-axis-0', 
     .... 
+0

"TypeError:Chart.controllers is undefined" ** EDIT **旧式のChart.jsを使用していました。 – Brent

関連する問題