D3 donut chart text centering
Asked Answered
D

1

6

I'm using a d3 donut chart for a project and I'm having issues centering the text inside the donut. I found a piece of code that I have modifying, but frankly I don't understand it much.

I have added the text in the center, but it's not quite centered. Is there anyone that could help me center it? I tried adding 'margin-top' to bring it down but that doesn't work, nor do a lot of css things I tried.

Here's the specific part that attaches the text:

 svg.append("text")
       .attr({
         "text-anchor": "middle",
       }).style({'fill': 'red', 'font-size': '18px'}).text(calories);
};

Codepen: http://codepen.io/anon/pen/xwwBBm

Dayton answered 12/9, 2015 at 16:50 Comment(4)
Try this #28097684Setscrew
that's exactly the question I used to help me add the middle text in the first place. The result is what you see in my codepen. It's not centered.Dayton
I understand. What I see is a vertical alignment problem. I'm not really a svg expert, but here is a closer example for this: #19622921Setscrew
Try add for the text this too: transform-origin: 0px 0px 0px;Setscrew
K
7

You may have noticed that two labels outside the circle are vertically centered, but the one in the middle is not.

It is missing following line:

 .attr('dy', '0.35em')

This is the new codepen.

enter image description here

I will leave to you to discover why is that line magical.

Kaiserdom answered 12/9, 2015 at 20:40 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.