单击后保持更改NVD3图例的位置

时间:2017-06-30 12:53:42

标签: d3.js charts legend nvd3.js

我正在尝试将nvd3图表图例位置更改为图表底部。

我听说过:

d3.select(.nv-legendWrap).attr("transform", "translate(x, y)")

它实际上正在工作,但图例上的点击操作将替换它在图表的顶部。

我不知道如何使用de legendPostion函数(根据控制台不是函数)。

1 个答案:

答案 0 :(得分:0)

这样做之后(注意引号):

d3.select(".nv-legendWrap").attr("transform", "translate(x,y)")

如您所知,将图例移动到另一个位置,单击它时设置相同的位置:

d3.select(".nv-legendWrap").on("click", function(){
    d3.select(this).attr("transform", "translate(x,y)");
})

以下是一个示例,图例的原始位置位于顶部,但我将其移动到底部。点击它,它将保持在相同的位置:



var data = function() {
  return stream_layers(3,10+Math.random()*100,.1).map(function(data, i) {
    return {
      key: 'Stream' + i,
      values: data
    };
  });
}

/* Inspired by Lee Byron's test data generator. */
function stream_layers(n, m, o) {
  if (arguments.length < 3) o = 0;
  function bump(a) {
    var x = 1 / (.1 + Math.random()),
        y = 2 * Math.random() - .5,
        z = 10 / (.1 + Math.random());
    for (var i = 0; i < m; i++) {
      var w = (i / m - y) * z;
      a[i] += x * Math.exp(-w * w);
    }
  }
  return d3.range(n).map(function() {
      var a = [], i;
      for (i = 0; i < m; i++) a[i] = o + o * Math.random();
      for (i = 0; i < 5; i++) bump(a);
      return a.map(stream_index);
    });
}

/* Another layer generator using gamma distributions. */
function stream_waves(n, m) {
  return d3.range(n).map(function(i) {
    return d3.range(m).map(function(j) {
        var x = 20 * j / m - i / 3;
        return 2 * x * Math.exp(-.5 * x);
      }).map(stream_index);
    });
}

function stream_index(d, i) {
  return {x: i, y: Math.max(0, d)};
}

nv.addGraph(function() {
    var chart = nv.models.multiBarChart();

    chart.xAxis
        .tickFormat(d3.format(',f'));

    chart.yAxis
        .tickFormat(d3.format(',.1f'));
    
    chart.multibar.stacked(true); // default to stacked
    chart.showControls(false); // don't show controls

    d3.select('#chart svg')
        .datum(data())
      .transition().duration(500).call(chart);

    nv.utils.windowResize(chart.update);
    
    d3.select(".nv-legendWrap").attr("transform", "translate(0,340)");
    
    d3.select(".nv-legendWrap").on("click", function(){
    d3.select(this).attr("transform", "translate(0,340)");
    })

    return chart;
});
&#13;
#chart svg {
  height: 400px;
  width: 600px;
}
&#13;
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.4.11/d3.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.8.5/nv.d3.min.js"></script>
<div id="chart">
  <svg></svg>
</div>
&#13;
&#13;
&#13;

请注意,legendPosition方法非常有限,您只能选择topright

chart.legendPosition("top")
chart.legendPosition("right")