当图表具有不同的宽度时,同步的HighCharts不起作用

时间:2017-03-01 10:31:08

标签: javascript charts highcharts

在HighCharts中,我按照Synchronized multi charts中的说明尝试了Fiddle。如果所有图表都具有相同的宽度,则效果很好。

$('#container').bind('mousemove touchmove touchstart', function (e) {
    var chart,
        point,
        i,
        event;

    for (i = 0; i < Highcharts.charts.length; i = i + 1) {
        chart = Highcharts.charts[i];
        event = chart.pointer.normalize(e.originalEvent); // Find coordinates within the chart
        point = chart.series[0].searchPoint(event, true); // Get the hovered point

        if (point) {
            point.highlight(e);
        }
    }
});

但如果我将图表的宽度更改为不同的大小,则工具提示无法正确同步。您可以查看Fiddle

即使图表尺寸不同,有没有办法同步?

1 个答案:

答案 0 :(得分:3)

如果您的数据具有相同的x坐标,则可以从悬停图表中捕获该点,然后在其他两个图表中找到相应的点 - 并调用highlight()

function highlightPoints(e) {
  const container = this;
  const charts = Highcharts.charts.slice();
  const chartIndex = charts.findIndex(chart => chart.renderTo === container);

  if (chartIndex > -1) {
    const chart = charts.splice(chartIndex, 1)[0];

    const event = chart.pointer.normalize(e.originalEvent); // Find coordinates within the chart
    const point = chart.series[0].searchPoint(event, true); // Get the hovered point

    if (point) {
      const x = point.x;
      point.highlight(e);

      charts.forEach(chart => {
        const points = chart.series[0].points;
        for (let i = 0; i < points.length; i = i + 1) {
          if (points[i].x === x) {
            points[i].highlight(e);
            break;
          }
        }
      })
    }
  }
}

绑定mousemove事件

  $('.chart-0, .chart-1, .chart-2').on('mousemove', highlightPoints);

示例:http://jsfiddle.net/5vcc6z40/