javascript - 在 Highcharts 中,没有动态数据的系列不会移动

标签 javascript highcharts

在有和没有动态数据的系列组合中,有动态数据的系列可以很容易地移动,但其他非动态数据的系列则不能完全移出。

我已在以下链接中重现了该问题:https://jsfiddle.net/8uxepk21/ 如您所见,这里有两个系列。具有静态数据的系列似乎正在发生变化,但如果您增加范围选择器的大小,则具有静态数据的系列不会完全移出图表,但仍然与其他系列不同。 是否有任何选项可以在不使用 series.addpoint() 方法的情况下显式转移数据。 我已经使用了series.data[0].remove(),它显然工作得很好,但是当一段时间后必须到达同一系列的新数据时,这个remove()方法将删除到达的数据点也。此外,如果我提供任何条件让最大点在移位时串联,即使这样也会导致性能问题。

预期结果:无论数据是静态还是动态,两个系列数据都必须完全移动。

// Create the chart
Highcharts.stockChart('container', {
    chart: {
        events: {
            load: function () {

                // set up the updating of the chart each second
                var series1 = this.series[0];
                setInterval(function () {
                    var x = (new Date()).getTime(), // current time
                        y = Math.round(Math.random() * 100);
                    series1.addPoint([x, y], true, true);
                }, 2000);
                var series2 = this.series[1];
                //setInterval(function () {
                    //var x = (new Date()).getTime(), // current time
                       // y = Math.round(Math.random() * 50);
                    //series2.addPoint([x, y], true, true);
                //}, 2000);
            }
        }
    },

    time: {
        useUTC: false
    },

    rangeSelector: {
        buttons: [{
            count: 1,
            type: 'minute',
            text: '1M'
        }, {
            count: 5,
            type: 'minute',
            text: '5M'
        }, {
            type: 'all',
            text: 'All'
        }],
        inputEnabled: false,
        selected: 0
    },

    title: {
        text: 'Live random data'
    },

    exporting: {
        enabled: false
    },
legend: {
                enabled: true
            },
plotOptions: {
        series: {
            marker: {
                states: {
                    hover: {
                        enabled: true,
                        animation: {duration: 100},
                        enableMouseTracking: true,
                        stickyTracking: true
                    }
                }
            }
        }
    },

tooltip:{
								shared: true,
                split: false,
  							stickyTracking: true,
                enableMouseTracking: true,
                enabled: true,
                followPointer: true,
                followTouchMove: true,
						    formatter: function(){
                var tooltip = "";
                var phaseNameList = "";
                
                //tooltip += "<b>I-unit "+ "<br/>"+ "x: "+this.x +"</b>";
                tooltip += "<b>I-unit "+ "<br/>"+ "x: "+ new Date(this.x)+
                "</b>";
                tooltip +=  "<br/>"+ "y: "+this.y +"</b>";
                tooltip +=  "<br/>"+ this + "</b>";
                return tooltip;
               }
},

    series: [{
        name: 'Random data1',
        data: (function () {
            // generate an array of random data
            var data = [],
                time = (new Date()).getTime(),
                i;

            for (i = -90; i <= 0; i += 1) {
                data.push([
                    time + i * 1000,
                    Math.round(Math.random() * 100)
                ]);
            }
            return data;
        }())
    },
    {
    name: 'Random data2',
        data: (function () {
            // generate an array of random data
            var data = [],
                time = (new Date()).getTime(),
                i;

            for (i = -90; i <= 0; i += 1) {
                data.push([
                    time + i * 1000,
                    Math.round(Math.random() * 50)
                ]);
            }
            return data;
        }())
    }]
});
<script src="https://code.highcharts.com/stock/highstock.js"></script>
<script src="https://code.highcharts.com/stock/modules/exporting.js"></script>
<script src="https://code.highcharts.com/stock/modules/export-data.js"></script>

<div id="container" style="height: 400px; min-width: 310px"></div>

最佳答案

要实现此目的,您可以将具有 null 值的点添加到第二个系列中。检查下面发布的代码和演示。

代码:

  chart: {
    events: {
      load: function() {
        var chart = this,
          series1 = chart.series[0],
          series2 = chart.series[1],
          x, y;

        setInterval(function() {
          x = (new Date()).getTime();
          y = Math.round(Math.random() * 100);
          series1.addPoint([x, y], false, true);
          series2.addPoint([x, null], false, true);

          chart.redraw();
        }, 2000);
      }
    }
  }

演示:

关于javascript - 在 Highcharts 中,没有动态数据的系列不会移动,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57074791/

相关文章:

php - 如何将变量从php页面传递给javascript并显示数据

Highcharts 在 2 条不同的行上写入 xaxis 值

r - 在 Highcharter 工具提示中格式化日期时间

javascript - 如果行的所有元素都不是值(NaN、null、未定义),如何删除数组数组中的行?

javascript - jQuery stopPropagation 无效

Highcharts:当没有位置数据时断开线路

javascript - 使用库合并两个或多个图形

javascript - 使用 highchart 时如何从工具提示中删除项目符号?

JSON 中的 Javascript 函数名称?

javascript - 使用嵌入代码跟踪访问