D3多列相对堆栈图

时间:2015-03-07 20:18:08

标签: javascript svg d3.js data-visualization

我目前正在修改以下示例以生成多水平相对堆栈图表。以下示例是"单个"堆栈图示例。

http://jsfiddle.net/zDkWP/

这是我的版本,但是我得到了NaN X和Width值,我想找出原因。谢谢。

在SVG中,每个结构的结构如下: -

g [g [rect,rect,rect]],g [g [rect,rect,rect]]

这是我的代码:http://jsfiddle.net/scottietom/7c3vb4e9/

        var dataset = [
                       [
                        [{x: 0,y: 100}],[{x: 0,y: 30}],[{x: 0,y: 50}]], 
                        [[{x: 0,y: 100}],[{x: 0,y: 30}],[{x: 0,y: 50}]]
                      ];

        //Set up stack method
        var stack = d3.layout.stack();

        //Data, stacked
        for (i=0; i<dataset.length; i++) {
          stack(dataset[i]);
        }

        //Set up scales
        var xScale = d3.scale.linear()
            .domain([0, d3.max(dataset, function (d) {
                return d3.max(d, function (d) {
                return d.y0 + d.y;
            });
        })])
        .range([0, w]);

        //Easy colors accessible via a 10-step ordinal scale
        var colors = d3.scale.category10();
        //or make your own colour palet
        var color = d3.scale.ordinal()
            .range(["#1459D9", "#148DD9", "#87ceeb", "#daa520"]);

        //Create SVG element
        var svg = d3.select(".pathanalysis_diagram")
            .append("svg")
            .attr("width", w + margin.left + margin.right)
            .attr("height", h + margin.top + margin.bottom)
            .append("g")
            .attr("transform", "translate(" + margin.left + "," + margin.top + ")");

        // Add a group for each row of data
        var groups = svg.selectAll("g")
            .data(dataset)
            .enter()
            .append("g")
            .style("fill", function (d, i) {
            return color(i);
        });

        // Add a rect for each data value
        var rects = groups.selectAll("rect")
            .data(function (d) {
                return d;
            })
            .enter()
            .append("rect")
            .attr("x", function (d) {
                return xScale(d.y0);
            })
            .attr("y", 50)
            .attr("height", 50)
            .attr("width", function (d) {
                return xScale(d.y);
            });

1 个答案:

答案 0 :(得分:1)

以下是您的解决方案的JSFiddle:http://jsfiddle.net/ee2todev/z73u6mro/

我调用了嵌套数据集arrayOfDatasets,因此更改变得更加清晰。 首先,您必须为每个数据集调用stack():

arrayOfDatasets.forEach(function (dataset) {stack(dataset); });

然后你必须检索xScale的最大值:

var xScale = d3.scale.linear()
    .domain([0, d3.max(arrayOfDatasets, function (dataset) {      
      return d3.max(dataset, function (d) {
        return d3.max(d, function (d) {
            return d.y0 + d.y;
        });
      })
    })])
    .range([0, w]);

最后,您只需要正确访问数据并转换数据集,使它们不重叠:

var groupOfGroups = svg.selectAll("g.toplevel")
    .data(arrayOfDatasets)
    .enter()
    .append("g")
    .attr("class", "toplevel")
    .attr("transform", function(d, i ) {return "translate(0, " + (-i * 55) + ")"; });   

// Add a group for each row of data
var groups = groupOfGroups.selectAll("g.dataset")
    .data(function(d) {return d; })
    .enter()
    .append("g")
    .attr("class", "dataset")
    .style("fill", function (d, i) {
    return color(i);
});

您可能仍会以不同的方式存储数据集,因为不清楚为什么要在其中包含x值。