繁体   English   中英

缩放 d3 的直方图 x 域会导致“无效的负值<rect>属性”错误

[英]Scaling d3's histogram x domain causes "Invalid negative value for <rect> attribute" errors

我正在尝试使用 D3 显示直方图。

我从这里官方示例开始,并尝试更改 x 域的比例。

但是,如果我更改 x 域的比例,则会在各个直方图桶的宽度上出现错误。

示例中的代码有效( jsfiddle ):

var x = d3.scale.linear()
  .domain([0, 1])
  .range([0, width]);

但这不是( jsfiddle ):

var x = d3.scale.linear()
  .domain([0.2, 1])
  .range([0, width]);

其他人提到,为了缩放 x 轴,你应该使用这个:

var x = d3.scale.linear()
  .domain(d3.extent(data))
  .range([0, width]);

但是,这是不可能的,因为尚未创建数据,因为数据需要 x:

var x = d3.scale.linear()
  .domain([60, 95])
  .range([0, width]);

// Generate a histogram using twenty uniformly-spaced bins.
var data = d3.layout.histogram()
  .bins(x.ticks(7))
  (values);

那么如果需要 x 来创建数据,我该如何使用数据来创建 x 呢?

请注意,缩放直方图的大边确实有效:

var x = d3.scale.linear()
  .domain([0, Number(d3.max(values))])
  .range([0, width]);

然而,如果小边不是零,事情就会破裂:

var x = d3.scale.linear()
  .domain([Number(d3.min(values)), Number(d3.max(values))])
  .range([0, width]);

您计算条形宽度的方式对于您的特定用例是不正确的; 特别是它会导致负宽度(如错误消息所示)。 您需要取范围的宽度并将其除以项目数(如果您想要间隙,则减去一个小数字):

.attr("width", (x.range()[1] - x.range()[0]) / data.length - 2)

在这里完成演示。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM