我试图使以下饼图更漂亮:
尤其是标签有明显的问题。我想旋转它们并将它们居中放置在相应的饼图上方,但是我只能旋转它们。此外,旋转需要通过设置进行大量调整
pie_properties[1][0].set_rotation(30)
,每个标签的度数都不同。
是否有一种自动或至少更简单的方法来制作它?
这是我的代码:
import matplotlib.pyplot as plt
import numpy as np
fig, ax = plt.subplots()
### Data structure:
# Network type:
group_names = ['Group 1', 'Group 2', 'Group 3']
group_vals = [43,49,38]
group_colors = ['w']*3
#Information level:
info_names = ['Subgroup 1', 'Subgroup 2', \
'Subgroup 1', 'Subgroup 2',\
'SSubgroup 1', 'Subgroup 2']
info_vals = np.array([[27,16],[26,23],[14,24]])
my_blue = [x/255 for x in [30,144,255]]
info_colors = [my_blue,'gray',\
my_blue,'gray',\
my_blue,'gray']
corr_vals = np.array([[10,3,7,3,4], [4,4,4,2,2],\
[10,5,5,3,3], [10,5,5,1,2],\
[4,4,2,2,2], [12,2,2,1,7]])
pale_green = [x/255 for x in [152,251,152]]
pale_red = [x/255 for x in [240,128,128]]
pale_gray = [x/255 for x in [169,169,169]]
corr_colors = ['green',pale_green,pale_gray,pale_red,'red', 'green',pale_green,pale_gray,pale_red,'red',\
'green',pale_green,pale_gray,pale_red,'red', 'green',pale_green,pale_gray,pale_red,'red',\
'green',pale_green,pale_gray,pale_red,'red', 'green',pale_green,pale_gray,pale_red,'red',]
#inner layer
pie_properties = ax.pie(group_vals, radius=1, colors=group_colors,
labels=group_names, labeldistance=0.7,
wedgeprops=dict(width=0.3, edgecolor='k'))
pie_properties[1][0].set_rotation(-45) #<===rotation
pie_properties[1][1].set_rotation(90)
pie_properties[1][2].set_rotation(-135)
#middle layer
pie_properties = ax.pie(info_vals.flatten(), radius=1+0.4, colors=info_colors,
labels=info_names, labeldistance=0.7,
wedgeprops=dict(width=0.4, edgecolor='w'))
pie_properties[1][0].set_rotation(-45)
pie_properties[1][1].set_rotation(15)
pie_properties[1][2].set_rotation(65)
pie_properties[1][3].set_rotation(125)
pie_properties[1][4].set_rotation(-160)
pie_properties[1][5].set_rotation(-125)
#outer layer
ax.pie(corr_vals.flatten(), radius=1+0.4+0.5, colors=corr_colors,
wedgeprops=dict(width=0.5, edgecolor='w'))
ax.set(aspect="equal")
plt.show()
答案 0 :(得分:1)
我想您可以用一点三角学来计算所需的角度。由于标签位于楔形的平均角度范围内,因此计算角度很容易。根据文本是在下半部还是上半部,您可以增加或减少90度。
import matplotlib.pyplot as plt
import numpy as np
fig, ax = plt.subplots()
group_names = ['Group 1', 'Group 2', 'Group 3']
group_vals = [43,49,38]
group_colors = ['w']*3
info_names = ['Subgroup 1', 'Subgroup 2', \
'Subgroup 1', 'Subgroup 2',\
'Subgroup 1', 'Subgroup 2']
info_vals = np.array([[27,16],[26,23],[14,24]])
my_blue = np.array([30,144,255])/255
info_colors = [my_blue,'gray']*3
corr_vals = np.array([[10,3,7,3,4], [4,4,4,2,2],\
[10,5,5,3,3], [10,5,5,1,2],\
[4,4,2,2,2], [12,2,2,1,7]])
pale_green = np.array([152,251,152])/255
pale_red = np.array([240,128,128])/255
pale_gray = np.array([169,169,169])/255
corr_colors = ['green',pale_green,pale_gray,pale_red,'red']*6
def rotatetext(text):
angle = np.rad2deg(np.arctan2(*text.get_position()[::-1]))
text.set(rotation = angle - 90*np.sign(angle),
rotation_mode="anchor", ha="center", va="center")
#inner layer
pie_properties = ax.pie(group_vals, radius=1/1.9, colors=group_colors,
labels=group_names, labeldistance=.8,
wedgeprops=dict(width=0.3/1.9, edgecolor='k'))
for text in pie_properties[1]:
rotatetext(text)
#middle layer
pie_properties = ax.pie(info_vals.flatten(), radius=(1+0.4)/1.9, colors=info_colors,
labels=info_names, labeldistance=.82,
wedgeprops=dict(width=0.4/1.9, edgecolor='w'))
for text in pie_properties[1]:
rotatetext(text)
#outer layer
ax.pie(corr_vals.flatten(), radius=(1+0.4+0.5)/1.9, colors=corr_colors,
wedgeprops=dict(width=0.5/1.9, edgecolor='w'))
ax.set(xlim=(-1,1), ylim=(-1,1))
ax.set(aspect="equal")
plt.show()
但是,最佳径向位置需要手动调整。在这里,我分别选择了0.80和0.82,但这肯定取决于图形和字体大小。