Highcharts:显示前的工具提示延迟

时间:2016-09-27 09:03:00

标签: javascript highcharts tooltip

在我的高潮图上,我需要延迟才能显示系列工具提示。

我定义了一个带有计时器的新刷新功能来实现它。如果计时器准备好,我检查鼠标位置。如果移动不那么多,则应该出现工具提示。

function (H) {
              var timer = [];
              var mousePosition = {
                  x: 0,
                  y: 0
              };

              window.addEventListener("mousemove", function (event) {
                  mousePosition.x = event.pageX;
                  mousePosition.y = event.pageY;
              });

              var getMousePositionX = function () {
                  return mousePosition.x;
              };

              var clearTimer = function () {
                  timer = [];
              }

              H.wrap(H.Tooltip.prototype, 'refresh', function (proceed) {
                  var mousePosX = getMousePositionX();
                  var delayForDisplay = this.chart.options.tooltip.delayForDisplay ? this.chart.options.tooltip.delayForDisplay : 1000;
                  timer[timer.length+1] = window.setTimeout(function () {
                      var currMousePosX = getMousePositionX();
                      if ((mousePosX >= currMousePosX - 5 && mousePosX <= currMousePosX + 5)) {
                          this.proceed.apply(this.tooltip, this.refreshArguments);
                          clearTimer();
                      }
                  }.bind({
                      refreshArguments: Array.prototype.slice.call(arguments, 1),
                      chart: this.chart,
                      tooltip: this,
                      clearTimer: clearTimer,
                      proceed: proceed
                  }), delayForDisplay);
              });
          };

我遇到的问题是,悬停全息也有延迟。

以下是一个示例:JSFiddle

针对此问题的任何解决方案?

1 个答案:

答案 0 :(得分:2)

您可以根据标准的Highcharts工具提示制作新的工具提示,并在鼠标悬停时显示一些超时:

load: function() {
  chart = this;
  this.myTooltip = new Highcharts.Tooltip(this, this.options.tooltip);
  this.tooltip.label.element.remove();
}


    point: {
      events: {
        mouseOver: function(e) {
          var i = this.x;
          points = [];
          Highcharts.each(this.series.chart.series, function(s) {
            Highcharts.each(s.data, function(p) {
              if (p.x === i) {
                points.push(p)
              }
            })
          });
          myTooltip = chart.myTooltip;
          setTimeout(function() {
            myTooltip.refresh(points, e)
          }, 1000)

        }, mouseOut: function() {
        setTimeout(function() {
        chart.myTooltip.hide();
          }, 1000)
        }
      }
    }

在这里,您可以看到一个示例:http://jsfiddle.net/az39das8/