jqPlot:如何实时更新图表

15

我无法自行找到一个合适的示例,以类似于此高级图表示例中演示的方式在jqPlot中执行实时更新。


+1 我喜欢你想要实现的东西。你已经有一些代码了吗?能在 http://jsfiddle.net 上分享一下吗? - Boro
我在原帖中发布了一个 jsFiddle 的示例。 - doberkofler
是的,我已经注意到这个例子。不过在我之前的评论中,我指的是您为 jqPlot 编写的代码,所以我们可以从您对 jqPlot 的操作开始工作。 - Boro
https://dev59.com/W2vXa4cB1Zd3GeqPKY4k#19471949 - 很棒的答案,带有测试 :) - Jacob Sobus
3个回答

22
根据来自这里的内容,我准备了以下示例:
$(document).ready(function() {
    var plot1 = $.jqplot('chart1', [new Array(1)], {
        title: 'Live Random Data',
        series: [
            {
            yaxis: 'y2axis',
            label: '',
            showMarker: false,
            fill: false,
            neighborThreshold: 3,
            lineWidth: 2.2,
            color: '#0571B6',
            fillAndStroke: true}
        ],
        axes: {
            xaxis: {
                renderer: $.jqplot.DateAxisRenderer,
                tickOptions: {
                    formatString: '%H:%M:%S'
                },
                numberTicks: 10
            },
            y2axis: {
                min: 100,
                max: 150,
                tickOptions: {
                    formatString: '%.2f'
                },
                numberTicks: 15
            }
        },
        cursor: {
            zoom: false,
            showTooltip: false,
            show: false
        },
        highlighter: {
            useAxesFormatters: false,
            showMarker: false,
            show: false
        },
        grid: {
            gridLineColor: '#333333',
            background: 'transparent',
            borderWidth: 3
        }
    });

    var myData = [];
    var x = (new Date()).getTime() - 101000;
    var y;
    var i;
    for ( i = 0; i < 100; i++) {
        x += 1000;
        y = Math.floor(Math.random() * 100);
        myData.push([x, y]);
    }

    plot1.series[0].data = myData;
    plot1.resetAxesScale();
    plot1.axes.xaxis.numberTicks = 10;
    plot1.axes.y2axis.numberTicks = 15;
    plot1.replot();

    function updateSeries() {
        myData.splice(0, 1);
        x = (new Date()).getTime();
        y = Math.floor(Math.random() * 100);
        myData.push([x, y]);

        plot1.series[0].data = myData;
        plot1.resetAxesScale();
        plot1.axes.xaxis.numberTicks = 10;
        plot1.axes.y2axis.numberTicks = 15;
        plot1.replot();
    }

    window.setInterval(updateSeries, 1000);
});

点击此链接测试一下。


@uesports135,我刚刚尝试了一下,它可以工作,请你再试一次好吗? - Fracu

7
我在JSFiddle上添加了一个示例,链接为jsfiddle.net/meccanismocomplesso/QAr4r/,它复制了你提供的示例。
我尽可能将主题保持得更加通用。如果需要更多解释,请阅读有关此内容的文章
var plot1 = $.jqplot('myChart', [data], options);
...
plot1.series[0].data = data; // update the graph

3
var plot1;

function updatePlot(data){
plot1 = $.jqplot('myChart', [data], options);
}


function reDrawPlot(data){`
updatePlot(data);
plot1.replot();
}

....
initialize plot
plot1 = $.jqplot('myChart', [data], options);
....


call function reDrawPlot with the new data as a parameter

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接