D3 多列相对堆栈图
D3 Multicolumn Relative Stack Chart
我目前正在修改以下示例以生成多水平相对堆栈图。以下示例是"单个"堆栈图示例。
http://jsfiddle.net/zDkWP/
这是我的版本,但是我得到了 NaN X 和宽度值,我正在寻找找出原因。谢谢。
在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);
});
下面是
包含您的解决方案的 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 值。
相关文章:
- 我可以获得相对于被点击元素的确切点击位置吗
- Rails File_field最大堆栈大小
- d3中堆栈函数和嵌套函数之间的差异
- 是什么让一个“;Uncaught RangeError:超过了最大调用堆栈大小“;错误(Chrome,在其他浏览器中显示
- 固定位置菜单时滚动,直到它击中一个相对容器的底部
- 可以用'吗/'在相对路径中
- JavaScript:单击时相对于父级增加变量值
- 为什么我的JavaScript堆栈排序函数不起作用
- 在不移动元件的情况下从相对位置更改为固定位置
- 超过了async.detect最大调用堆栈大小
- 如何远程检查JavaScript应用程序的函数调用堆栈
- 打开相对于鼠标位置的CSS3/HTML5模式对话框
- 抵消在具有pageY计算的相对容器中位于顶部
- 超过了最大调用堆栈大小,循环无限
- Fresh Spark Install+Homestead上的Vue异步堆栈跟踪错误
- Chrome原生拖放相对容器并不能正确渲染重影
- 如何确定相对较新版本的IE的高度和宽度(IE8不喜欢从JavaScript设置这种样式吗?
- 超过了最大调用堆栈大小.递归标签
- 使用MEAN堆栈-查询MongoDB并将值作为变量传递
- D3 多列相对堆栈图