function getRandomColor() {
var letters = '0123456789ABCDEF'.split('');
var color = '#';
for (var i = 0; i < 6; i++) {
color += letters[Math.floor(Math.random() * 16)];
}
return color;
}
我在我正在处理的项目中使用 JSCharts,我需要为图形/条形图中的每个条形图使用不同的颜色。
下面的例子工作正常,但如果我有超过 6 条记录,那么它会提醒我一条消息:
JSChart" 在饼图和条形图的情况下,颜色数组长度必须等于数据长度
如何根据记录数生成颜色?
以下是条形图数据集的示例:
$.getJSON("http://...", function (data) {
var array = $.map(data, function (data) {
return [[data.Name, parseInt(data.Id)]];
});
var colors = ['#FA5E1F', '#FDCB3F', '#71D743', '#D23333', '#BAE73F', '#B381C9'];
var myChart = new JSChart('graph', 'bar');
myChart.setDataArray(array);
myChart.colorizeBars(colors);
myChart.setTitle('Title');
myChart.setTitleColor('#8E8E8E');
myChart.setAxisNameX('Orgs');
myChart.setAxisNameY('%');
myChart.setAxisColor('#c6c6c6');
myChart.setAxisWidth(1);
myChart.setAxisNameColor('#9a9a9a');
myChart.setAxisValuesColor('#939393');
myChart.setAxisPaddingTop(60);
myChart.setAxisPaddingLeft(50);
myChart.setAxisPaddingBottom(60);
myChart.setTextPaddingBottom(20);
myChart.setTextPaddingLeft(15);
myChart.setTitleFontSize(11);
myChart.setBarBorderWidth(0);
myChart.setBarSpacingRatio(50);
myChart.setBarValuesColor('#737373');
myChart.setGrid(false);
myChart.setSize(616, 321);
//myChart.setBackgroundImage('chart_bg.jpg');
myChart.draw();
});