在四处寻找解决同一问题的方法时,我发现了一个看起来更干净的方法(或者至少在精神上比原来的问题更清晰),即使用 TextPath:
from matplotlib import pyplot as plt
from matplotlib.text import TextPath
data = [["peach", 1.0, 1.0],
["apples", 19, 3.5],
["oranges", 7, 2.2],
["grapes", 23, 7.8]]
max_d2 = max([d[2] for d in data]) + 1e-3
max_d1 = max([d[1] for d in data]) + 1e-3
cmap = plt.get_cmap('RdBu')
for d in data:
path = TextPath((0,0), d[0])
# These dots are to display the weakness below, remove for the actual question
plt.plot(d[1],d[2],'.',color='k')
plt.plot(d[1],d[2],marker=path,markersize=100, color=cmap(d[2]/max_d2))
plt.xlim([0,max_d1+5])
plt.ylim([0,max_d2+0.5])
此解决方案有其自身的一些优点和缺点:
- 主要缺点:如圆点所示,我无法将文本正确居中。相反,所需的值是图片的左下角。
- 主要优点:这没有乳胶问题并使用“真实”标记路径,这意味着它可以很容易地用于标记线图(虽然不是原始问题)
代码:
import numpy as np
x = np.cumsum(np.random.randn(100,5), axis=0)
plt.figure(figsize=(15,5))
for i in range(5):
label = TextPath((0,0), str(i), linewidth=1)
plt.plot(x[:,i], color='k')
plt.plot(np.arange(0,len(x),5),x[::5,i], color='k', marker=label, markersize=15, linewidth=0)
如果您有很多行/标记,则通过“文本”或“注释”的简单循环执行上述操作会非常慢,而这可以更好地扩展。