首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >D3.js甜甜圈图表...arc.centroid(d)不受d.innerRadius和d.outerRadius的影响

D3.js甜甜圈图表...arc.centroid(d)不受d.innerRadius和d.outerRadius的影响
EN

Stack Overflow用户
提问于 2013-04-17 22:05:19
回答 1查看 8.5K关注 0票数 3

我正在创建一个甜甜圈(或拼图),我想把标签放在区域的外面。我已经为它创建了一个fiddle http://jsfiddle.net/VeeTee/mA3V7/

代码语言:javascript
复制
arcs.append("svg:text")
    .attr("transform", function(d) {
        //this is where I want to make a translation to the outside border
        d.innerRadius = radius;
        d.outerRadius = height/2;
        return "translate(" + arc.centroid(d) +")";
    })
    .attr("dy", ".35em")
    .attr("text-anchor", "middle")
    .text(function(d, i) { return d.value.toFixed(2); });

arc.centroid(d) ->总是给出相同的结果(因此也是相同的翻译)

EN

回答 1

Stack Overflow用户

发布于 2013-04-17 23:15:14

不确定你所说的总是给你相同的结果是什么意思,但是你可以通过将质心的坐标乘以1.5来将标签放在图表之外。代码是这样的。

代码语言:javascript
复制
.attr("transform", function(d) {
        var c = arc.centroid(d);
        return "translate(" + c[0]*1.5 +"," + c[1]*1.5 + ")";
    })

更新了jsfiddle here

票数 9
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/16062257

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档