今天就跟大家聊聊有關(guān)Python中的wxpython基本的控件按鈕怎么用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
成都創(chuàng)新互聯(lián)公司主營正陽網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營網(wǎng)站建設(shè)方案,重慶APP開發(fā)公司,正陽h5微信小程序開發(fā)搭建,正陽網(wǎng)站營銷推廣歡迎正陽等地區(qū)企業(yè)咨詢
在wxPython 中有很多不同類型的按鈕。這一節(jié),我們將討論文本按鈕、位圖按鈕、開關(guān)按鈕(toggle buttons )和通用(generic )按鈕。
在第一部分(part 1)中,我們已經(jīng)說明了幾個按鈕的例子,所以這里我們只簡短的涉及它的一些基本的東西。圖7.4顯示了一個簡單的按鈕。
圖7.4
使用按鈕是非常簡單的。例7.4顯示了該簡單按鈕的代碼。
Python代碼
import wx
class ButtonFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Button Example',
size=(300, 100))
panel = wx.Panel(self, -1)
self.button = wx.Button(panel, -1, "Hello", pos=(50, 20))
self.Bind(wx.EVT_BUTTON, self.OnClick, self.button)
self.button.SetDefault()
def OnClick(self, event):
self.button.SetLabel("Clicked")
if __name__ == '__main__':
app = wx.PySimpleApp()
frame = ButtonFrame()
frame.Show()
app.MainLoop()
wx.Button 的構(gòu)造函數(shù)類似于我們已經(jīng)看到過的,如下所示:
wx.Button(parent , id , label , pos , size =wxDefaultSize , style =0, validator , name ="button ")
參數(shù)label 是顯示在按鈕上的文本。它可以在程序運行期間使用SetLabel() 來改變,并且使用GetLabel() 來獲取。另外兩個有用的方法是GetDefaultSize() 和SetDefault() 。GetDefaultSize() 返回系統(tǒng)默認(rèn)按鈕的尺寸(對于框架間的一致性是有用的);SetDefault() 設(shè)置按鈕為對話框或框架的默認(rèn)按鈕。默認(rèn)按鈕的繪制不同于其它按鈕,它在對話框獲得焦點時,通常按下回車鍵被激活。
wx.Button 類有一個跨平臺的樣式標(biāo)記:wx.BU_EXACTFIT 。如果定義了這個標(biāo)記,那么按鈕就不把系統(tǒng)默認(rèn)的尺寸作為最小的尺寸,而是把能夠恰好填充標(biāo)簽的尺寸作為最小尺寸。如果本地窗口部件支持的話,你可以使用標(biāo)記wx.BU_LEFT , wx.BU_RIGHT , wx.BU_TOP , 和 wx.BU_BOTTOM 來改變按鈕中標(biāo)簽的對齊方式。每個標(biāo)記對齊標(biāo)簽到邊,該邊你根據(jù)標(biāo)記的名字可以知道。正如我們在第一部分中所討論過的,wx.Button 在被敲擊時觸發(fā)一個命令事件,事件類型是EVT_BUTTON 。
有時候,你可能想在你的按鈕上顯示一個圖片,而非一個文本標(biāo)簽,如圖7.5所示。
在wxPython 中,使用類wx.BitmapButton 來創(chuàng)建一個位圖按鈕。處理一個wx.BitmapButton 的代碼是與通用按鈕的代碼非常類似的,例7.5顯示了產(chǎn)生7.5的代碼。
例7.5 創(chuàng)建一個位圖按鈕
Python代碼
import wx
class BitmapButtonFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Bitmap Button Example',
size=(200, 150))
panel = wx.Panel(self, -1)
bmp = wx.Image("bitmap.bmp", wx.BITMAP_TYPE_BMP).ConvertToBitmap()
self.button = wx.BitmapButton(panel, -1, bmp, pos=(10, 20))
self.Bind(wx.EVT_BUTTON, self.OnClick, self.button)
self.button.SetDefault()
self.button2 = wx.BitmapButton(panel, -1, bmp, pos=(100, 20),
style=0)
self.Bind(wx.EVT_BUTTON, self.OnClick, self.button2)
def OnClick(self, event):
self.Destroy()
if __name__ == '__main__':
app = wx.PySimpleApp()
frame = BitmapButtonFrame()
frame.Show()
app.MainLoop()
與普通按鈕的主要的區(qū)別是你需要提供一個位圖,而非一個標(biāo)簽。否則,構(gòu)造器和大部分代碼是與文本按鈕的例子相同的。位圖按鈕在被敲擊時同樣產(chǎn)生EVT_BUTTON 事件。
關(guān)于位圖按鈕有幾個有趣的特性。首先,一個樣式標(biāo)記wx.BU_AUTODRAW ,它是默認(rèn)的。如果該標(biāo)記是打開的,那么位圖將帶有一個3D的邊框,這使它看起來像一個文本按鈕(圖7.5中的左按鈕),并且按鈕比原位圖大幾個像素。如果該標(biāo)記是關(guān)閉的,則位圖被簡單地繪制為按鈕而沒有邊框。通過設(shè)置style =0使圖7.5中右邊的按鈕關(guān)閉默認(rèn)設(shè)置,它沒有了3D的效果。
默認(rèn)情況下,給wxPython 傳遞單個位圖作為主顯示的位圖,在當(dāng)按鈕被按下或獲得焦點或無效時,wxPython 自動創(chuàng)建一個標(biāo)準(zhǔn)的派生自主顯示的位圖的位圖作為此時顯示在按鈕上的位圖。如果自動創(chuàng)建的位圖不是你想要的,你可以使用下面的方法: SetBitmapDisabled() , SetBitmapFocus() ,SetBitmapLabel() , 和SetBitmap -Selected()顯式地告訴wxPython 你要使用哪個位圖。這些方法都要求一個wx.Bitmap 對象作為參數(shù),并且它們都有相應(yīng)的get*()方法。
你不能通過使用標(biāo)準(zhǔn)的wxWidgets C++庫來合并一個位圖和文本。你可以創(chuàng)建一個包含文本的位圖。然而,正如我們將在通用按鈕問題討論中所看到的,wxPython 有額外的方法來實現(xiàn)這一合并行為。
=== 如何創(chuàng)建開關(guān)按鈕(toggle button )?===
你可以使用wx.ToggleButton 創(chuàng)建一個開關(guān)按鈕(toggle button )。開關(guān)按鈕(toggle button )看起來十分像文本按鈕,但它的行為更像復(fù)選框,它的選擇或非選擇狀態(tài)是可視化的。換句話說,當(dāng)你按下一個開關(guān)按鈕(togglebutton )時,它將一直保持被按下的狀態(tài)直到你再次敲擊它。
在wx.ToggleButton 與父類wx.Button 之間只有丙個區(qū)別:
1、當(dāng)被敲擊時,wx.ToggleButton 發(fā)送一個EVT_TOGGLEBUTTON 事件。
2、wx.ToggleButton 有GetValue() 和SetValue() 方法,它們處理按鈕的二進制狀態(tài)。
開關(guān)按鈕(toggle button )是有用的,它相對于復(fù)選框是另一好的選擇,特別是在工具欄中。記住,你不能使用wxWidgets 提供的對象來將開關(guān)按鈕(toggle button )與位圖按鈕合并,但是wxPython 有一個通用按鈕類,它提供了這種行為,我們將在下一節(jié)對其作討論。
通用按鈕是一個完全用Python 重新實現(xiàn)的一個按鈕窗口部件,回避了本地系統(tǒng)窗口部件的用法。它的父類是wx.lib.buttons. GenButton 。通用按鈕有通用位圖和切換按鈕。
這兒有幾個使用通用按鈕的原因:
1、通用按鈕比本地按鈕具有更好的跨平臺的外觀。另一方面,通用按鈕可能在具體的系統(tǒng)上看起來與本地按鈕有些微的不同。
2、使用通用按鈕,你對它的外觀有更多的控制權(quán),并且能改變屬性,如3D斜面的寬度和顏色,而這對于本地控件可能是不允許的。
3、通用按鈕類允許特性的合并,而wxWidget 按鈕不行。比如GenBitmapTextButton 允許文本標(biāo)簽和位圖的組合,GenBitmapToggleButton 實現(xiàn)一個位圖切換按鈕。
4、如果你正在創(chuàng)建一個按鈕類,使用通用按鈕是較容易的。由于其代碼和參數(shù)是用Python 寫的,所以當(dāng)創(chuàng)建一個新的子類的時候,對于檢查和覆蓋,它們的可用性更好。
圖7.6顯示了實際的通用按鈕和常規(guī)按鈕的對照。
圖7.6
例7.6顯示了產(chǎn)生圖7.6的代碼。第二個導(dǎo)入語句:import wx.lib.buttons as buttons ,是必須的,它使得通用按鈕類可用。
例7.6 創(chuàng)建和使用wxPython 的通用按鈕
Python代碼
import wx
import wx.lib.buttons as buttons
class GenericButtonFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Generic Button Example',
size=(500, 350))
panel = wx.Panel(self, -1)
sizer = wx.FlexGridSizer(1, 3, 20, 20)
b = wx.Button(panel, -1, "A wx.Button")
b.SetDefault()
sizer.Add(b)
b = wx.Button(panel, -1, "non-default wx.Button")
sizer.Add(b)
sizer.Add((10,10))
b = buttons.GenButton(panel, -1, 'Genric Button')#基本的通用按鈕
sizer.Add(b)
b = buttons.GenButton(panel, -1, 'disabled Generic')#無效的通用按鈕
b.Enable(False)
sizer.Add(b)
b = buttons.GenButton(panel, -1, 'bigger')#自定義尺寸和顏色的按鈕
b.SetFont(wx.Font(20, wx.SWISS, wx.NORMAL, wx.BOLD, False))
b.SetBezelWidth(5)
b.SetBackgroundColour("Navy")
b.SetForegroundColour("white")
b.SetToolTipString("This is a BIG button...")
sizer.Add(b)
bmp = wx.Image("bitmap.bmp", wx.BITMAP_TYPE_BMP).ConvertToBitmap()
b = buttons.GenBitmapButton(panel, -1, bmp)#通用位圖按鈕
sizer.Add(b)
b = buttons.GenBitmapToggleButton(panel, -1, bmp)#通用位圖開關(guān)按鈕
sizer.Add(b)
b = buttons.GenBitmapTextButton(panel, -1, bmp, "Bitmapped Text",
size=(175, 75))#位圖文本按鈕
b.SetUseFocusIndicator(False)
sizer.Add(b)
b = buttons.GenToggleButton(panel, -1, "Toggle Button")#通用開關(guān)按鈕
sizer.Add(b)
panel.SetSizer(sizer)
if __name__ == '__main__':
app = wx.PySimpleApp()
frame = GenericButtonFrame()
frame.Show()
app.MainLoop()
在例7.6中,通用按鈕的用法非常類似于常規(guī)按鈕。通用按鈕產(chǎn)生與常規(guī)按鈕同樣的EVT_BUTTON 和EVT_TOGGLEBUTTON 事件。通用按鈕引入了GetBevelWidth() 和SetBevelWidth() 方法來改變3D斜面效果。它們用在了圖7.6中大按鈕上。
通用位圖按鈕類GenBitmapButton 工作的像標(biāo)準(zhǔn)的wxPython 版本。在構(gòu)造器中。GenBitmapTextButton 要求先要一個位圖,然后是文本。通用類GenToggleButton ,GenBitmapToggleButton ,和 GenBitmapTextToggleButton 與非開關(guān)版的一樣,并且對于處理按鈕的開關(guān)狀態(tài)響應(yīng)于GetToggle() 和 SetToggle() 。
在下一節(jié),我們將討論關(guān)于使你的用戶能夠輸入或觀看一個數(shù)字值的方案。
有時你想要顯示圖形化的數(shù)字信息,或你想讓用戶不必使用鍵盤來輸入一個數(shù)字量。在這一節(jié),我們將瀏覽wxPython 中用于數(shù)字輸入和顯示的工具:滑塊(slider )、微調(diào)控制框和顯示量度的標(biāo)尺。
滑塊是一個窗口部件,它允許用戶通過在該控件的尺度內(nèi)拖動指示器來選擇一個數(shù)值。在wxPython 中,該控件類是wx.Slider ,它包括了滑塊的當(dāng)前值的只讀文本的顯示。圖7.7顯示了水平和垂直滑塊的例子。
圖7.7
滑塊的基本使用是十分簡單的,但是你可以增加許多事件。
如何使用滑塊
例7.7是產(chǎn)生圖7.7的例子。
例7.7 水平和垂直滑塊的顯示代碼
Python代碼
import wx
class SliderFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Slider Example',
size=(300, 350))
panel = wx.Panel(self, -1)
self.count = 0
slider = wx.Slider(panel, 100, 25, 1, 100, pos=(10, 10),
size=(250, -1),
style=wx.SL_HORIZONTAL | wx.SL_AUTOTICKS | wx.SL_LABELS )
slider.SetTickFreq(5, 1)
slider = wx.Slider(panel, 100, 25, 1, 100, pos=(125, 70),
size=(-1, 250),
style=wx.SL_VERTICAL | wx.SL_AUTOTICKS | wx.SL_LABELS )
slider.SetTickFreq(20, 1)
if __name__ == '__main__':
app = wx.PySimpleApp()
frame = SliderFrame()
frame.Show()
app.MainLoop()
通常,當(dāng)你使用wx.Slider 類時,所有你所需要的就是一個構(gòu)造函數(shù),它與別的調(diào)用不同,如下所示:
wx.Slider(parent , id , value , minValue , maxValue , pos =wxDefaultPosition , size =wx.DefaultSize , style=wx.SL_HORIZONTAL , validator =wx.DefaultValidator , name ="slider ")
value 是滑塊的初始值,而minValue 和maxValue 是兩端的值。
使用滑塊樣式工作
滑塊的樣式管理滑塊的位置和方向,如下表7.9所示。
表7.9 wx.Slider 的樣式
wx.SL_AUTOTICKS :如果設(shè)置這個樣式,則滑塊將顯示刻度??潭乳g的間隔通過SetTickFreq 方法來控制。
wx.SL_HORIZONTAL :水平滑塊。這是默認(rèn)值。
wx.SL_LABELS :如果設(shè)置這個樣式,那么滑塊將顯示兩頭的值和滑塊的當(dāng)前只讀值。有些平臺可能不會顯示當(dāng)前值。
wx.SL_LEFT :用于垂直滑塊,刻度位于滑塊的左邊。
wx.SL_RIGHT :用于垂直滑塊,刻度位于滑塊的右邊。
wx.SL_TOP :用于水平滑塊,刻度位于滑塊的上部。
wx.SL_VERTICAL :垂直滑塊。
如果你想通過改變滑塊中的值來影響你的應(yīng)用程序中的其它的部分,那么這兒有幾個你可使用的事件。這些事件與窗口滾動條所發(fā)出的是相同的,詳細(xì)的說明參見第8章的滾動條部分。
表7.10列出了你可用于滑塊的Set *()方法。每個Set *()方法都有一個對應(yīng)的Get 方法——Get 方法的描述參考其對應(yīng)的Set *()方法。
表7.10
GetRange() SetRange(minValue , maxValue) :設(shè)置滑塊的兩端值。
GetTickFreq() SetTickFreq(n , pos) :使用參數(shù)n設(shè)置刻度的間隔。參數(shù)pos 沒有被使用,但是它仍然是必要的,將它設(shè)置為1。
GetLineSize() SetLineSize(lineSize) :設(shè)置你每按一下方向鍵,滑塊所增加或減少的值。
GetPageSize() SetPageSize(pageSize) :設(shè)置你每按一下PgUp 或PgDn 鍵,滑塊所增加或減少的值。
GetValue() SetValue(value) :設(shè)置滑塊的值。
盡管滑塊提供了一個可能范圍內(nèi)的值的快速的可視化的表示,但是它們也有兩個缺點。其一是它們占據(jù)了許多的空間,另外就是使用鼠標(biāo)精確地設(shè)置滑塊是困難的。下面我們將討論的微調(diào)控制器解決了上面的這兩個問題。
微調(diào)控制器是文本控件和一對箭頭按鈕的組合,它用于調(diào)整數(shù)字值,并且在你要求一個最小限度的屏幕空間的時候,它是替代滑塊的最好選擇。圖7.8顯示了wxPython 的微調(diào)控制器控件。
圖7.8
在wxPython 中,類wx.SpinCtrl 管理微調(diào)按鈕和相應(yīng)的文本顯示。在接下來的部分,我們將創(chuàng)建一個微調(diào)控制器。
如何創(chuàng)建一個微調(diào)控制器
要使用wx.SpinCtrl 來改變值,可通過按箭頭按鈕或通過在文本控件中輸入。鍵入的非數(shù)字的文本將被忽略,盡管控件顯示的是鍵入的非數(shù)字的文本。一個超出范圍的值將被認(rèn)作是相應(yīng)的最大或最小值,盡管顯示的是你輸入的值。例7.8顯示了wx.SpinCtrl 的用法。
例7.8 使用wx.SpinCtrl
Python代碼
import wx
class SpinnerFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Spinner Example',
size=(100, 100))
panel = wx.Panel(self, -1)
sc = wx.SpinCtrl(panel, -1, "", (30, 20), (80, -1))
sc.SetRange(1,100)
sc.SetValue(5)
if __name__ == '__main__':
app = wx.PySimpleApp()
SpinnerFrame().Show()
app.MainLoop()
幾乎微調(diào)控件所有復(fù)雜的東西都是在其構(gòu)造函數(shù)中,其構(gòu)造函數(shù)如下:
Python代碼
wx.SpinCtrl(parent, id=-1, value=wx.EmptyString, pos=wx.DefaultPosition, size=wx.DefaultSize, style=wx.SP_ARROW_KEYS, min=0, max=100, initial=0, name="wxSpinCtrl")
參數(shù)value 是虛設(shè)的。使用initial 參數(shù)來設(shè)置該控件的值,并使用min 和max 來設(shè)置該控件的范圍。
對于wx.SpinCtrl 有兩個樣式標(biāo)記。默認(rèn)樣式是wx.SP_ARROW_KEYS ,它允許用戶通過鍵盤上的上下箭頭鍵來改變控件的值。樣式wx.SP_WRAP 使得控件中的值可以循環(huán)改變,也就是說你通過箭頭按鈕改變控件中的值到最大或最小值時,如果再繼續(xù),值將變?yōu)樽钚』蜃畲?,從一個極端到另一個極端。
你也可以捕獲EVT_SPINCTRL 事件,它在當(dāng)控件的值改變時產(chǎn)生(即使改變是直接由文本輸入引起的)。如果文本改變了,將引發(fā)一個EVT_TEXT 事件,就如同你使用一個單獨的文本控件時一樣。
如例7.8所示,你可以使用SetRange(minVal , maxVal) 和 SetValue(value) 方法來設(shè)置范圍和值。SetValue() 函數(shù)要求一個字符串或一個整數(shù)。要得到值,使用方法:GetValue() (它返回一個整數(shù)), GetMin() , 和 GetMax() 。
當(dāng)你需要對微調(diào)控制器的行為有更多的控制時,如允許浮點數(shù)或一個字符串的列表,你可以把一個wx.SpinButton和一個wx.TextCtrl 放到一起,并在它們之間建立一個聯(lián)系。然后捕獲來自wx.SpinButton 的事件,并更新wx.TextCtrl 中的值。
如果你只想圖形化地顯示一個數(shù)字值而不允許用戶改變它,那么使用相應(yīng)的wxPython 窗口部件wx.Gauge 。 相關(guān)的例子就是圖7.9所顯示的進度條。
圖7.9
例7.9顯示了產(chǎn)生圖7.9的代碼。與本章中許多別的例子不同的是,這里我們增加了一個事件處理器。下面的代碼在空閉時調(diào)整標(biāo)尺的值,使得值周而復(fù)始的變化。
例7.9 顯示并更新一個wx.Gauge
Python代碼
import wx
class GaugeFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Gauge Example',
size=(350, 150))
panel = wx.Panel(self, -1)
self.count = 0
self.gauge = wx.Gauge(panel, -1, 50, (20, 50), (250, 25))
self.gauge.SetBezelFace(3)
self.gauge.SetShadowWidth(3)
self.Bind(wx.EVT_IDLE, self.OnIdle)
def OnIdle(self, event):
self.count = self.count + 1
if self.count == 50:
self.count = 0
self.gauge.SetValue(self.count)
if __name__ == '__main__':
app = wx.PySimpleApp()
GaugeFrame().Show()
app.MainLoop()
wx.Gauge 的構(gòu)造函數(shù)類似于其它的數(shù)字的窗口部件:
Python代碼
wx.Gauge(parent, id, range, pos=wx.DefaultPosition, size=wx.DefaultSize, style=wx.GA_HORIZONTAL, validator=wx.DefaultValidator, name="gauge")
當(dāng)你使用參數(shù)range 來指定數(shù)字值時,該值代表標(biāo)尺的上限,而下限總是0。默認(rèn)樣式wx.GA_HORIZONTAL 提供了一個水平條。要將它旋轉(zhuǎn)90度,使用wx.GA_VERTICAL 樣式。如果你是在Windows 上,那么樣式wx.GA_PROGRESSBAR 給你的是來自Windows 工具包的本地化的進度條。
作為一個只讀控件,wx.Gauge 沒有事件。然而,它的屬性你可以設(shè)置。你可以使用GetValue() , Set -Value(pos) ,GetRange() , 和 SetRange(range) 來調(diào)整它的值和范圍。如果你是在Windows 上,并且沒有使用本地進度條樣式,那么你可以使用SetBezelFace(width) and SetShadowWidth() 來改變3D效果的寬度。
幾乎每個應(yīng)用程序都要求用戶在一套預(yù)先定義的選項間進行選擇。在wxPython 中,有多種窗口部件幫助用戶處理這種任務(wù),包括復(fù)選框、單選按鈕、列表框和組合框。接下來的部分將介紹這些窗口部件。
復(fù)選框是一個帶有文本標(biāo)簽的開關(guān)按鈕。復(fù)選框通常成組的方式顯示,但是每個復(fù)選框的開關(guān)狀態(tài)是相互獨立的。當(dāng)你有一個或多個需要明確的開關(guān)狀態(tài)的選項時,可以使用復(fù)選框。圖7.10顯示了一組復(fù)選框。
圖7.10
在wxPython 中復(fù)選框很容易使用。它們是wx.CheckBox 類的實例,并且通過把它們一起放入一個父容器中可以讓它們在一起顯示。例7.10提供了生成圖7.10的代碼。
例7.10 插入三個復(fù)選框到一個框架中
Python代碼
import wx
class CheckBoxFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Checkbox Example',
size=(150, 200))
panel = wx.Panel(self, -1)
wx.CheckBox(panel, -1, "Alpha", (35, 40), (150, 20))
wx.CheckBox(panel, -1, "Beta", (35, 60), (150, 20))
wx.CheckBox(panel, -1, "Gamma", (35, 80), (150, 20))
if __name__ == '__main__':
app = wx.PySimpleApp()
CheckBoxFrame().Show()
app.MainLoop()
wx.CheckBox 有一個典型的wxPython 構(gòu)造函數(shù):
Python代碼
wx.CheckBox(parent, id, label, pos=wx.DefaultPosition, size=wx.DefaultSize, style=0, name="checkBox")
label 參數(shù)是復(fù)選框的標(biāo)簽文本。復(fù)選框沒有樣式標(biāo)記,但是它們產(chǎn)生屬于自己的獨一無二的命令事件:EVT_CHECKBOX 。wx.CheckBox 的開關(guān)狀態(tài)可以使用GetValue() 和SetValue(state) 方法來訪問,并且其值是一個布爾值。IsChecked() 方法等同于GetValue() 方法,只是為了讓代碼看起來更易明白。
單選按鈕是一種允許用戶從幾個選項中選擇其一的窗口部件。與復(fù)選框不同,單選按鈕是顯式地成組配置,并且只能選擇其中一個選項。當(dāng)選擇了新的選項時,上次的選擇就關(guān)閉了。單選按鈕的使用比復(fù)選框復(fù)雜些,因為它需要被組織到一組中以便使用。radio button 的名字得自于老式轎車上有著同樣行為的成組的選擇按鈕。
在wxPython 中,有兩種方法可以創(chuàng)建一組單選按鈕。其一,wx.RadioButton ,它要求你一次創(chuàng)建一個按鈕,而wx.RadioBox 使你可以使用單一對象來配置完整的一組按鈕,這些按鈕顯示在一個矩形中。
wx.RadioButton 類更簡單些,在單選按鈕對其它窗口部件有直接影響或單選按鈕不是布置在一個單一的矩形中的情況下,它是首選。圖7.11顯示了一組wx.RadioButton 對象的列子。
圖7.11
我們在這個例子中使用wx.RadioButton 的原因是因為每個單選按鈕控制著一個關(guān)聯(lián)的文本控件。由于窗口部件是位于這組單選按鈕之外的,所以我們不能只用一個單選按鈕框。
如何創(chuàng)建單選按鈕
例7.11顯示了圖7.11的代碼,它管理單選按鈕和文本控件之間的聯(lián)系。
例7.11 使用wx.RadioButton 來控制另一個窗口部件
Python代碼
import wx
class RadioButtonFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Radio Example',
size=(200, 200))
panel = wx.Panel(self, -1)
#創(chuàng)建單選按鈕
radio1 = wx.RadioButton(panel, -1, "Elmo", pos=(20, 50), style=wx.RB_GROUP)
radio2 = wx.RadioButton(panel, -1, "Ernie", pos=(20, 80))
radio3 = wx.RadioButton(panel, -1, "Bert", pos=(20, 110))
#創(chuàng)建文本控件
text1 = wx.TextCtrl(panel, -1, "", pos=(80, 50))
text2 = wx.TextCtrl(panel, -1, "", pos=(80, 80))
text3 = wx.TextCtrl(panel, -1, "", pos=(80, 110))
self.texts = {"Elmo": text1, "Ernie": text2, "Bert": text3}#連接按鈕和文本
for eachText in [text2, text3]:
eachText.Enable(False)
for eachRadio in [radio1, radio2, radio3]:#綁定事件
self.Bind(wx.EVT_RADIOBUTTON, self.OnRadio, eachRadio)
self.selectedText = text1
def OnRadio(self, event):#事件處理器
if self.selectedText:
self.selectedText.Enable(False)
radioSelected = event.GetEventObject()
text = self.texts[radioSelected.GetLabel()]
text.Enable(True)
self.selectedText = text
if __name__ == '__main__':
app = wx.PySimpleApp()
RadioButtonFrame().Show()
app.MainLoop()
我們創(chuàng)建了單選按鈕和文本框,然后使用字典來建立它們間的連接。一個for 循環(huán)使得兩個文本框無效,另一個for 循環(huán)綁定單選按鈕命令事件。當(dāng)事件發(fā)生的時候,當(dāng)前活動的文本框變?yōu)闊o效,與被敲擊的按鈕相匹配的文本框變?yōu)橛行А?/p>
wx.RadioButton 的使用類似于是wx.CheckBox 。它們的構(gòu)造函數(shù)幾乎是相同的,如下所示:
Python代碼
wx.RadioButton(parent, id, label, pos=wx.DefaultPosition, size=wx.DefaultSize, style=0, validator=wx.DefaultValidator, name="radioButton")
在復(fù)選框中,label 是相應(yīng)按鈕的顯示標(biāo)簽。
wx.RB_GROUP 樣式聲明該按鈕位于一組單選按鈕開頭。一組單選按鈕的定義是很重要的,因為它控制開關(guān)行為。當(dāng)組中的一個按鈕被選中時,先前被選中的按鈕被切換到未選中狀態(tài)。在一個單選按鈕使用wx.RB_GROUP 被創(chuàng)建后,所有后來的被添加到相同父窗口部件中的單選按鈕都被添加到同一組,直到另一單選按鈕使用wx.RB_GROUP 被創(chuàng)建,并開始下一個組。在例7.11中,第一個單選按鈕是使用wx.RB_GROUP 聲明的,而后來的沒有。結(jié)果導(dǎo)致所有的按鈕都被認(rèn)為在同一組中,這樣一來,敲擊它們中的一個時,先前被選中按鈕將關(guān)閉。
使用單選框
通常,如果你想去顯示一組按鈕,分別聲明它們不是最好的方法。取而代之,wxPython 使用wx.RadioBox 類讓你能夠創(chuàng)建一個單一的對象,該對象包含了完整的組。如圖7.12所示,它看起來非常類似一組單選按鈕。
圖7.12
要使用wx.RadioBox 類,你所需要的全部就是構(gòu)造函數(shù)。例7.12顯示了圖7.12的代碼。
例7.12 建造單選框
Python代碼
import wx
class RadioBoxFrame(wx.Frame):
def __init__(self):
wx.Frame.__init__(self, None, -1, 'Radio Box Example',
size=(350, 200))
panel = wx.Panel(self, -1)
sampleList = ['zero', 'one', 'two', 'three', 'four', 'five',
'six', 'seven', 'eight']
wx.RadioBox(panel, -1, "A Radio Box", (10, 10), wx.DefaultSize,
sampleList, 2, wx.RA_SPECIFY_COLS)
wx.RadioBox(panel, -1, "", (150, 10), wx.DefaultSize,
sampleList, 3, wx.RA_SPECIFY_COLS | wx.NO_BORDER)
if __name__ == '__main__':
app = wx.PySimpleApp()
RadioBoxFrame().Show()
app.MainLoop()
wx.RadioBox 的構(gòu)造函數(shù)比簡單的單選按鈕更復(fù)雜,因為你需要去一下子為所有的按鈕指定數(shù)據(jù),如下所示:
Python代碼
wx.RadioBox(parent, id, label, pos=wx.DefaultPosition,
size=wxDefaultSize, choices=None, majorDimension=0,
style=wx.RA_SPECIFY_COLS, validator=wx.DefaultValidator,
name="radioBox")
label 參數(shù)是靜態(tài)文本,它顯示在單選框的邊框上。這些按鈕使用choices 參數(shù)指定,它是一個Python 的字符串標(biāo)簽的序列。
如同網(wǎng)格的sizer 一樣,你通過使用規(guī)定一個維數(shù)的尺寸來指定wx.RadioBox 的尺度,wxPython 在另一維度上自動填充。維度的主尺寸使用majorDimension 參數(shù)指定。哪一維是主要的由樣式標(biāo)記決定。默認(rèn)值是wx.RA_SPECIFY_COLS 。在本例中,左框的列數(shù)被設(shè)置為2,右框的列數(shù)被設(shè)置為3,行數(shù)由choices 列表中的元素數(shù)量動態(tài)的決定。如果你想得到相反的行為,你要將樣式設(shè)置為wx.RA_SPECIFY_ROWS 。如果你想在單選框被敲擊時響應(yīng)命令事件,那么這個命令事件是EVT_RADIOBOX 。
wx.RadioBox 類有許多方法來管理框中的不同的單選按鈕。這些方法使你能夠處理一個特定的內(nèi)部按鈕,傳遞該按鈕的索引。索引以0為開始,并按嚴(yán)格的順序展開,它的順序就是按鈕標(biāo)簽傳遞給構(gòu)造函數(shù)的順序。表7.11列出了這些方法。
表7.11 wx.RadioBox 的方法
EnableItem(n , flag) :flag 參數(shù)是一個布爾值,它用于使索引為n的按鈕有效或無效。要使整個框立即有效,使用Enable() 。
FindString(string) :根據(jù)給定的標(biāo)簽返回相關(guān)按鈕的整數(shù)索引值,如果標(biāo)簽沒有發(fā)現(xiàn)則返回-1。
GetCount() :返回框中按鈕的數(shù)量。
GetItemLabel(n) SetItemLabel(n , string) :返回或設(shè)置索引為n的按鈕的字符串標(biāo)簽。
GetSelection() GetStringSelection() SetSelection(n) SetStringSelection( string) :GetSelection() 和SetSelection() 方法處理當(dāng)前所選擇的單選按鈕的整數(shù)索引。GetStringSelection() 返回當(dāng)前所選擇的按鈕的字符串標(biāo)簽,SetStringSelection() 改變所選擇的按鈕的字符串標(biāo)簽為給定值。沒有set *()產(chǎn)生EVT_RADIOBOX 事件。
ShowItem(item , show) :show 參數(shù)是一個布爾值,用于顯示或隱藏索引為item 的按鈕。
單選按鈕不是給用戶一系列選擇的唯一方法。列表框和組合框占用的空間也少,也可以被配置來讓用戶從同一組中作多個選擇。
列 表框是提供給用戶選擇的另一機制。選項被放置在一個矩形的窗口中,用戶可以選擇一個或多個。列表框比單選按鈕占據(jù)較少的空間,當(dāng)選項的數(shù)目相對少的時候, 列表框是一個好的選擇。然而,如果用戶必須將滾動條拉很遠(yuǎn)才能看到所有的選項的話,那么它的效用就有所下降了。圖7.13顯示了一個wxPython 列表框。