我想创建一个chart.js插件来创建瀑布图。
我是使用chart.js的新手。我正在考虑扩展条形图以创建瀑布图。
条形图控制器中的绘图功能如下:
draw: function(ease) {
var me = this;
var easingDecimal = ease || 1;
helpers.each(me.getMeta().data, function(rectangle, index) {
var d = me.getDataset().data[index];
if (d !== null && d !== undefined && !isNaN(d)) {
rectangle.transition(easingDecimal).draw();
}
}, me);
},
可以在此处找到完整的条形图控制器js文件: https://github.com/chartjs/Chart.js/tree/master/src/controllers
答案 0 :(得分:3)
自Chart.js v2.9.0.起,我们可以使用floating bars轻松创建瀑布图。因此,可以使用语法[min, max]
指定各个条。
给定值数组[3, 5, 4, 2, 6]
,我们需要产生以下数据(最后一项是“总计”栏的计算值):
[[0, 3], [3, 8], [8, 12], [12, 14], [14, 20], 20]
剩下要做的唯一一件事就是定义一个tooltips.callback
函数,该函数计算要在工具提示中显示的正确值。
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const v = data.datasets[0].data[tooltipItem.index];
return Array.isArray(v) ? v[1] - v[0] : v;
}
}
},
请查看以下代码示例,这些示例从baseData
数组中生成瀑布图。
let baseData = [
{ label: 'A', value: 3 },
{ label: 'B', value: 5 },
{ label: 'C', value: 4 },
{ label: 'D', value: 2 },
{ label: 'E', value: 6 }
];
const labels = baseData.map(o => o.label).concat('Total');
const data = [];
let total = 0;
for (let i = 0; i < baseData.length; i++) {
const vStart = total;
total += baseData[i].value;
data.push([vStart, total]);
}
data.push(total);
const backgroundColors = data.map((o, i) => 'rgba(255, 99, 132, ' + (i + (11 - data.length)) * 0.1 + ')');
new Chart('waterfall', {
type: 'bar',
data: {
labels: labels,
datasets: [{
data: data,
backgroundColor: backgroundColors,
barPercentage: 1
}]
},
options: {
responsive: true,
maintainAspectRatio: false,
legend: {
display: false
},
tooltips: {
callbacks: {
label: (tooltipItem, data) => {
const v = data.datasets[0].data[tooltipItem.index];
return Array.isArray(v) ? v[1] - v[0] : v;
}
}
},
scales: {
yAxes: [{
ticks: {
beginAtZero: true
}
}]
}
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.9.3/Chart.min.js"></script>
<canvas id="waterfall" height="200"></canvas>
如果图表应以“总计”栏开头,则只需
reverse
labels
,data
和backgroundColors
数组,如下所示。
data: {
labels: labels.reverse(),
datasets: [{
data: data.reverse(),
backgroundColor: backgroundColors.reverse(),
...
答案 1 :(得分:1)
我为瀑布图创建了一个chartjs插件。
请参阅https://github.com/MartinDawson/chartjs-plugin-waterfall
此插件的工作原理是检查是否有任何数据集包含一个名为dummyStack的属性,该属性设置为true。 stack属性必须与dummyStack一起使用才能使此插件正常工作。如果dummyStack为true,则它隐藏标签,工具提示并将颜色设置为不可见。当您使用堆叠时,它会创建浮动条的效果,如上图所示,我们可以将其用于瀑布图,因为默认情况下chartjs-2不支持瀑布图。
import waterFallPlugin from 'chartjs-plugin-waterfall';
var chart = new Chart(ctx, {
plugins: [waterFallPlugin]
});
const data = {
datasets: [
{
label: 'Closing Costs',
data: [50],
backgroundColor: '#e8cdd7',
stack: 'stack 1',
},
{
label: 'Purchase Price',
data: [700],
backgroundColor: '#d29baf',
stack: 'stack 1',
},
{
data: [200],
dummyStack: true,
stack: 'stack 2',
},
{
label: 'Opening Loan Balance',
data: [550],
backgroundColor: '#bb6987',
stack: 'stack 2',
},
{
label: 'Initial Cash Investment',
data: [200],
backgroundColor: '#a53860',
stack: 'stack 3',
},
],
};
它还有从条到条的行步。
答案 2 :(得分:0)
您可以使用Chart.JS https://github.com/everestate/chartjs-plugin-waterfall(参考:https://www.chartjs.org/docs/2.7.2/notes/extensions.html)推荐的插件
安装
npm install --save chartjs-plugin-waterfall
用法
import waterFallPlugin from 'chartjs-plugin-waterfall';
var chart = new Chart(ctx, {
plugins: [waterFallPlugin]
});