wxPython将wx.StaticBitmap添加到wx.GridBagSizer

时间:2018-09-04 20:48:35

标签: python bitmap wxpython gridbagsizer

我有2个位图,我想使用wx.GridBagSizer放置在特定位置。这个问题类似于this one。但是,目前尚不清楚是否已经解决。

这里是one of the examples I found。我相信我做的完全一样,但是我的图像没有添加到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()

我得到的是重叠图

enter image description here

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

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

enter image description here

1 个答案:

答案 0 :(得分:0)

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

JQuery