gpt4 book ai didi

d3.js - D3 Chart version 4 Normalized Stacked Bar Chart 从垂直到水平

转载 作者:行者123 更新时间:2023-12-02 15:16:57 25 4
gpt4 key购买 nike

这个问题与 D3JS question 非常相似但我使用的是最新的 D3 版本(//d3js.org/d3.v4.min.js)。

我正在尝试制作 this Normalized Stacked Bar Chart水平图表。最新版本有没有优化的方法来实现这个?

我已经交换了 x 轴和 y 轴,如下所示

var svg = d3.select("svg"),
margin = {top: 20, right: 60, bottom: 30, left: 40},
width = +svg.attr("width") - margin.left - margin.right,
height = +svg.attr("height") - margin.top - margin.bottom,
g = svg.append("g").attr("transform", "translate(" + margin.left + "," + margin.top + ")");

var y = d3.scaleBand()
.rangeRound([0, width])
.padding(0.1)
.align(0.1);

var x = d3.scaleLinear()
.rangeRound([height, 0]);

var z = d3.scaleOrdinal()
.range(["#98abc5", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);

var stack = d3.stack()
.offset(d3.stackOffsetExpand);

d3.csv("data.csv", type, function(error, data) {
if (error) throw error;

data.sort(function(a, b) { return b[data.columns[1]] / b.total - a[data.columns[1]] / a.total; });

y.domain(data.map(function(d) { return d.State; }));
z.domain(data.columns.slice(1));

var serie = g.selectAll(".serie")
.data(stack.keys(data.columns.slice(1))(data))
.enter().append("g")
.attr("class", "serie")
.attr("fill", function(d) { return z(d.key); });

serie.selectAll("rect")
.data(function(d) { return d; })
.enter().append("rect")
.attr("y", function(d) { return y(d.data.State); })
.attr("x", function(d) { return x(d[1]); })
.attr("height", function(d) { return x(d[0]) - x(d[1]); })
.attr("width", y.bandwidth());

g.append("g")
.attr("class", "axis axis--y")
.attr("transform", "translate(0," + height + ")")
.call(d3.axisBottom(y));

g.append("g")
.attr("class", "axis axis--x")
.call(d3.axisLeft(x).ticks(10, "%"));

var legend = serie.append("g")
.attr("class", "legend")
.attr("transform", function(d) { var d = d[d.length - 1]; return "translate(" + (y(d.data.State) + y.bandwidth()) + "," + ((x(d[0]) + x(d[1])) / 2) + ")"; });

legend.append("line")
.attr("x1", -6)
.attr("x2", 6)
.attr("stroke", "#000");

legend.append("text")
.attr("y", 9)
.attr("dy", "0.35em")
.attr("fill", "#000")
.style("font", "10px sans-serif")
.text(function(d) { return d.key; });
});

function type(d, i, columns) {
for (i = 1, t = 0; i < columns.length; ++i) t += d[columns[i]] = +d[columns[i]];
d.total = t;
return d;
}

最佳答案

指的是 example

您需要反转域:

  var y = d3.scaleBand()
.rangeRound([0, width])
.padding(0.1)
.align(0.1);

var x = d3.scaleLinear()
.rangeRound([height, 0]);

将 x 交换为 y,因为域是相反的,因此当您创建矩形时,x 将变为 y,y 将变为 x。

serie.selectAll("rect")
.data(function(d) {
return d;
})
.enter().append("rect")
.attr("y", function(d) {
return y(d.data.State);
})
.attr("x", function(d) {
return x(d[1]);
})
.attr("width", function(d) {
return x(d[0]) - x(d[1]);
})
.attr("height", y.bandwidth());

相应地更改图例位置以将其定位在顶部栏上。

var legend = serie.append("g")
.attr("class", "legend")
.attr("transform", function(d) {
var d = d[0];//get the top data for placing legends on that.
return "translate(" + ((x(d[0]) + x(d[1])) / 2) + ", " +(y(d.data.State) - y.bandwidth())+ ")";
});

最后定位图例线:

legend.append("line")
.attr("y1", 5)
.attr("x1", 15)
.attr("x2", 15)
.attr("y2", 12)
.attr("stroke", "#000");

工作代码here

关于d3.js - D3 Chart version 4 Normalized Stacked Bar Chart 从垂直到水平,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39700232/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com