Stacked Bar Flot 条形图使用工具提示显示每个系列中每个类别的值

Stacked Bar Flot bar chart show values of every category in each series with tooltip

使用下面的这个实现:

$.fn.UseStackBarTooltip = function (module) {
$(this).bind("plothover", function (event, pos, item) {
    if (item) {
        if ((previousLabel != item.series.label) || (previousPoint != item.dataIndex)) {
            previousPoint = item.dataIndex;
            previousLabel = item.series.label;
            $("#tooltip").remove();

            var x = item.datapoint[0];
            var y = item.datapoint[1] - item.datapoint[2];
            var formated = y.toLocaleString();

            var color = item.series.color;

            showStackTooltip(item.pageX,
                item.pageY,
                color,
                "<strong>" + item.series.label + "</strong><br><strong>" + formated + "</strong>", module);
        }
    } else {
        $("#tooltip").remove();
        previousPoint = null;
    }
});};

当我将鼠标悬停在所选栏上时,我可以显示所选类别的值,我想做的是我只想在一次悬停中显示所选栏上每个类别的所有值。是否有可能做到这一点?谢谢!

当您处于悬停事件中并悬停在某个项目上时,您必须遍历 x 轴索引上的数据值才能获得剩余的堆叠值:

$("#graph").bind("plothover", function(event, pos, item) {

  // if we're hovering over an item
  if (item) {
    // get the data in the plot
    var plotData = plot.getData();
    var valueString = "";

    // loop through the data and grab each value in the same stack
    for (var i = 0; i < plotData.length; ++i) {
      var series = plotData[i];
      for (var j = 0; j < series.data.length; ++j) {
        // item.datapoint[0] contains the x axis value of the hovered over item
        // ensure we get the other values at the same x axis value.
        if (series.data[j][0] === item.datapoint[0]) {
          valueString += series.data[j][1] + " ";
        }
      }
    }

    // show the tool tip here - the valueString object has all the values in the stack

  }
});

下面的示例显示了工具提示中堆栈的值 - 您需要根据需要格式化字符串。

$(function() {
  var data = [{
    data: [
      [0, 21.51],
      [1, 32.50],
      [2, 47.14],
      [3, 10]
    ],
    stack: 0,
    label: 'Bottom'
  }, {
    data: [
      [0, 37.77],
      [1, 24.65],
      [2, 7.67],
      [4, 15]
    ],
    stack: 0,
    label: 'Top'
  }];

  var options = {
    series: {
      bars: {
        show: true,
        barWidth: .5,
        align: "center"
      },
      points: {
        show: false
      }
    },
    grid: {
      show: true,
      hoverable: true,
    }
  };

  var plot = $.plot($('#graph'), data, options);

  $("#graph").bind("plothover", function(event, pos, item) {
  
    $("#tooltip").remove();

    if (item) {
      var plotData = plot.getData();
      var valueString = "";

      for (var i = 0; i < plotData.length; ++i) {
        var series = plotData[i];
        for (var j = 0; j < series.data.length; ++j) {
          if (series.data[j][0] === item.datapoint[0]) {
            valueString += series.data[j][1] + " ";
          }
        }
      }

      $("<div id='tooltip'>" + valueString + "</div>").css({
        position: "absolute",
        display: "none",
        top: pos.pageY + 5,
        left: pos.pageX + 5,
        border: "1px solid #fdd",
        padding: "2px",
        "background-color": "#fee",
        opacity: 0.80
      }).appendTo("body").fadeIn(200);

    }
  });
});
#graph {
  width: 600px;
  height: 400px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/flot/0.8.3/jquery.flot.js"></script>
<script src="https://rawgit.com/flot/flot/master/jquery.flot.stack.js"></script>
<div id="graph"></div>

$("#graph").bind("plothover", function(event, pos, item) {

  // if we're hovering over an item
  if (item) {
    // get the data in the plot
    var plotData = plot.getData(); 
    var valueString = plotData[item.seriesIndex].data[item.dataIndex][1];
    // show the tool tip here - the valueString object has all the values in the stack

  }
});