0

我有 2 个要使用 wx.GridBagSizer 放置在特定位置的位图。这个问题与这个问题类似。但是,尚不清楚它是否曾经得到解决。

这是我找到的示例之一。我相信我做的完全一样,但我的图像没有添加到 sizer 中。

这是我的代码。我使用 wx.gridbagsizer 创建了一个框架、面板并将 2 个位图放在可能的两个不同单元格中。但是,当我用实际图形更新位图时,它们看起来是重叠的。

    frame = wx.Frame.__init__(self, None, wx.ID_ANY, "", size = (1200,800))#, style= wx.SYSTEM_MENU | wx.CAPTION)
    self.panel = wx.Panel(self, wx.ID_ANY, style=wx.BORDER_THEME, size = (1200,800))

    bmp1 = wx.Bitmap.FromRGBA(100, 100, red=255, alpha=0)
    self.bitmap1 = wx.StaticBitmap(self.panel, bitmap=bmp1)
    self.bitmap2 = wx.StaticBitmap(self.panel, bitmap=bmp1)

    sizer = wx.GridBagSizer(hgap = 0, vgap = 0)#(13, 11)
    sizer.Add(self.bitmap1, pos=(0,0),  flag = wx.ALL)#, flag=wx.TOP|wx.RIGHT) FIXIT so the sidebar is closer to the graph
    sizer.Add(self.bitmap2, pos=(0,1),  flag = wx.ALL)#,flag=wx.TOP|wx.RIGHT)


    def buf2wx (buf):
        image = PIL.Image.open(buf)
        width, height = image.size
        return wx.Bitmap.FromBuffer(width, height, image.tobytes())

    import PIL
    import io
    from matplotlib import pyplot as plt
    import urllib, base64
    import cStringIO
    import io
    from numpy import random
    plt.figure()
    b = random.rand(100,)
    plt.subplot(311)
    plt.plot(b)
    b = random.rand(100,)
    plt.subplot(312)
    plt.plot(b)
    b = random.rand(100,)
    plt.subplot(313)
    plt.plot(b)
    plt.title("test")
    buf = io.BytesIO()
    plt.savefig(buf, format='jpg')
    buf.seek(0)

    self.bitmap1.SetBitmap(buf2wx(buf))
    self.bitmap2.SetBitmap(buf2wx(buf))


    buf.close()
    app.MainLoop()

我得到的是重叠图

在此处输入图像描述

我可以通过指定位置来移动它们

self.bitmap1.SetPosition((0,0))
self.bitmap2.SetPosition((100,0))

在此处输入图像描述

4

1 回答 1

0

答案最终变得微不足道。为了使它工作,我需要设置 sizer。在图表末尾 app.MainLoop() 之前添加以下代码,尤其是“SetSizer()”。其他功能负责调整大小等。此外,请确保将位图添加到面板对象(self.panel),而不是框架(self)。

    self.panel.SetSizer(sizer)
    self.Layout()
    self.panel.Layout()
    self.Fit()
于 2018-09-06T14:10:47.110 回答