Javascript 甜甜圈图表d3.js
我试图修改这个例子。我想创建两个数据数组,并使用特殊的Javascript 甜甜圈图表d3.js,javascript,d3.js,pie-chart,Javascript,D3.js,Pie Chart,我试图修改这个例子。我想创建两个数据数组,并使用特殊的mergingAr()函数而不是data.csv来合并它们。但它不起作用。有一张没有任何数据的彩色图表。我在代码中找不到问题所在。这就是: var width = 250, height = 250, radius = 230; var arr1 = [44, 64]; //age var arr2 = [14106543, 8819342]; //population function type(d) { d[1]
mergingAr()
函数而不是data.csv
来合并它们。但它不起作用。有一张没有任何数据的彩色图表。我在代码中找不到问题所在。这就是:
var width = 250,
height = 250,
radius = 230;
var arr1 = [44, 64]; //age
var arr2 = [14106543, 8819342]; //population
function type(d) {
d[1] = +d[1];
return d;
}
function mergingAr(array1, array2)
{
var i, out = [];
for(i=0;i<array1.length;i++)
{
out.push([array1[i],array2[i]]);
}
return out;
}
var data = mergingAr(arr1, arr2);
var color = d3.scale.ordinal()
.range(["#EB7221", "#8a89a6", "#7b6888", "#6b486b", "#a05d56", "#d0743c", "#ff8c00"]);
var arc = d3.svg.arc()
.outerRadius(radius - 100)
.innerRadius(radius - 180);
var pie = d3.layout.pie()
.sort(null)
.value(function(d) { return d[1]; });
var svg = d3.select("#pie").append("svg")
.attr("width", width)
.attr("height", height)
.append("g")
.attr("transform", "translate(" + width / 2 + "," + height / 2 + ")");
var g = svg.selectAll(".arc")
.data(pie(data))
.enter().append("g")
.attr("class", "arc");
g.append("path")
.attr("d", arc)
.style("fill", function(d) { return color(d[0]); });
g.append("text")
.attr("transform", function(d) { return "translate(" + arc.centroid(d) + ")"; })
.attr("dy", ".35em")
.style("text-anchor", "middle")
.text(function(d) { return d[0]; });
var legend = svg.selectAll(".legend")
.data(color.domain())
.enter().append("g")
.attr("class", "legend")
.attr("transform", function(d, i) { return "translate(0," + i * 20 + ")"; });
legend.append("rect")
.attr("x", width - 18)
.attr("width", 18)
.attr("height", 18)
.style("fill", color);
legend.append("text")
.attr("x", width - 24)
.attr("y", 9)
.attr("dy", ".35em")
.style("text-anchor", "end")
.text(function(d) { return d; });
var宽度=250,
高度=250,
半径=230;
var arr1=[44,64]//年龄
var arr2=[141065438819342]//人口
功能类型(d){
d[1]=+d[1];
返回d;
}
函数mergingAr(array1,array2)
{
var i,out=[];
对于(i=0;i您的数据在那里,但您的颜色是错误的。现在,您有以下行设置路径颜色:
.style("fill", function(d) { return color(d[0]); });
问题在于数据是一个对象,而不是一个数组。(它由饼图
函数转换),因此需要引用对象上的数据
属性,然后获取该数组的零索引,如下所示:
.style("fill", function(d) { return color(d.data[0]); });