无法使用FlotJs绘制2个单独的图

时间:2019-04-24 04:22:03

标签: javascript jquery arrays flot

我正在尝试使用flotJS绘制2个单独的图形(实际上是9个,但现在只有2个),数据以某种方式混合并在两个图形上绘制相同的混合数据

这是我的JS代码:

var graphData1, graphData2, graphData3 = [];
var graphBuffer = 1000;
var xmin = 0;
var xmax = 5;

var options = {
    xaxes: [
        {position: 'bottom', autoScale: 'none', min: 0, max: 5}
    ],
    yaxes: [
        {position: 'left', autoScale: 'none', min: -1.5, max: 1.5}
    ],
    zoom: {interactive: true},
    pan: {interactive: true}
};


function deleteGraph() {
    graphData1 = graphData2 = graphData3 = [];

    $.plot("#graph1", [{graphData1}], options);
    $.plot("#graph2", [{graphData2}], options);
    //$.plot("#graph3", [{graphData3}], options);
}

function updateGraph(data) {

    var datatmp = data.data;

    // Formatea y Almacena datos a graficar
    datatmp.forEach(function (sample) {
        graphData1.push([parseFloat(sample.timestamp.toFixed(4)), parseFloat(sample.sensor1.toFixed(4))]);
        //graphData2.push([parseFloat(sample.timestamp.toFixed(4)), parseFloat(sample.sensor2.toFixed(4))]);
    });

    $.plot("#graph1", [graphData1], options);
    $.plot("#graph2", [graphData2], options);

}

,使用此代码,输出为:

graph result 1

您可以看到,即使在//graphData2.push([parseFloat(sample.timestamp.toFixed(4)), parseFloat(sample.sensor2.toFixed(4))]);被注释的情况下,它在两个图表上的绘制信息也相同

但是,如果我删除评论,结果是这样的:

graph result 2

您可以看到它混合了数据并在两个图形上绘制了相同的混合数据

如何在不同的图形上绘制不同的数据?

感谢您的帮助...

1 个答案:

答案 0 :(得分:1)

您正在设置graphData1 = graphData2,因此它们是同一阵列。然后,将所有数据点推入两个图表中都显示的那个数组中。

替换

var graphData1, graphData2, graphData3 = [];

// and

function deleteGraph() {
    graphData1 = graphData2 = graphData3 = [];

使用

var graphData1 = [], graphData2 = [], graphData3 = [];

// and

function deleteGraph() {
    graphData1 = [];
    graphData2 = [];
    graphData3 = [];