d3.layout.stack()带有'wiggle'偏移问题

时间:2014-07-15 15:25:11

标签: javascript layout d3.js offset stream-graph

我在d3中编写了一个函数,以便在样本页面中创建显示不同数据集的多个图。

我使用流程图和堆栈布局,我无法理解为什么使用相同的代码我可以使用偏移zeroexpandsilhouette生成图表相同的数据集和相同的堆栈布局wiggle偏移量不会产生任何结果。 (我已经多次阅读过文档)

以下是代码的摘录:

var stack = d3.layout.stack()
    .values(function(d) {
        return d.values;
    }).offset(o || 'silhouette');// o could be one of [expand, wiggle, zero, silhouette]

var layers = stack(stacked.datalayers()); // See after this piece of code

var maxY = d3.max(layers, function(c) {
    return d3.max(c.values, function(d) {
        return d.y0 + d.y;
    });
});

var x = d3.scale.ordinal().domain(stacked.x()).rangeRoundBands([0, w]); // stacked.x() returns an array with the min and the max values for X
var y = d3.scale.linear().domain([0, maxY]).range([h, 0]);

var area = d3.svg.area()
        .x(function(d) {
            return x(d.x) + (x.rangeBand() / 2);
        })
        .y0(function(d) {
            return y(d.y0);
        })
        .y1(function(d) {
            return y(d.y0 + d.y);
        }).interpolate("monotone");

...

series.append("path")
        .attr("d", function(d) {
            return area(d.values);
        })
        .style("fill", function(d) {
            return color(cdomain.indexOf(d.name));
        })
        .style("fill-opacity", ".5")
        .style("stroke", function(d) {
            return color(cdomain.indexOf(d.name));
        })
        .style("stroke-width", "2px");

这是从stacked.datalayer()

返回的数据结构
[
  {
    "name": "US",
    "values": [
      {
        "x": "01/2014",
        "y": 1.726118500604595,
        "name": "US",
        "y0": 0.8662854227545267
      },
      {
        "x": "02/2014",
        "y": 2.5897229845496037,
        "name": "US",
        "y0": 0.38969767845094694
      },
      {
        "x": "03/2014",
        "y": 2.388349800480026,
        "name": "US",
        "y0": 0.518912280793379
      }
    ]
  },
  {
    "name": "Europe28",
    "values": [
      {
        "x": "01/2014",
        "y": 0.42541539123546496,
        "name": "Europe28",
        "y0": 2.5924039233591216
      },
      {
        "x": "02/2014",
        "y": 0.5149863958976154,
        "name": "Europe28",
        "y0": 2.9794206630005506
      },
      {
        "x": "03/2014",
        "y": 0.4579303752823291,
        "name": "Europe28",
        "y0": 2.907262081273405
      }
    ]
  }
]

以下是结果的一些截图(使用相同的数据集):

抵消'零': offset 'zero'

抵消'扩大': offset 'expanded'

偏移'剪影': offset 'silhouette'

抵消'摆动': offset 'wiggle'

1 个答案:

答案 0 :(得分:3)

来自documentation for stack.x

  

访问者的返回值必须是数字。

默认访问者返回d.x,您的数据当前包含此属性的字符串(例如"01/2014")。您可以设置自己的访问者,也可以修改数据以使x值为数字。它仅影响wiggle模式的原因是它使用x值来计算渐变。