首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >wxPython -选择要在应用程序中使用的正确大小

wxPython -选择要在应用程序中使用的正确大小
EN

Stack Overflow用户
提问于 2009-12-12 11:00:25
回答 2查看 3K关注 0票数 4

我很难弄清楚如何让wxPython中的sizers以我想要的方式工作(顺便问一句:我是唯一一个认为wxPython文档很少的人吗?)。我有4个按钮和一个textctrl,我想要这样排列:

代码语言:javascript
复制
==============================================
|WINDOW TITLE                          _ [] X|
|============================================|
|Button1  |  Button2  |   Button3  |  Button4|
|--------------------------------------------|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxTextCtrlxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
|xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx|
==============================================

按钮应该水平展开,而不是垂直展开,并且textctrl应该同时水平和垂直展开。我已经尝试了wxPython演示程序中列出的几乎所有的sizer,但没有一个有效-多个方框,gridsizer+ boxsizers,普通gridsizer,flexgridsizer和rowcolsizer,但都不起作用,有人能帮忙吗?作为参考,下面是我现在得到的代码。

代码语言:javascript
复制
            ...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...
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2009-12-14 00:14:30

我花了一段时间才弄明白这个问题。这是我一直和wxPython一起做的事情。从本质上讲,你需要嵌套盒子大小。你需要一个垂直的盒子大小来容纳两个水平的盒子大小。

以下是您需要的代码:

代码语言:javascript
复制
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()

垂直定尺vsizer有两个水平定尺。第一个水平大小可以容纳您想要添加的任意多个按钮,并且它们可以水平扩展。因为您将其添加到垂直大小,并且其“权重”的数字小于1,所以它不会垂直扩展。第二个水平大小调整包含文本控件,它可以扩展以占据所有剩余的水平和垂直空间。两个大小都会随着窗口的扩展而扩展。

我推荐你阅读Rappin和Dunn写的wxPython in Action这本书--它真的帮助我理解了wxPython大小和屏幕布局是如何工作的。

我对99%的wxPython程序使用嵌套的装箱程序。

Curt

票数 8
EN

Stack Overflow用户

发布于 2009-12-22 08:32:26

维基上有大量的信息,例如查看http://wiki.wxpython.org/UsingSizers。底部的图像很好地展示了所有标志和函数参数是如何工作的。

其他很好的例子是-zetcodeand,不要忘了检查wxwidgets页面。

示例/演示应用程序也可以从wxpython下载页面获得。我不能提供多个链接,因为我是一个新的StackOverflow用户。

在玩了一段时间的sizers之后,它们应该会“滴答”--我发现使用它们可以轻而易举地创建我的GUI。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1892110

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档