javascript - 使用 d3.nest 创建饼图

标签 javascript d3.js nested pie-chart

我有各种各样的数据,我用它来创建一个圆环图。我想使用数据分割来制作饼图,这些数据是我使用 d3.nest 获取的,以分割我拥有的数据(目前分为 3 个类别:nest 将其分割为 129 个类别)。基本上,我有基于授予奖牌的奥运会数据,并且我想将交互数据分割为他们获得的运动项目。

我只是不确定如何使用嵌套数据创建饼图,特别是在键可变的情况下。我将包括我对圆环图的实现。

  var pie = d3.pie();

  // color based on medal awarded
  // order: gold, silver, bronze
  var color = d3.scaleOrdinal()
    .range(['#e5ce0c', '#e5e4e0', '#a4610a']);

  var arcs = d3.select(svg).selectAll("g.arc")
    .data(pie(data))
    .enter()
    .append("g")
    .attr("class", "arc")
    .attr("transform", "translate(" + (w/2) + "," + ((h-25)/2) + ")");

  arcs.append("path")
  .attr("fill", function(d, i) {
    return color(i);
  })
  .attr("d", arc)
  .attr("stroke", "white")
  .style("stroke-width", "0.5px")
  .on('mouseover', function(d) {
    d3.select(this).attr('opacity', .7);

  })
  .on('mouseleave', function(d) {
    d3.select(this).attr('opacity', 1);
  });

  // title
  d3.select(svg).append('text')
    .attr('x', function(d) {
      return ((w/2) - 85);
    })
    .attr('y', '20')
    .text(function(d) {
      return ('Medal breakdown for ' + country);
    })
    .attr('font-size', '16px');

  arcs.append("text")
    .attr("transform", function(d) {
      return "translate(" + arc.centroid(d) + ")";
    })
    .attr("text-anchor", "middle")
    .text(function(d) {
      return d.value;
    });

最佳答案

您能确认一下您的数据格式是这样吗?

请查找下面的代码,如果您有任何疑问,请告诉我。

var w = 400;
var h = 400;
var r = h/2;
var color = d3.scale.category20c();

var data = [
{name:"football", medal:1},
{name:"hockey", medal:2},
{name:"cricket", medal:3},
{name:"tennis", medal:4},
{name:"table tennis", medal:5},
];


var vis = d3.select('#chart').append("svg:svg").data([data]).attr("width", w).attr("height", h).append("svg:g").attr("transform", "translate(" + r + "," + r + ")");
var pie = d3.layout.pie().value(function(d){return d.medal;});

// declare an arc generator function
var arc = d3.svg.arc().outerRadius(r);

// select paths, use arc generator to draw
var arcs = vis.selectAll("g.slice").data(pie).enter().append("svg:g").attr("class", "slice");
arcs.append("svg:path")
    .attr("fill", function(d, i){
        return color(i);
    })
    .attr("d", function (d) {
        // log the result of the arc generator to show how cool it is :)
        return arc(d);
    });

// add the text
arcs.append("svg:text").attr("transform", function(d){
			d.innerRadius = 0;
			d.outerRadius = r;
    return "translate(" + arc.centroid(d) + ")";}).attr("text-anchor", "middle").text( function(d, i) {
    return data[i].name;}
		);
<script src="https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.15/d3.min.js"></script>
<div id="chart"></div>

关于javascript - 使用 d3.nest 创建饼图,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60299152/

相关文章:

javascript - 当任何状态发生变化时,在 React 组件的渲染函数中调用返回 JSX 的方法是否会影响性能?

Javascript变量包含特殊字符

javascript - 将圆排列成行

javascript - 如何使用 D3 在 Angular 中使用 'this'?

mysql - 获取mysql中嵌套查询的值

java - 通过 Javascript 进行 Vertx 3 应用程序日志记录

javascript - 为什么访问给定位置旁边的元素会出现错误,而访问前一个元素却可以正常工作?

html - 无法使移动响应

javascript - 在 JavaScript 中嵌套 if else

c# - Linq 将许多表的结果转换为具有嵌套类的继承类