【问题标题】:Combine picture and plot with Python Matplotlib用 Python Matplotlib 结合图片和绘图
【发布时间】:2011-04-15 11:16:33
【问题描述】:

我有一个图,它在 x 轴上有时间戳,在 y 轴上有一些信号数据。作为文档,我想将带有时间戳的图片与情节中的特定点相关联。是否可以在情节中画一条线到情节下方的一系列图片中的图片?

【问题讨论】:

    标签: python matplotlib


    【解决方案1】:

    matplotlib 库中的This 演示展示了如何插入图片、为其绘制线条等。我将从库中发布图像,您可以关注link 来查看代码。

    这是代码(来自 2.1.2 版):

    import matplotlib.pyplot as plt
    import numpy as np
    
    from matplotlib.patches import Circle
    from matplotlib.offsetbox import (TextArea, DrawingArea, OffsetImage,
                                      AnnotationBbox)
    from matplotlib.cbook import get_sample_data
    
    
    if 1:
        fig, ax = plt.subplots()
    
        # Define a 1st position to annotate (display it with a marker)
        xy = (0.5, 0.7)
        ax.plot(xy[0], xy[1], ".r")
    
        # Annotate the 1st position with a text box ('Test 1')
        offsetbox = TextArea("Test 1", minimumdescent=False)
    
        ab = AnnotationBbox(offsetbox, xy,
                            xybox=(-20, 40),
                            xycoords='data',
                            boxcoords="offset points",
                            arrowprops=dict(arrowstyle="->"))
        ax.add_artist(ab)
    
        # Annotate the 1st position with another text box ('Test')
        offsetbox = TextArea("Test", minimumdescent=False)
    
        ab = AnnotationBbox(offsetbox, xy,
                            xybox=(1.02, xy[1]),
                            xycoords='data',
                            boxcoords=("axes fraction", "data"),
                            box_alignment=(0., 0.5),
                            arrowprops=dict(arrowstyle="->"))
        ax.add_artist(ab)
    
        # Define a 2nd position to annotate (don't display with a marker this time)
        xy = [0.3, 0.55]
    
        # Annotate the 2nd position with a circle patch
        da = DrawingArea(20, 20, 0, 0)
        p = Circle((10, 10), 10)
        da.add_artist(p)
    
        ab = AnnotationBbox(da, xy,
                            xybox=(1.02, xy[1]),
                            xycoords='data',
                            boxcoords=("axes fraction", "data"),
                            box_alignment=(0., 0.5),
                            arrowprops=dict(arrowstyle="->"))
    
        ax.add_artist(ab)
    
        # Annotate the 2nd position with an image (a generated array of pixels)
        arr = np.arange(100).reshape((10, 10))
        im = OffsetImage(arr, zoom=2)
        im.image.axes = ax
    
        ab = AnnotationBbox(im, xy,
                            xybox=(-50., 50.),
                            xycoords='data',
                            boxcoords="offset points",
                            pad=0.3,
                            arrowprops=dict(arrowstyle="->"))
    
        ax.add_artist(ab)
    
        # Annotate the 2nd position with another image (a Grace Hopper portrait)
        fn = get_sample_data("grace_hopper.png", asfileobj=False)
        arr_img = plt.imread(fn, format='png')
    
        imagebox = OffsetImage(arr_img, zoom=0.2)
        imagebox.image.axes = ax
    
        ab = AnnotationBbox(imagebox, xy,
                            xybox=(120., -80.),
                            xycoords='data',
                            boxcoords="offset points",
                            pad=0.5,
                            arrowprops=dict(
                                arrowstyle="->",
                                connectionstyle="angle,angleA=0,angleB=90,rad=3")
                            )
    
        ax.add_artist(ab)
    
        # Fix the display limits to see everything
        ax.set_xlim(0, 1)
        ax.set_ylim(0, 1)
    
        plt.show()
    

    【讨论】:

    • 有谁知道这是否适用于 3D?我们可以在飞机上添加图片吗?
    • @CromeX:请提出一个单独的问题。
    • @Sanket_Diwale:感谢您指出这一点!我更新了链接并发布在代码中。 (我应该从一开始就输入代码,因为失败是不可避免的。)
    【解决方案2】:

    如果我正确理解了这个问题,那么这可能会有所帮助:

    import scipy
    import pylab
    fig = pylab.figure()
    axplot = fig.add_axes([0.07,0.25,0.90,0.70])
    axplot.plot(scipy.randn(100))
    numicons = 8
    for k in range(numicons):
        axicon = fig.add_axes([0.07+0.11*k,0.05,0.1,0.1])
        axicon.imshow(scipy.rand(4,4),interpolation='nearest')
        axicon.set_xticks([])
        axicon.set_yticks([])
    fig.show()
    fig.savefig('iconsbelow.png')
    

    【讨论】:

    • 当图像周围的黑色边框不受欢迎时,axicon.set_xticks([])axicon.set_yticks([]) 命令可以替换为axicon.axis('off')
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2022-12-06
    • 2020-06-12
    • 2020-09-02
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多