缩放jqplot后获取画布中的数据点列表

时间:2013-05-24 09:59:15

标签: javascript jquery graph jqplot

如果有人可以帮我解决这个问题,我真的很感激。我们使用Jqplot绘制一些统计数据,并像缩放功能一样。

具体来说我们想要使用

中的例子

http://www.jqplot.com/deploy/dist/examples/zoom1.html

http://www.jqplot.com/deploy/dist/examples/zoomOptions.html

我们需要做的一件事是重新计算我们在页面上显示的一些值,如标准偏差,平均值等,放大后图中可见的点。   为此,我们需要在放大后获取图表上(保留)的数据点列表。理想情况下,我们正在查看返回的方法 放大后,当前数据集在图表中可见。

我查了API文档,但似乎没有这样的方法。所以,如果有人帮助我,我真的很感激  我应该继续这样做。

感谢....阿米特

1 个答案:

答案 0 :(得分:6)

好的,所以在经过大量的代码挖掘后,实际上没有任何简单的方法来获取这些数据,但是,有一种方法。

在下面的解决方案中,我有一个 zoomChart jqPLot obj,它充当我的主jqPLot的缩放代理,称为图表。据推测,如果您没有代理,只要您绑定到正确的对象,这也应该可以正常工作。

我正在做的是将自定义功能绑定到' jqplotZoom' event,在缩放操作完成后调用。

    zoomChart.target.bind('jqplotZoom', function(ev, gridpos, datapos, plot, cursor){
        var plotData =  plot.series[0].data;
        for (var i=0; i< plotData.length; i++) {
            if(plotData[i][0] >= chart.axes.xaxis.min && plotData[i][0] <= chart.axes.xaxis.max ) {
                //this dataset from the original is within the zoomed region
                //You can save these datapoints in a new array
                //This new array will contain your zoom dataset
                //for ex: zoomDataset.push(plotData[i]);
            }
        }
    });

这有意义吗?基本上,chart.axes.xaxis包含缩放区域的边界,plot.series[N].data是图表格式的所有原始数据。

请注意,我使用了 chart ,因为我最初创建了var chart = $.jqplot("chartDiv", ...

您应该使用您给出的任何变量名称。 希望这有帮助!