Python GUI编程:wxPython模块之布局

图形界面开发的时候往往要面临一个如何布局的问题,一个合理的布局能够把有面积的使用最大化,也能帮助使用者更直观的使用界面,我们使用wxPython的时候可以采用两种布局的形式,一种是前面我们用到的绝对布局,也就是说我们所创建的控件的位置是固定不变的,无论窗口的大小如何变化,绝对布局的子窗口或者控件都是不变的,本节我们学习一种Sizer管理布局,它能帮助我们自动布局一组窗口控件。

WxPython中有八种sizer供我们使用,分别是Sizer、WrapSizer、BoxSizer、GridSizer、FlexGridSizer、GridBagSizer和StaticBoxSzer、StdDialogButtonSizer,我们主要对BoxSizer进行学习。

它的分类如图:

Python GUI编程:wxPython模块之布局

我们在日常使用的时候一般使用BoxSizer、StaticBoxSizer、GridSizer和FlexGridSizer这四种,继承Sizer中的方法。

    1. BoxSizer布局

BoxSizer布局是使用的几种布局中最灵活简便的一个,它的排布方式垂直或水平,一般是在创建的时候指定布局的方向。

12 my_box   =  wx.BoxSizer(wx.HORIZINTAL) My_box   =  wx.BoxSizer(wx.VERTICAL)

上面的属于水平布局,当括号中为空的时候即默认为水平布局,下面的为垂直方向的布局。

我们往布局中添加控件的时候,使用Add()方法,这个Add方法由wx.Sizer继承而来,它的语法格式为:

1 Add(parent,proportion = ,flag = ,border = ,userData = None )

这种方式添加到父窗口parent当中。

1 Add(AnotherSizer,proportion = ,flag = ,border = ,userData = None )

这种方式添加到另外一个布局当中。

1 Add(AnotherSizer,proportion = ,flag = ,border = ,userData = None )

这种方式创建了一个新的空间。

其中flag为对齐、边框和尺寸参数,border为边框宽度、userData为数据的传输。

flag对齐标志有多种:

标志 说明
ALIGN_TOP 顶对齐
wx.ALIGN_LEFT 左对齐
wx.ALIGN_BOTTOM 底对齐
wx.ALIGN_RIGHT 右对齐
wx.ALIGN_CENTER 居中对齐
wx.ALIGN_CENTER_VERTIAL 垂直居中对齐
wx.ALIGN_CENTER_HORIZONTAL 水平居中对齐

边框flag标志有:

标志 说明
wx.TOP 设置有顶部边框,边框的宽度需要通过Add()方法的border参数设置
wx.BOTTOM 设置有底部边框
wx.LEFT 设置有左边框
wx.RIGHT 设置有右边框
wx.ALL 设置4面全有边框

调整尺寸flag标志:

标志 说明
wx.EXPAND  调整子窗口(或控件)完全填满有效空间
wx.SHAPED 调整子窗口(或控件)填充有效空间,但保存高宽比
wx.FIXED_MINSIZE 调整子窗口(或控件)为最小尺寸
wx.RESERVE_SPACE_EVEN_IF_HIDDEN 设置此标志后,子窗口(或控件)如果被隐藏,所占空间保留

我们来使用BoxSizer布局来创建一个登陆界面:

1234567891011121314151617181920212223242526272829303132 import wx class MyFrame(wx.Frame):      def __init__( self ):          wx.Frame.__init__( self None - 1 "登录界面" , size = ( 300 300 ))          panel  = wx.Panel( self ) #创建一个画布,然后创建功能区并放到画布上          self .title  = wx.StaticText(panel,label  = '登陆界面' )          self .username  = wx.StaticText(panel,label  = '用户:' )          self .user_name  = wx.TextCtrl(panel,style  = wx.TE_LEFT)          self .userpassword  = wx.StaticText(panel,label  = '密码:' )          self .user_password  = wx.TextCtrl(panel,style  = wx.TE_PASSWORD)          self .button_login  = wx.Button(panel,label  = '登陆' )          self .button_register  = wx.Button(panel,label  = '注册' )          container_one  = wx.BoxSizer(wx.HORIZONTAL)   # 创建一个box容器并控制水平排列          container_one.Add( self .username,proportion  =  ,flag  = wx. ALL ,border  = 7 )          container_one.Add( self .user_name,proportion  = 1 ,flag  = wx. ALL ,border  = 7 )          container_two  = wx.BoxSizer(wx.HORIZONTAL)   # 创建一个box容器并控制水平排列          container_two.Add( self .userpassword,proportion  =  ,flag  = wx. ALL ,border  = 7 )          container_two.Add( self .user_password,proportion  = 1 ,flag  = wx. ALL ,border  = 7 )          container_three  = wx.BoxSizer(wx.HORIZONTAL)   # 创建一个box容器并控制水平排列          container_three.Add( self .button_login,proportion  =  ,flag  = wx.ALIGN_CENTER,border  = 4 )          container_three.Add( self .button_register,proportion  = ,flag  = wx.ALIGN_CENTER,border  = 4 )          sizers  = wx.BoxSizer(wx.VERTICAL)            sizers.Add( self .title,proportion = ,flag = wx.BOTTOM|wx.TOP|wx.ALIGN_CENTER,border = 10 )          sizers.Add(container_one,proportion  =  ,flag  = wx.EXPAND|wx.LEFT|wx.RIGHT,border = 40 )          sizers.Add(container_two, proportion = , flag = wx.EXPAND | wx.LEFT | wx.RIGHT, border = 40 )          sizers.Add(container_three, proportion = , flag = wx.ALIGN_CENTER|wx.TOP, border = 10 )          panel.SetSizer(sizers) if __name__  = = "__main__" :      app  = wx.App()      frame  = MyFrame()      frame.Show()      app.MainLoop()

输出结果如图:

Python GUI编程:wxPython模块之布局

对应下图:

 

Python GUI编程:wxPython模块之布局

在这个例子中,我们主要使用了竖直和水平两种布局,我们首先把用户和输入信息放入一个水平BoxSizer,然后把密码和输入信息放入一个BoxSizer,再把两个按钮放在一个BoxSizer,最后再把四种信息全部放到一个竖直的BoxSizer当中。

    2. 总结

布局是我们图形界面开发的重要一环,就好比在建造房子之前是一定要设计好图纸的,所以我们先设计布局再进行页面开发。