以下示例显示了D3.js中的圆环图,是否可以在图表中添加多个响铃?
var dataset = {
apples: [53245, 28479, 19697, 24037, 40245],
};
var width = 460,
height = 300,
radius = Math.min(width, height) / 2;
var color = d3.scale.category20();
var pie = d3.layout.pie()
.sort(null);
var arc = d3.svg.arc()
.innerRadius(radius - 100)
.outerRadius(radius - 50);
var svg = d3.select("body").append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");
var path = svg.selectAll("path")
.data(pie(dataset.apples))
.enter().append("path")
.attr("fill", function(d, i) { return color(i); })
.attr("d", arc);
示例:http://jsfiddle.net/gregfedorov/Qh9X5/9/
因此,在我的数据集中,我需要以下内容:
var dataset = {
apples: [53245, 28479, 19697, 24037, 40245],
oranges: [53245, 28479, 19697, 24037, 40245],
lemons: [53245, 28479, 19697, 24037, 40245],
pears: [53245, 28479, 19697, 24037, 40245],
pineapples: [53245, 28479, 19697, 24037, 40245],
};
我想要的是在同一个中心点共有5个响铃,这是否可行,有没有人有例子?
答案 0 :(得分:17)
是的,你可以很容易地做到这一点。关键是使用nested selections。也就是说,您传入列表的顶级列表并为每个列表创建容器元素。然后执行嵌套选择并绘制实际元素。在这种特殊情况下,您还需要调整弧的半径,使它们不重叠。
var gs = svg.selectAll("g").data(d3.values(dataset)).enter().append("g");
var path = gs.selectAll("path")
.data(function(d) { return pie(d); })
.enter().append("path")
.attr("fill", function(d, i) { return color(i); })
.attr("d", function(d, i, j) {
return arc.innerRadius(10+cwidth*j).outerRadius(cwidth*(j+1))(d);
});
更新了jsfiddle here。
答案 1 :(得分:2)
使用你发布的小提琴,这里有一个“弧形”:
var arc = d3.svg.arc()
.innerRadius(radius - 100)
.outerRadius(radius - 50);
这个弧是用于构建环形图的地方:
var path = svg.selectAll("path")
.data(pie(dataset.apples))
.enter().append("path")
.attr("fill", function(d, i) { return color(i); })
.attr("d", arc);
因此,如果您为每个具有各种半径的数据集创建了不同的弧,则图表中会有额外的环。