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

Can I define data point color with a function when using angular-chart?

本文关键字:数据 定义 颜色 函数 我可以      更新时间:2023-09-26

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

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

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

回复: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;
    }         

我确实设法让它与角度图一起工作:

 # 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字段中的值返回颜色哈希中的值。