鍍金池/ 教程/ Python/ wxPython BoxSizer布局
wxPython GUI構(gòu)建工具wxFormBuilder
wxPython StaticText類
WxPython教程
wxPython可停靠窗口
wxPython ComboBox & Choice類
wxPython FlexiGridSizer布局
wxPython入門(Hello World)
wxPython RadioButton & RadioBox類
wxPython拖放
wxPython HTMLWindow類
wxPython ToolBar類
wxPython GridBagSizer布局
wxPython Dialog類
wxPython布局管理
wxPython TextCtrl類
wxPython開發(fā)環(huán)境安裝
wxPython Slider類
wxPython CheckBox類
wxPython Major類
wxPython GridSizer布局
wxPython事件處理
wxPython SplitterWindow類
Menu Item, Menu & MenuBar類
wxPython Button控件
wxPython StaticBoxSizer布局
wxPython Guage類
wxPython Frame類
wxPython多文檔界面
wxPython Panel類
wxPython BoxSizer布局
wxPython繪圖API

wxPython BoxSizer布局

sizer允許控件排放在按行或列的方式。BoxSizer布局是由它的定位參數(shù)(wxVERTICAL或wxHORIZONTAL)確定。
Box = wx.BoxSizer(wxHORIZONTAL)
Box = wx.BoxSizer(wxVERTICAL)
Add() 方法(從wxSizer繼承)它附加到sizer的下一行/列。
Box.Add(control, proportion, flag, border) 

proportion 參數(shù)控制的控件響應(yīng)于所述容器的尺寸改變其大小。各種flag 參數(shù)的組合決定控件在sizer的外觀。下面是一些標(biāo)志-

對齊標(biāo)志

wx.ALIGN_TOP
wx.ALIGN_BOTTOM
wx.ALIGN_LEFT
wx.ALIGN_RIGHT
wx.ALIGN_CENTER_VERTICAL
wx.ALIGN_CENTER_HORIZONTAL

邊界標(biāo)志

wx.TOP
wx.BOTTOM
wx.LEFT
wx.RIGHT
wx.ALL

行為標(biāo)志

S.N.
行為標(biāo)志和說明
1

wx.EXPAND

項(xiàng)目將擴(kuò)大,以填補(bǔ)提供給它的空間(wx.GROW是一樣的)
2

wx.SHAPED

與EXPAND相似,但保持了項(xiàng)目的高寬比
3

wx.FIXED_MINSIZE

不允許該項(xiàng)目變得比其最初的最小尺寸更小
4

wx.RESERVE_SPACE_EVEN_IF_ HIDDEN

不允許測量器(sizer)回收項(xiàng)目空間,當(dāng)它被隱藏時(shí)
border參數(shù)是整數(shù),也可以在控件之間留下像素空間。 例如,
b = wx.StaticText(self, -1, “Enter a number”) 
Box.Add(b,1,wx.ALL|wx.EXPAND,10) 
以下是 wx.BoxSizer 類的一些方法 -
S.N. 方法 & 描述
1

SetOrientation()

設(shè)置定向wxHORIZONTAL或wxVERTICAL
2

AddSpacer()

添加非伸縮性空間
3

AddStretchSpacer()

增加了伸縮空間,以便調(diào)整窗口的大小會(huì)影響控件的大小成比例
4

Clear()

從sizer移除子控件
5

Detach()

從sizer刪除控件不銷毀
6

Insert()

在指定位置插入一個(gè)子控件
7

Remove()

從sizer和銷毀刪除子控件

實(shí)例

在下面的代碼,一個(gè)垂直box sizer用用于放置在 wxFrame 窗口面板對象。
p = wx.Panel(self) 
vbox = wx.wx.BoxSizer(wx.VERTICAL)
在框中的第一行顯示在中心,并且以20個(gè)像素作為邊框的標(biāo)簽(wx.StaticText對象)。
l1 = wx.StaticText(p,label = "Enter a number",style = wx.ALIGN_CENTRE ) 
vbox.Add(l1,0,  wx.ALL|wx.EXPAND|wx.ALIGN_CENTER_HORIZONTAL, 20)
在第二行中,將顯示一個(gè)wx.Button對象。因?yàn)閣x.EXPAND標(biāo)志它占據(jù)窗口的整個(gè)寬度。
b1 = wx.Button(p, label = "Btn1") 
vbox.Add(b1,0, wx.EXPAND) 

下一行還包含一個(gè)按鈕。它沒有使用EXPAND標(biāo)志補(bǔ)充說。相反,因?yàn)锳LIGN_CENTER_HORIZONTAL按鈕的默認(rèn)大小顯示在中心水平。

b2 = wx.Button(p, label = "Btn2") 
vbox.Add(b2,0,wx.ALIGN_CENTER_HORIZONTAL)
在接下來的一行,添加proportion參數(shù)到TextCtrl對象設(shè)定為1和EXPAND標(biāo)志集。其結(jié)果是,大小變更大。
t = wx.TextCtrl(p) 
vbox.Add(t,1,wx.EXPAND,10)
最后一排保持水平sizer 對象,這反過來又都有一個(gè)標(biāo)簽,并通過按鈕拉伸空格分開。
hbox = wx.BoxSizer(wx.HORIZONTAL) 
l2 = wx.StaticText(p,label = "Label2", style = wx.ALIGN_CENTRE) 
hbox.Add(l2,0,wx.EXPAND) 

b3 = wx.Button(p,label = "Btn3") 
hbox.AddStretchSpacer(1) 
hbox.Add(b3,0,wx.ALIGN_LEFT,20) 
vbox.Add(hbox,1,wx.ALL|wx.EXPAND)
最后,垂直box sizer適用于 wx.Panel 對象。
下面是完整的代碼 -
import wx 
 
class Example(wx.Frame): 
   
   def __init__(self, parent, title): 
      super(Example, self).__init__(parent, title = title, size = (200,300)) 
             
      self.InitUI() 
      self.Centre() 
      self.Show()
		
   def InitUI(self): 
      p = wx.Panel(self) 
      vbox = wx.wx.BoxSizer(wx.VERTICAL) 
      l1 = wx.StaticText(p,label = "Enter a number",style = wx.ALIGN_CENTRE ) 
      vbox.Add(l1,0,  wx.ALL|wx.EXPAND|wx.ALIGN_CENTER_HORIZONTAL, 20) 
      b1 = wx.Button(p, label = "Btn1") 
      vbox.Add(b1,0,wx.EXPAND) 
          
      b2 = wx.Button(p, label = "Btn2") 
      vbox.Add(b2,0,wx.ALIGN_CENTER_HORIZONTAL) 
      t = wx.TextCtrl(p) 
      vbox.Add(t,1,wx.EXPAND,10) 
      hbox = wx.BoxSizer(wx.HORIZONTAL) 
      l2 = wx.StaticText(p,label = "Label2", style = wx.ALIGN_CENTRE) 
		
      hbox.Add(l2,0,wx.EXPAND) 
      b3 = wx.Button(p,label = "Btn3") 
      hbox.AddStretchSpacer(1) 
      hbox.Add(b3,0,wx.ALIGN_LEFT,20) 
      vbox.Add(hbox,1,wx.ALL|wx.EXPAND) 
      p.SetSizer(vbox) 
          
app = wx.App() 
Example(None, title = 'BoxSizer Demo - www.yiibai.com') 
app.MainLoop()
上面的代碼產(chǎn)生下面的輸出 -