我正在使用D3.js v5在Angular中创建一个甜甜圈图。所有其他简单的图形(如条形图,圆形,线形等)都可以正常工作,但是“ pie()”函数会产生一些错误。谁能建议我如何在Angular中正确使用pie()函数?
在以下提到的情况下我遇到了错误。
在设置颜色域时,它不接受数据,它说,它需要ReadOnlyArray<String>
,因此尝试提供硬编码域["a","b","c","d","e"]
pie()
->不接受值,不知道为什么,在这里尝试了很多。
this.color(d.data.key))
-> this.color
不接受访问数据和密钥。
需要解决所有上述问题。
export class DonutChartComponent implements OnInit {
width = 450
height = 450
margin = 40
radius;
svg;
color;
pie;
data_ready;
// Create dummy data
public data = {a: 9, b: 20, c:30, d:8, e:12}
constructor() { }
ngOnInit() {
this.draw();
}
draw(){
this.radius = Math.min(this.width, this.height) / 2 - this.margin
this.svg = d3.select("app-donut-chart")
.append("svg")
.attr("width", this.width)
.attr("height", this.height)
.append("g")
.attr("transform", "translate(" + this.width / 2 + "," +
this.height / 2 + ")");
// set the color scale
this.color = d3.scaleOrdinal()
.domain(this.data) // this.data gives error here
.range(d3.schemeDark2);
console.log(d3.scaleOrdinal());
// Compute the position of each group on the pie:
this.pie = d3.pie()
.value(function(d) {return d.values}); //error here
this.data_ready = this.pie(d3.entries(this.data))
this.svg
.selectAll('whatever')
.data(this.data_ready)
.enter()
.append('path')
.attr('d', d3.arc()
.innerRadius(100) // This is the size of the donut hole
.outerRadius(this.radius))
.attr('fill', function(d){ return(this.color(d.data.key)) })
//error here
.attr("stroke", "black")
.style("stroke-width", "2px")
.style("opacity", 0.7)
}
}
我希望代码能够正常运行,根据给出的数据,我可以看到一个甜甜圈图。
答案 0 :(得分:0)
纠正错误:
您的色标的.domain
需要一个字符串列表。修改为:
.domain(Object.keys(this.data))
您的饼图生成器应定义为:
this.pie = d3.pie()
.value(function (d) { return d.value })
现在works。
答案 1 :(得分:0)
this.radius = Math.min(this.width, this.height) / 2 - this.margin;
this.svg = select("pie-chart")
.append("svg")
.attr("width", this.width)
.attr("height", this.height)
.append("g")
.attr("transform", "translate(" + this.width / 2 + "," +
this.height / 2 + ")");
this.color = scaleOrdinal()
.domain(Object.keys(this.data))
.range(schemeDark2);
console.log(scaleOrdinal());
this.pie = pie()
.value((d) => d.valueOf());
this.dataReady = this.pie(entries(this.data));
this.svg
.selectAll("whatever")
.data(this.dataReady)
.enter()
.append("path")
.attr("d", arc()
.outerRadius(this.radius))
.attr("fill", (d) => (this.color(d.data.key)))
.attr("stroke", "black")
.style("stroke-width", "2px")
.style("opacity", 0.7);