我使用ZingChart library创建了一个图表,一切都按预期工作。该图用于显示特定插座随时间的功耗。
加载图表后,系统会显示该时间段的kWh消耗量。
用户可以放大和缩小图表,当发生这种情况时,我想显示图表中显示的那段时间的功耗。
我正在使用缩放事件:
zingchart.render({
id:'chartDiv',
data:graphset,
height:500,
events:{
zoom:function(p){
console.log(p);
console.log(zingchart.exec(p.id, 'getseriesdata', {}));
console.log(zingchart.exec(p.id, 'getseriesvalues', {}));
console.log(zingchart.exec(p.id, "getplotvalues", {}));
}
},
width:"100%"
});
当我放大或缩小时,函数getseriesdata,getseriesvalues和getplotvalues总是返回完整的图形值,而不仅仅是可见的值。
p对象给出了新的x和y限制,但我找不到使用它们来获取可见值的方法。
有人这样做过吗?
非常感谢任何帮助。
谢谢!
答案 0 :(得分:8)
zoom
事件返回scaleX min和max(为kmin
和kmax
)以及系列min和max(为xmin
和xmax
)。
使用xmin
和xmax
,您可以简单地对values数组进行切片以获取可见值。
这是一个例子。
zingchart.bind('myChart', 'zoom', function(p) {
var start = p.xmin;
var end = p.xmax + 1;
var series = zingchart.exec('myChart', 'getseriesvalues')[0];
series = series.slice(start, end+1);
// You can now do whatever you want with the series values
});
You can view a working demo here.
完全披露:我在ZingChart团队。如果这解决了您的问题,请告诉我。
答案 1 :(得分:3)
所以,不是最好的解决方案,但它现在会做。
如果有人有改进此垃圾代码的任何提示,请随时发表评论。
使用Moment.js作为日期,我使用了zoom事件返回的最小和最大日期/时间值,并在这两个日期/时间之间添加了功耗值。
zingchart.render({ // Render Method[3]
id:'chartDiv',
locale:"MYLOCALE",
data:graphset,
height:500,
events:{
zoom:function(p){
var dateInit = moment(p.kmin).format("YYYY-MM-DD HH:mm:ss");
var dateEnd = moment(p.kmax).format("YYYY-MM-DD HH:mm:ss");
var newTotal = 0.0;
var arrayTotal = 0;
function getNewConsumption(element, index, array) {
if( moment(element[5]).isAfter(dateInit) && moment(element[5]).isBefore(dateEnd) ){
newTotal = newTotal + element[2];
arrayTotal++;
}
}
parseJSONReturn.forEach(getNewConsumption);
var new_average_consumption = newTotal / arrayTotal;
var new_ms = moment(dateEnd).diff(moment(dateInit));
var new_d = moment.duration(new_ms).asHours();
var new_total_kwh = new Big((new_average_consumption * new_d) / 1000);
$("#kwh_consumption").empty().text(new_total_kwh.toFixed(2));
}
},
width:"100%"
});