如何解决如何通过画布外的按钮ChartJs控制画布图像的可见性?
为此,我使用了 draw
的 Chart.helpers.extend
函数,如下所示
let originalLineDraw = Chart.controllers.line.prototype.draw;
const base_image = new Image();
base_image.src="https://cdn0.iconfinder.com/data/icons/classic-icons/512/087.png";
Chart.helpers.extend(Chart.controllers.line.prototype,{
draw: function () {
originalLineDraw.apply(this,arguments);
let chart = this.chart;
let ctx = chart.chart.ctx;
let xaxis = chart.scales['x-axis-0'];
let yaxis = chart.scales['y-axis-0'];
ctx.save();
ctx.beginPath();
ctx.moveTo(xaxis.getPixelForValue(undefined,index),yaxis.top+40);
ctx.strokeStyle = '#000';
ctx.lineTo(xaxis.getPixelForValue(undefined,yaxis.bottom);
ctx.lineWidth = 2;
ctx.globalCompositeOperation = 'destination-over';
ctx.drawImage(base_image,xaxis.getPixelForValue(undefined,index) - 15,50,30,30);
ctx.stroke();
ctx.restore();
}
});
到目前为止,这有点挑战性,但最大的挑战是通过按钮控制插入的所有图像和绘制的黑线的可见性(如 chartJs 的图例过滤器按钮)。
我想我可能会使用 clearRect()
来清除我绘制的内容,但问题是由于动态数据有更多的图像和线条。
我该如何解决这个问题?
JSFiddle = https://jsfiddle.net/xazpjqb2/1/
编辑 我想出了一个关于用全局变量包装图表渲染函数来控制它的答案。然后 Chart.update() 可以解决问题。
这是我的解决方案:https://jsfiddle.net/1nwbv5k9/
解决方法
您可以通过一个新属性来增强 Chart 的基类,该属性确定是否应显示图像。例如
Chart.showImage=true;
此属性可在您的扩展绘制函数中使用,并最终调用或不调用 ctx.drawImage
。
if (Chart.showImage) {
ctx.drawImage(base_image,xaxis.getPixelForValue(undefined,index) - 15,50,30,30);
}
有了这个,您可以简单地将 showImage
设置为 false 并像这样更新您的图表:
var myChart = new Chart(ctx,options);
createImg(1);
function clearChart(index) {
//functions will go here to clear placed elements
Chart.showImage = false;
myChart.update();
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。