ZingChart JS - 获取可见节点

时间:2015-12-26 21:16:15

标签: javascript graph plot zoom zingchart

我使用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限制,但我找不到使用它们来获取可见值的方法。

有人这样做过吗?

非常感谢任何帮助。

谢谢!

2 个答案:

答案 0 :(得分:8)

zoom事件返回scaleX min和max(为kminkmax)以及系列min和max(为xminxmax )。

使用xminxmax,您可以简单地对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%"
        });