使用角度图时,我可以使用函数定义数据点颜色吗?

时间:2016-05-03 18:21:27

标签: javascript angularjs d3.js c3.js angular-chart

https://github.com/GraFiddle/angular-chart

在C3库中有一个数据相关颜色样本(http://c3js.org/samples/data_color.html):

var chart = c3.generate({
    data: {
        ...,
        color: function (color, d) {
            // d will be 'id' when called for legends
            return d.id && d.id === 'data3' ? d3.rgb(color).darker(d.value / 150) : color;
        }
    }
});

所以我认为我添加了color功能:

dims = {
    dt: {
      axis: 'x',
      name: 'Date',
      displayFormat: '%H:%M:%S',
      dataType: 'datetime'
    }
  };

  // key is something like errorRate etc. 
  dims[key] = {
    axis: 'y',
    name: key,
    type: 'line',
    color: function(color, d) {
      return console.log(arguments);
    }
  };

但是颜色功能似乎被忽略了。有没有办法使用这个库制作一个依赖于函数的颜色?

2 个答案:

答案 0 :(得分:0)

看起来它只是一个字符串,可以用它来支持它并提交PR:

RE:https://github.com/GraFiddle/angular-chart/blob/master/src/js/converter.js

   // set color
    if (angular.isString(dimension.color)) {
      configuration.data.colors[key] = dimension.color;
    }         

答案 1 :(得分:0)

我确实设法让它与角度图表一起使用:

 # coffeescript
 graphOptions =  
   data: datapoints
   dimensions: dims
   chart:
     data:
       color: (color, d) ->
         if d.index? and data[d.index]?
           return colors[data[d.index].status]
         else return color

此函数将根据数据点status字段中的值从颜色哈希返回值。