matplotlib中的文本对象不能正确响应缩放

时间:2014-04-26 02:03:55

标签: python matplotlib

。 大家好,

我最近尝试在我的情节中添加文字对象。但是当我放大文本时,文本大小保持不变。我想要的是当我放大时文本大小会增加,而当我缩小时文本大小会减小。

import matplotlib as mpl
fig=plt.figure()
ax1=fig.add_subplot(111)
ax1.text('','', '',position=[0.5,0.5], text='Y', fontsize='xx-small' )

感谢任何帮助。感谢〜

Supplement-UTC + 8 30/04/2013 9:40 AM

感谢tcaswell的建议。 TextPath确实实现了我的部分目的。

我发现官方matplotlib网站上没有关于textpath的文档,所以我查看源代码以了解它的作用。最后,我得到了一个不太好但令人满意的结果如下。

from matplotlib.textpath import TextPath
import matplotlib.pyplot as plt
import matplotlib.patches as patches
from matplotlib.path import Path

fig=plt.figure()
ax1=fig.add_subplot(111)
tp1=TextPath((0.5,0.5), r'How do you turn this on?', size=1)
polygon=tp1.to_polygons()
for a in polygon:
    p1=patches.Polygon(a)
    ax1.add_patch(p1)

此代码中不太出色的部分是它不支持旋转并将文本导出为填充多边形。有没有简单的方法来旋转文本?我可以将文本导出为非填充多边形吗?

2 个答案:

答案 0 :(得分:2)

创建Polygon实例时,您可以指定许多关键字参数,包括设置fill = False(请参阅详细信息here):

from matplotlib.textpath import TextPath
import matplotlib.pyplot as plt
import matplotlib.patches as patches
from matplotlib.path import Path

fig=plt.figure()
ax1=fig.add_subplot(111)
ax1.set_ylim(-1 , 3)
ax1.set_xlim(-3, 15)
tp1=TextPath((0.0,0.5), r'How do you turn this on?', size=1)
polygon=tp1.to_polygons()
for a in polygon:
    p1=patches.Polygon(a, fill=False)
    ax1.add_patch(p1)

plt.show()

figure image

答案 1 :(得分:0)

感谢您的提问和准备!我的解决方案仅由命令调用:

text_fixed_size(ax=ax, text=f'pos=(4,8), h=1', pos=(4,8), h=1, color=c)

并在以下图片(纯文字和孔,如'o'中,未填充)中产生橙色输出。该解决方案也适用于倒置轴。高度和宽度可以根据需要独立设置。

enter image description here

代码

import matplotlib as mpl
import matplotlib.pyplot as plt
import numpy as np

def text_fixed_size(ax, text, pos, w=None, h=None, auto_trans=True, color='k'):

    assert not (w is None and h is None)

    tp = mpl.textpath.TextPath((0.0,0.0), text, size=1)
    x0, y0 = np.amin(np.array(tp.vertices), axis=0)
    x1, y1 = np.amax(np.array(tp.vertices), axis=0)
    hax = -np.subtract(*ax.get_xlim())
    wax = -np.subtract(*ax.get_ylim())

    if w is None:
        w = h / (y1 - y0) * ( x1 - x0)
    if h is None:
        h = w / (x1 - x0) * ( y1 - y0)
    if auto_trans:
        w *= np.sign(hax)
        h *= np.sign(wax)

    verts = []
    for vert in tp.vertices:
        vx = vert[0] * w / (x1 - x0) + pos[0]
        vy = vert[1] * h / (y1 - y0) + pos[1]
        verts += [ [vx, vy] ]
    verts = np.array(verts)

    tp = mpl.path.Path(verts, tp.codes)
    ax.add_patch(mpl.patches.PathPatch(tp, facecolor=color, lw=0))

fig, axs = plt.subplots(2, 2)
axs = np.array(axs).T.flatten()

lims = np.array([[0, 15], [0,10]])
for aa, ax in enumerate(axs):
    d0 = int((-(aa%2)+.5)*2)
    d1 = int((-(aa//2)+.5)*2)
    l = np.array([lims[0, ::d0], lims[1, ::d1]])
    ax.set_xlim(l[0, 0], l[0, 1])
    ax.set_ylim(l[1, 0], l[1, 1])

for aa, ax in enumerate(axs):
    c = 'C0'
    text_fixed_size(ax=ax, text=f'pos=(6,3), w=5, h=1',
                    pos=(6,3), w=5, h=1, color=c)
    c = 'C1'
    text_fixed_size(ax=ax, text=f'pos=(4,8), h=1',
                    pos=(4,8), h=1, color=c)
    c = 'C2'
    text_fixed_size(ax=ax, text=f'pos=(8,1), w=5, auto_trans=False',
                    pos=(3,1), w=10, auto_trans=False, color=c)

plt.show()