1. 程式人生 > 程式設計 >wxpython佈局的實現方法

wxpython佈局的實現方法

我們目前已經學會了四個控制元件,也編出了幾個視窗例項,它們都有一個共同的特點,就是醜,主要原因是沒有進行合理地佈局。

此前的佈局方式簡單粗暴,即明確規定每個控制元件的大小和位置,從而使之固定。這種佈局方式可稱之為絕對定位佈局,缺點是控制元件尺寸固定,並不會隨著視窗的放縮而同步變化。而且所有的控制元件都處於同一層次中,邏輯混亂,難於修改。

一個比較初級但很直觀的想法是,我們可不可以按照比例來調整控制元件的佈局?我等菜鳥所能想到的需求,彼等大佬自然早已解決,BoxSizer便是為此而生。

我們可以將BoxSizer理解為一個容器或者一個箱子,裡面的控制元件要麼水平排列,要麼豎直排列。而且BoxSizer之間也可以互相巢狀,從而實現一種非常靈活的佈局方式。如圖所示:

在上圖中,第一步,將按鈕0、1、2裝進一個BoxSizer;將3、4、5、6裝入第二個BoxSizer;再將7-11裝入第三個BoxSizer。這三個BoxSizer都是橫向的。

第二步,將這三個BoxSizer裝入一個縱向的BoxSizer中。

第三步,再將這個縱向的BoxSizer與按鈕12裝入主BoxSizer中。於是這個佈局便完成了。

其程式碼如下,為了表現清晰,所以並沒有寫得很精簡。

import wx

class testBox(wx.Frame):
  def __init__(self,parent=None):
    wx.Frame.__init__(self,parent=parent)

    #生成12個按鈕
    btns = [wx.Button(self,label=str(i)) for i in range(13)]
    myStyle = wx.EXPAND|wx.ALL #設定裝填風格

    #左側第一行的BoxSizer
    box1 = wx.BoxSizer()
    for i in range(3):
      box1.Add(btns[i],1,myStyle,border=10)

    #左側第二行的BoxSizer
    box2 = wx.BoxSizer()
    for i in range(3,7):
      box2.Add(btns[i],border=10)

    #左側第三行的BoxSizer
    box3 = wx.BoxSizer()
    for i in range(7,12):
      box3.Add(btns[i],border=10)

    #左側BoxSizer,wx.VERTICAL表示這個BoxSizer為縱向
    leftBox = wx.BoxSizer(wx.VERTICAL)
    leftBox.Add(box1,border=10)
    leftBox.Add(box2,border=10)
    leftBox.Add(box3,border=10)

    #總BoxSizer
    mainBox = wx.BoxSizer()
    mainBox.Add(leftBox,border=10)
    mainBox.Add(btns[12],border=10)

    #在框架中設定mainBox
    self.SetSizer(mainBox)

class MyApp(wx.App):
  def OnInit(self):
    self.SetAppName("testbox")
    self.Frame = testBox()
    self.Frame.Show()
    return True

if __name__ == "__main__":
  test = MyApp()
  test.MainLoop()

wx.BoxSizer控制元件除了self之外,只有一個初始化引數,即orient,預設為wx.HORIZONTAL,即橫向;如果輸入wx.VERTICAL,則為縱向。

wx.BoxSizer通過Add方法裝填控制元件,其常用的呼叫格式為:

Add (self,window,proportion=0,flag=0,border=0)
  • window為BoxSizer所裝填的控制元件
  • proportion宣告這個控制元件的尺寸是否隨著視窗的放縮而改變,如果改變的話其比例為多少
  • flag宣告裝填風格,如果想擁有多種風格,風格之間用"|"連線
  • border為邊界間隔

其中,proportion的引數為0時,表示尺寸不變;為正整數時,分別按照這個值的比例進行縮放。

Flags相對來說比較複雜,常用的可選值大致有三類,分別是宣告邊界、宣告對齊和宣告填充。

Add方法通過wx.TOP、wx.BOTTOM、wx.LEFT、wx.RIGHT、wx.ALL來宣告邊界。例如,如果選擇了wx.LEFT,即說明左側的邊界寬度為border。

Add通過wx.ALIGN_LEFT、wx.ALIGN_RIGHT、wx.ALIGN_RIGHT、wx.ALIGN_TOP、wx.ALIGN_BOTTOM、wx.ALIGN_CENTER來宣告對齊方式,如果選擇wx.ALIGN_LEFT,則表示左對齊。此外,對於居中而言,還支援水平或豎直的居中,欄位為wx.ALIGN_CENTER_HORIZONTAL、wx.ALIGN_CENTER_VERTICAL。

wx.EXPAND是一個常用的值,表示裝載的控制元件將填充所有的剩餘空間。一般來說,如果選了這個,那麼proportion的值就不能為0了。

至此,我們就已經有足夠的能力編寫出右側選項卡中的引數佈局了,下面則考慮左側畫圖區的實現。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。