我无法弄清楚如何让wxPython中的sizer以我想要的方式工作(除此之外:我是唯一一个认为wxPython文档记录不好的人吗?)。我有4个按钮和一个我希望安排的文本控件:
==============================================
|WINDOW TITLE _ [] X|
|============================================|
|Button1 | Button2 | Button3 | Button4|
|--------------------------------------------|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxTextCtrlxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
==============================================
按钮应水平扩展,但不能垂直扩展,textctrl应水平和垂直扩展。我已经尝试了wxPython演示程序中列出的几乎所有sizer,但没有一个工作 - 多个boxsizer,gridsizer + boxsizeres,plain gridsizer,flexgridsizer和rowcolsizer但是没有一个工作,有人可以帮忙吗?作为参考,这是我现在的代码。
...snip...
panel = wx.Panel(self, -1)
select_file = wx.Button(panel, self.BUTTON_0, "Select File")
button1 = wx.Button(panel, self.BUTTON_1, "250 Words")
button2 = wx.Button(panel, self.BUTTON_2, "500 Words")
button3 = wx.Button(panel, self.BUTTON_3, "750 Words")
self.txt = wx.TextCtrl(panel, -1, "", style=wx.TE_MULTILINE | wx.TE_READONLY)
# Now to re-do this with gridsizers instead.
# 4 rows, 4 columns, 2 pixel gap horizontally and vertically.
grid = rcs.RowColSizer()
# These buttons need to expand to fill their space, and then
# expand when the windows are resized.
grid.Add( select_file, row=1, col=1 )
grid.Add( button1, row=1, col=2 )
grid.Add( button2, row=1, col=3 )
grid.Add( button3, row=1, col=4 )
grid.Add( self.txt, row=2, col=1 )
...snip...
答案 0 :(得分:8)
我花了一段时间才弄明白这一点。这是我一直用wxPython做的事情。基本上你需要嵌套box sizer。你需要一个垂直盒子大小调整器,它可以容纳两个水平盒子大小调整器。
以下是您需要的代码:
import wx
class sizertest(wx.Panel):
def __init__(self,parent):
wx.Panel.__init__(self,parent)
vsizer = wx.BoxSizer(wx.VERTICAL)
hsizer1 = wx.BoxSizer(wx.HORIZONTAL)
button1 = wx.Button(self,-1,"button 1")
self.Bind( wx.EVT_BUTTON,self.button1,button1)
hsizer1.Add(button1,1,wx.EXPAND)
button2 = wx.Button(self,-1,"button 2")
self.Bind( wx.EVT_BUTTON,self.button2,button2)
hsizer1.Add(button2,1,wx.EXPAND)
vsizer.Add(hsizer1,.1,wx.EXPAND)
self.SetSizer(vsizer)
tc = wx.TextCtrl(self,-1,"",style=wx.TE_MULTILINE)
hsizer2 = wx.BoxSizer(wx.HORIZONTAL)
hsizer2.Add(tc,1,wx.EXPAND)
vsizer.Add(hsizer2,1,wx.EXPAND)
def button1(self,event):pass
def button2(self,event):pass
if __name__ == "__main__":
app = wx.App()
frame = wx.Frame(parent=None, id=-1, title="sizer test")
panel = sizertest(frame)
frame.Show()
app.MainLoop()
vertical sizer vsizer包含两个水平大小调整器。第一个水平sizer包含您想要添加的多个按钮,它们可以水平扩展。因为您将其添加到垂直分级器中,其“重量”的数字小于1,所以它不会垂直扩展。第二个水平sizer保存文本控件,它可以扩展以占用所有剩余的水平和垂直空间。随着窗口的扩展,两个大小调整器都会扩展。
我建议您通过Rappin和Dunn获取wxPython in Action一书 - 这真的帮助我理解了wxPython sizer和屏幕布局是如何工作的。
我为99%的wxPython程序使用嵌套的boxsizer。
简略
答案 1 :(得分:0)
维基上有大量信息,请查看http://wiki.wxpython.org/UsingSizers。底部的图像非常适合显示所有标志和函数参数的工作原理。
其他很好的例子是-zetcode,也不要忘记查看wxwidgets页面。
wxpython下载页面提供了样本/演示应用程序。由于是新的StackOverflow用户,我无法提供多个链接。
使用sizer后,他们应该“打勾” - 我发现使用它们会让我的GUI变得轻而易举。