Pyqt5系列(一)_第1頁(yè)
Pyqt5系列(一)_第2頁(yè)
Pyqt5系列(一)_第3頁(yè)
Pyqt5系列(一)_第4頁(yè)
Pyqt5系列(一)_第5頁(yè)
已閱讀5頁(yè),還剩24頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、Pyqt5系列(一)一 Pyqt5的安裝由于在實(shí)際的工作中需要使用到python來(lái)進(jìn)行GUI的開發(fā),基于python的GUI開發(fā),只是去考慮具體使用依賴那個(gè)GUI庫(kù)來(lái)進(jìn)行開發(fā)。GUI庫(kù)的選擇:1、TKinter,python配備的標(biāo)準(zhǔn)gui庫(kù),但是功能比較弱,似乎只適合開發(fā)非常簡(jiǎn)單的界面。2、Wxpython,目前官方網(wǎng)站還沒(méi)有release針對(duì)python3.0以上版本的庫(kù),雖然在國(guó)外的博客上有針對(duì)python3的版本。3、Pyqt,Pyqt基于QT,在GUI開發(fā)上可以參考QT的開發(fā) 。 對(duì)比了Tkinter,Wxpython,Pyqt之后,選擇使用Pyqt來(lái)進(jìn)行GUI的開發(fā),PyQt基于G

2、PL許可開發(fā)。PyQt安裝: 整體安裝的步驟比較簡(jiǎn)單,首先下載與自己python版本和開發(fā)環(huán)境一致的PyQt版本。1、開發(fā)環(huán)境:python3.35win7 32bit2、官網(wǎng)下載:官網(wǎng)上之后對(duì)應(yīng)的source package。需要自己編譯生成。3、OSDN下載:OSDN上羅列了所有released的PyQt安裝程序,根據(jù)開發(fā)環(huán)境下載了PyQt5-5.2.1-gpl-Py3.3-Qt5.2.0-x32.exe 安裝程序。Note:1、下載PyQt時(shí)注意選擇匹配的Python版本和系統(tǒng)的位數(shù);2、直接通過(guò)exe文件安裝PyQt,Pip安裝的方式比較復(fù)雜;功能驗(yàn)證:安裝之后簡(jiǎn)單寫個(gè)測(cè)試程序驗(yàn)證一下

3、python view plain copy 在CODE上查看代碼片派生到我的代碼片#!/user/bin/python3 #-*- coding:utf-8 -*- ''''' Creat a simple window ''' _author_ = 'Tony Zhu' import sys from PyQt5.QtWidgets import QWidget, QApplication if _name_ = '_main_': app = QApplication(sys.argv) w

4、= QWidget() w.show() w.setWindowTitle("Hello PyQt5") sys.exit(app.exec_() 運(yùn)行之后會(huì)直接顯示一個(gè)標(biāo)題為“Hello PyQt5”的空白窗口。二 第一個(gè)PyQt程序通過(guò)下面的一個(gè)PyQt5簡(jiǎn)單例子,來(lái)簡(jiǎn)單了解一下關(guān)于如何創(chuàng)建PyQt5的。具體代碼如下:#-*- coding:utf-8 -*-'''Frist PyQt5 program'''_author_ = 'Tony Zhu'from PyQt5.QtWidgets import Q

5、Application, QWidget, QLabel, QHBoxLayout, QPushButton, QLineEdit, QVBoxLayout,QMessageBoximport sysclass ShowWindow(QWidget): def _init_(self): super(ShowWindow,self)._init_() self.initUI() def initUI(self): self.inputLabel = QLabel("Input your text") self.editLine = QLineEdit() self.prin

6、tButton = QPushButton("Print") self.clearButton = QPushButton("Clear") self.printButton.clicked.connect(self.printText) self.clearButton.clicked.connect(self.clearText) inputLayout = QHBoxLayout() inputLayout.addWidget(self.inputLabel) inputLayout.addWidget(self.editLine) buttonL

7、ayout = QHBoxLayout() buttonLayout.addWidget(self.printButton) buttonLayout.addWidget(self.clearButton) mainLayout = QVBoxLayout() mainLayout.addLayout(inputLayout) mainLayout.addLayout(buttonLayout) self.setLayout(mainLayout) self.setWindowTitle('FristWindow') self.show() def printText(self

8、): text = self.editLine.text() if text = '': QMessageBrmation(self, "Empty Text", "Please enter the letter.") else : QMessageBrmation(self, "Print Success", "Text: %s" % text) def clearText(self): text = self.editLine.text() if text = 

9、9;': return else : self.editLine.clear()if _name_ = '_main_': app = QApplication(sys.argv) ex = ShowWindow() sys.exit(app.exec_() 運(yùn)行的結(jié)果: 程序運(yùn)行后的結(jié)果結(jié)合代碼和運(yùn)行的結(jié)果,分析代碼: Line78:from PyQt5.QtWidgets import QApplication, QWidget, QLabel, QHBoxLayout, QPushButton, QLineEdit, QVBoxLayout,QMessageBox

10、import sys導(dǎo)入了程序運(yùn)行所必須的模塊Line10:class ShowWindow(QWidget):創(chuàng)建一個(gè)ShowWindow類繼承QWidget,其中PyQt中非常重要的通用窗口類,是所有用戶界面對(duì)象的基類,所有和用戶界面相關(guān)的控件類都是繼承自QWidger類。Line1214:def _init_(self): super(ShowWindow,self)._init_() self.initUI()定義了ShowWindow類的構(gòu)造函數(shù) init,由于ShowWindow繼承自QWidgert類,因此在構(gòu)造函數(shù)中調(diào)用父類QWidget的構(gòu)造函數(shù)super.init()。 同

11、時(shí)在構(gòu)造函數(shù)中調(diào)用自定義的初始化函數(shù)initUI(),在該函數(shù)中初始化GUI中所需各個(gè)控件。Line1720:self.inputLabel = QLabel("Input your text")self.editLine = QLineEdit()self.printButton = QPushButton("Print")self.clearButton = QPushButton("Clear")創(chuàng)建成員:一個(gè)標(biāo)簽(inputLabel ),輸入框(editLine ),兩個(gè)按鈕(printButton ,clearButton

12、 )Line2223:self.printButton.clicked.connect(self.printText) self.clearButton.clicked.connect(self.clearText)1printButton和clearButton點(diǎn)擊事件處理的邏輯:點(diǎn)擊printButton之后會(huì)調(diào)用自定義函數(shù)printText()中的處理邏輯;點(diǎn)擊clearButton之后調(diào)用自定義函數(shù)clearText()中的處理邏輯。通過(guò)connect()方法將點(diǎn)擊事件和處理邏輯關(guān)聯(lián)起來(lái) 這個(gè)涉及到PyQt信號(hào)與槽的概念,信號(hào)和槽用于對(duì)象之間的通信。當(dāng)指定事件發(fā)生,一個(gè)事件信號(hào)會(huì)被發(fā)射

13、。槽可以被任何Python腳本調(diào)用。當(dāng)和槽連接的信號(hào)被發(fā)射時(shí),槽會(huì)被調(diào)用。有關(guān)信號(hào)與槽的概念,在后續(xù)的文章中會(huì)專門講解。Line2526:inputLayout = QHBoxLayout()inputLayout.addWidget(self.inputLabel)inputLayout.addWidget(self.editLine)創(chuàng)建一個(gè)inputLayout的水平布局(QHBoxLayout),在inputLayout中添加已定義的控件inputLabel和editLine。QHBoxLayout讓添加的控件水平排布Line2931:buttonLayout = QHBoxLayou

14、t()buttonLayout.addWidget(self.printButton)buttonLayout.addWidget(self.clearButton)同上創(chuàng)建一個(gè)buttonLayout 的水平布局(QHBoxLayout),在buttonLayout 中添加printButton和clearButtonLine3335:mainLayout = QVBoxLayout()mainLayout.addLayout(inputLayout)mainLayout.addLayout(buttonLayout)創(chuàng)建一個(gè)mainLayout 的垂直布局(QVBoxLayout),在ma

15、inLayout 中嵌套子布局inputLayout和buttonLayout。通過(guò)如下的布局圖,進(jìn)一步了解一下該程序中l(wèi)ayout是如何布局的。有l(wèi)ayout的概念,在后續(xù)的文章中會(huì)專門講解。Line37:self.setLayout(mainLayout)通過(guò)將setLayout()方法,將mainLayout設(shè)置為窗口layout。Line38:self.setWindowTitle('FristWindow')通過(guò)setWindowTitle()方法設(shè)置窗口的標(biāo)題Line39:self.show()通過(guò)show()方法將窗口顯示到屏幕上Line4048: def pri

16、ntText(self): text = self.editLine.text() if text = '': QMessageBrmation(self, "Empty Text", "Please enter the letter.") else : QMessageBrmation(self, "Print Success", "Text: %s" % text)定義了處理printButton點(diǎn)擊信號(hào)的槽函數(shù),當(dāng)editLine輸入框中的文本為空的時(shí)候彈出消息框(

17、QMessageBox),提示“Please enter the letter.”;當(dāng)editLine輸入框中的文本不為空時(shí)候彈出消息框,顯示editLine中的文本。觸發(fā)槽函數(shù)printText()之后,當(dāng)editLine輸入框內(nèi)容為空時(shí)界面顯示如下:Line4955: def clearText(self): text = self.editLine.text() if text = '': return else : self.editLine.clear()定義了處理clearButton點(diǎn)擊信號(hào)的槽函數(shù),清空editLine輸入框中的文本信息。Line 5760:if

18、 _name_ = '_main_': app = QApplication(sys.argv) ex = ShowWindow()sys.exit(app.exec_()程序運(yùn)行的入口函數(shù)類似C語(yǔ)言中的main()方法。 app = QApplication(sys.argv),每一個(gè)pyqt程序必須創(chuàng)建一個(gè)application對(duì)象,sys.argv是命令行參數(shù),可以通過(guò)命令啟動(dòng)的時(shí)候傳遞參數(shù)。 ex = ShowWindow(),創(chuàng)建ShowWindow對(duì)象。 sys.exit(app.exec_(),app.exec_() 事件處理開始,進(jìn)入程序主循環(huán)。主循環(huán)等待時(shí)間,

19、并把事件發(fā)送給指定處理的任務(wù)中。當(dāng)調(diào)用app.exit()或者程序因?yàn)楦鞣N原因被破壞后,使用sys.exit()關(guān)閉程序,并釋放內(nèi)存資源。到此為止,第一個(gè)PyQt程序分析結(jié)束,可能會(huì)存在輸入框,布局,等各類控件如何使用,如何確定對(duì)應(yīng)的控件在那個(gè)模塊中?在后續(xù)的文章中會(huì)詳細(xì)進(jìn)行介紹。三 基本界面組件之Button抽象類 QAbstractButton:QAbstractButton作為抽象類,提供button的通用功能,可按按鈕(push button)和可選擇按鈕(checkable button)??蛇x擇按鈕實(shí)現(xiàn)有QRadioButton和QCheckBox;可按按鈕實(shí)現(xiàn)有QPushButt

20、on和QToolButton。 任何一種button可以顯示帶文本(.setText()方法設(shè)置文本)和圖標(biāo)(.setIcon()設(shè)置圖標(biāo))的標(biāo)簽。QAbstractButton 提供的狀態(tài): 1、isDown() 提示button是否按下 2、isChecked()提示button是否已經(jīng)標(biāo)記 3、isEnable()提示button是否可以被用戶點(diǎn)擊 4、isCheckAble()提示button是否為可標(biāo)記 5、setAutoRepeat()設(shè)置button是否在用戶長(zhǎng)按按鈕的時(shí)候可以自動(dòng)重復(fù)執(zhí)行。QAbstractButton 提供的信號(hào): 1、pressed(),當(dāng)鼠標(biāo)在button

21、上并點(diǎn)擊左鍵的時(shí)候 觸發(fā)信號(hào) 2、released(),當(dāng)鼠標(biāo)左鍵被釋放的時(shí)候觸發(fā)信號(hào) 3、clicked(),當(dāng)鼠標(biāo)首次按下,然后釋放,或者快捷鍵被釋放的時(shí)候觸發(fā)信號(hào) 4、toggled(),當(dāng)button的標(biāo)記狀態(tài)發(fā)生改變的時(shí)候觸發(fā)信號(hào)接下來(lái)會(huì)針對(duì)每一種button進(jìn)行介紹:QPushButton :class QPushButton(QAbstractButton) | QPushButton(QWidget parent=None) | QPushButton(str, QWidget parent=None) | QPushButton(QIcon, str, QWidget par

22、ent=None)由此可見QPushButton繼承自QAbstractButton,是一種command按鈕。點(diǎn)擊執(zhí)行一些命令,或者響應(yīng)一些問(wèn)題。常見的諸如“確認(rèn)”,“申請(qǐng)”,“取消”,“關(guān)閉”,“是”,“否”等按鈕。 Command Button經(jīng)常通過(guò)文本來(lái)描述執(zhí)行的動(dòng)作。有時(shí)候我們也會(huì)通過(guò)快捷鍵來(lái)執(zhí)行對(duì)應(yīng)按鈕的命令。通過(guò)一個(gè)示例對(duì)QPushButton來(lái)進(jìn)行說(shuō)明:#-*- coding:utf-8 -*-'''PushButton'''_author_ = 'Tony Zhu'from PyQt5.QtWidgets im

23、port QApplication, QWidget, QPushButtonfrom PyQt5.QtGui import QIconfrom PyQt5.QtCore import Qtimport sysclass PushButton(QWidget): def _init_(self): super(PushButton,self)._init_() self.initUI() def initUI(self): self.setWindowTitle("PushButton") self.setGeometry(400,400,300,260) self.clo

24、seButton = QPushButton(self) self.closeButton.setText("Close") #text self.closeButton.setIcon(QIcon("close.png") #icon self.closeButton.setShortcut('Ctrl+D') #shortcut key self.closeButton.clicked.connect(self.close) self.closeButton.setToolTip("Close the widget"

25、;) #Tool tip self.closeButton.move(100,100)if _name_ = '_main_': app = QApplication(sys.argv) ex = PushButton() ex.show() sys.exit(app.exec_()運(yùn)行之后的效果:控件說(shuō)明:示例說(shuō)明: 名稱為“Close”的 Buttton,點(diǎn)擊該Button之后關(guān)閉該窗口?;蛘咄ㄟ^(guò)快捷鍵“Ctrl+C”的快捷方式亦可關(guān)閉該窗口。 代碼分析: 其他代碼部分可以參考上一篇Pyqt5系列(二 )-第一個(gè)PyQt程序中的說(shuō)明。L2122:self.closeButt

26、on.setText("Close") #textself.closeButton.setIcon(QIcon("close.png") #iconsetText()方法,設(shè)定button的文本 setIcon()方法,設(shè)定button的圖標(biāo) 關(guān)于button 文本和圖標(biāo)的顯示,也可以通過(guò)QPushButton的構(gòu)造函數(shù),在創(chuàng)建對(duì)象實(shí)例的時(shí)候通過(guò)參數(shù)直接設(shè)定。 | QPushButton(str, QWidget parent=None) | QPushButton(QIcon, str, QWidget parent=None)L23:self.clo

27、seButton.setShortcut('Ctrl+D') #shortcut key給closeButton設(shè)定快捷鍵方式,即通過(guò)Ctrl+D實(shí)現(xiàn)與點(diǎn)擊closeButton一樣的功能。L24:self.closeButton.clicked.connect(self.close)closeButton點(diǎn)擊事件處理的邏輯:在點(diǎn)擊closeButton之后調(diào)用QWidget的close()方法。通過(guò)connect()方法將點(diǎn)擊事件和處理邏輯關(guān)聯(lián)起來(lái) 。L25:self.closeButton.setToolTip("Close the widget")se

28、tToolTip()設(shè)定提示信息,當(dāng)鼠標(biāo)移動(dòng)到button上時(shí)顯示”Close the widget”提示信息。QToolButton:class QToolButton(QAbstractButton) | QToolButton(QWidget parent=None)同理QToolButton繼承自QAbstractButton。QToolButton就是工具操作相關(guān)的按鈕,通常和QToolBar搭配使用。QToolButton通常不顯示文本,而顯示圖標(biāo)QIcon。一般QToolButton會(huì)在QToolBar:addAction時(shí)創(chuàng)建,或者已經(jīng)存在的action添加到QToolBar時(shí)

29、創(chuàng)建。通過(guò)一個(gè)示例對(duì)QToolButton來(lái)進(jìn)行說(shuō)明:#-*- coding:utf-8 -*-'''ToolButton'''_author_ = 'Tony Zhu'from PyQt5.QtWidgets import QApplication, QWidget, QToolButton, QMainWindowfrom PyQt5.QtGui import QIconfrom PyQt5.QtCore import Qtimport sysclass ToolButton(QMainWindow): def _init_(

30、self): super(ToolButton,self)._init_() self.initUI() def initUI(self): self.setWindowTitle("ToolButton") self.setGeometry(400,400,300,260) self.toolbar = self.addToolBar("toolBar") self.statusBar() self._detailsbutton = QToolButton() self._detailsbutton.setCheckable(True) self._d

31、etailsbutton.setChecked(False) self._detailsbutton.setArrowType(Qt.RightArrow) self._detailsbutton.setAutoRaise(True) #self._detailsbutton.setIcon(QIcon("test.jpg") self._detailsbutton.setToolButtonStyle(Qt.ToolButtonIconOnly) self._detailsbutton.clicked.connect(self.showDetail) self.toolb

32、ar.addWidget(self._detailsbutton) def showDetail(self): if self._detailsbutton.isChecked(): self.statusBar().showMessage("Show Detail.") else: self.statusBar().showMessage("Close Detail.")if _name_ = '_main_': app = QApplication(sys.argv) ex = ToolButton() ex.show() sys.e

33、xit(app.exec_()運(yùn)行之后的效果:控件說(shuō)明:示例說(shuō)明: 圖標(biāo)為“右箭頭圖標(biāo)”的 Buttton,此按鈕有開關(guān)之分。當(dāng)Button打開之后在消息欄顯示“Show Detail.”,反之顯示“Close Detail”。 代碼分析: 其他代碼部分可以參考上一篇Pyqt5系列(二 )-第一個(gè)PyQt程序中的說(shuō)明。 L2425:self._detailsbutton.setCheckable(True) setCheckable()方法,“True”設(shè)置該button為可選屬性,及存在“開”和“關(guān)”兩種狀態(tài)。 setChecked()方法,設(shè)置button的狀態(tài)為為選中的狀態(tài)。L26:se

34、lf._detailsbutton.setArrowType(Qt.RightArrow)setArrowType()方法,設(shè)定button上顯示的箭頭類型 arrowType,箭頭屬性,按鈕是否顯示一個(gè)arrow代替正常的icon Qt.NoArrow 0 Qt.UpArrow 1 Qt.DownArrow 2 Qt.LeftArrow 3 Qt.RightArrow 4L29:self._detailsbutton.setToolButtonStyle(Qt.ToolButtonIconOnly)setToolButtonStyle(),設(shè)定button文本和圖標(biāo)顯示的樣式。程序中的參數(shù)為

35、只顯示icon不顯示文本(Qt.ToolButtonIconOnly) 參數(shù)類型如下: Qt.ToolButtonIconOnly 0 Only display the icon. Qt.ToolButtonTextOnly 1 Only display the text. Qt.ToolButtonTextBesideIcon 2 The text appears beside the icon. Qt.ToolButtonTextUnderIcon 3 The text appears under the icon. Qt.ToolButtonFollowStyle 4如果在實(shí)際的使用過(guò)程

36、中,需要同時(shí)顯示自定義的icon和文本的時(shí)候,可以按照如下參數(shù)設(shè)置:self._detailsbutton.setIcon(QIcon("test.jpg")self._detailsbutton.setToolButtonStyle(Qt.ToolButtonTextBesideIcon)對(duì)于QPushButton和QToolButton,如上的例子中只是涉及到部分常用的方法,所以對(duì)于詳細(xì)的說(shuō)明可以通過(guò)如下途徑:在命令行中通過(guò)help()方法: 如 help(QPushButton)QRadioButton :class QRadioButton(QAbstractBut

37、ton) | QRadioButton(QWidget parent=None) | QRadioButton(str, QWidget parent=None)由此可見QRadioButton繼承自QAbstractButton。單選按鈕提供一個(gè)按鈕和一個(gè)label,label用于顯示對(duì)應(yīng)的文本信息。單選按鈕是一種開關(guān)按鈕,可以切換為on或者off即checked或者unchecked。主要用途用于提供給用戶one of many選擇。如果用戶選擇另外一個(gè)單選按鈕,則之前的就被反選了。 RaidoButton 默認(rèn)是autoExclusive。對(duì)于繼承自同一個(gè)父類Wdiget的單選按鈕,他們

38、屬于同一個(gè)exclusive按鈕組合。如果需要多個(gè)exclusive按鈕組合的時(shí)候,需要將他們放在QButtonGroup。 當(dāng)單選按鈕切換到on或者off的時(shí)候,就會(huì)發(fā)送toggled()的信號(hào)。綁定這個(gè)信號(hào),在按鈕狀態(tài)發(fā)生改變的時(shí)候,觸發(fā)相應(yīng)的行為。通過(guò)一個(gè)示例對(duì)QPushButton來(lái)進(jìn)行說(shuō)明:#-*- coding:utf-8 -*-'''ToolButton'''_author_ = 'Tony Zhu'from PyQt5.QtWidgets import QApplication, QWidget, QRadioBu

39、tton, QStyleFactory, QVBoxLayoutimport sysclass RadioButton(QWidget): def _init_(self): super(RadioButton,self)._init_() self.initUI() def initUI(self): self.setWindowTitle("RadioButton") self.setGeometry(400,400,300,260) self._xpButton = QRadioButton("WindowsXP") self._vistaButt

40、on = QRadioButton("WindowsVista") self._windowSButton = QRadioButton("Windows") self._xpButton.toggled.connect(lambda:self.changeStyle("WindowsXP") self._vistaButton.toggled.connect(lambda:self.changeStyle("WindowsVista") self._windowSButton.toggled.connect(la

41、mbda:self.changeStyle("Windows") layout = QVBoxLayout() layout.addWidget(self._xpButton) layout.addWidget(self._vistaButton) layout.addWidget(self._windowSButton) layout.addStretch(1) self.setLayout(layout) self._xpButton.setChecked(True) self.changeStyle("Windows") def changeSty

42、le(self,styleName): QApplication.setStyle(QStyleFactory.create(styleName)if _name_ = '_main_': app = QApplication(sys.argv) ex = RadioButton() ex.show() sys.exit(app.exec_()示例說(shuō)明: 通過(guò)選擇單選框按鈕,來(lái)切換不同的window界面風(fēng)格,XP,Vista,Windows風(fēng)格 代碼分析: 其他代碼部分可以參考上一篇Pyqt5系列(二 )-第一個(gè)PyQt程序中的說(shuō)明。L1924:self._xpButton =

43、 QRadioButton("WindowsXP") self._vistaButton = QRadioButton("WindowsVista")self._windowSButton = QRadioButton("Windows") self._xpButton.toggled.connect(lambda:self.changeStyle("WindowsXP") self._vistaButton.toggled.connect(lambda:self.changeStyle("Windows

44、Vista") self._windowSButton.toggled.connect(lambda:self.changeStyle("Windows")創(chuàng)建_xpButton ,_vistaButton , _windowsButton三個(gè)單選框按鈕,然后將切換開關(guān)發(fā)射的toggle信號(hào)和自定義槽函數(shù)changeStyle()綁定在一起。 在綁定槽函數(shù)的時(shí)候,由于要傳遞參數(shù),因此通過(guò)lambada來(lái)重新定義一個(gè)函數(shù),此函數(shù)中傳入了所需的參數(shù)。L33:self._xpButton.setChecked(True)初始化設(shè)定_xpButton為選中狀態(tài)。L3637

45、:def changeStyle(self,styleName): QApplication.setStyle(QStyleFactory.通過(guò)QStyleFactory.keys()可以獲取到支持的style: Windows, WindowsXP, WindowsVista, Fusion QApplication.setStyle()方法來(lái)設(shè)定界面顯示的風(fēng)格,這樣可以根據(jù)自己的喜好來(lái)設(shè)定。QCheckBox:class QCheckBox(QAbstractButton) | QCheckBox(QWidget parent=None) | QCheckBox(str, QWidget

46、parent=None)由此可見QCheckBox繼承自QAbstractButton。 同QRadioButton,QCheckBox也是一個(gè)開關(guān)按鈕,可切換狀態(tài)on或者off,即checked或者unchecked。 一般,此復(fù)選框可以enable或者disable但不影響其他復(fù)選按鈕。但是如果此放置到一個(gè)互斥的QButtonGroup里面,則只能選一個(gè)復(fù)選框。這是有互斥選項(xiàng)的QButtonGroup所限定的屬性。 當(dāng)checkbox復(fù)選框是checked標(biāo)記或者清楚,都會(huì)觸發(fā)stateChangeed信號(hào)??梢允褂胕sChecked()去查詢復(fù)選框按鈕是否標(biāo)記。除了常用的選中與沒(méi)選中狀態(tài)

47、,QCheckBox提供第三種狀態(tài)即“沒(méi)有改變”狀態(tài)。如果使用此狀態(tài),設(shè)置其屬性setTristate(),然后用checkState()去查詢當(dāng)前標(biāo)記切換的狀態(tài)。通過(guò)一個(gè)示例對(duì)QCheckBox來(lái)進(jìn)行說(shuō)明:#-*- coding:utf-8 -*-'''CheckBox'''_author_ = 'Tony Zhu'from PyQt5.QtWidgets import QApplication, QWidget, QCheckBox, QGroupBox, QStyleFactory, QVBoxLayout, QTextBr

48、owserimport sysfrom PyQt5.QtCore import Qtfrom PyQt5.QtGui import QFontclass CheckBox(QWidget): def _init_(self): super(CheckBox,self)._init_() self.initUI() def initUI(self): self.setWindowTitle("CheckBox") self.setGeometry(400,400,300,260) groupBox = QGroupBox("Non-Exclusive Checkbo

49、xes") groupBox.setFlat(True) self.checkBox1 = QCheckBox("&Checkbox 1") self.checkBox2 = QCheckBox("C&heckbox 2") self.checkBox2.setChecked(True) self.tristateBox = QCheckBox("Tri-&state button") self.tristateBox.setTristate(True) self.tristateBox.setChe

50、ckState(Qt.PartiallyChecked) self.checkBox1.stateChanged.connect(self.changeCheckBoxStatus) self.checkBox2.stateChanged.connect(self.changeCheckBoxStatus) self.tristateBox.stateChanged.connect(self.changeCheckBoxStatus) vbox = QVBoxLayout() vbox.addWidget(self.checkBox1) vbox.addWidget(self.checkBox

51、2) vbox.addWidget(self.tristateBox) vbox.addStretch(1) groupBox.setLayout(vbox) self.lcd = QTextBrowser() self.lcd.setFixedHeight(190) self.lcd.setFont(QFont("Microsoft YaHei", 20) self.lcd.setText(self.getCheckBoxStatus() mainLayout = QVBoxLayout() mainLayout.addWidget(groupBox) mainLayou

52、t.addWidget(self.lcd) self.setLayout(mainLayout) def changeCheckBoxStatus(self): self.lcd.setText(self.getCheckBoxStatus() def getCheckBoxStatus(self): status = self.checkBox1.text()+": "+ str(self.checkBox1.checkState() +"n" +self.checkBox2.text()+": "+ str(self.checkB

53、ox2.checkState() +"n"+self.tristateBox.text()+": "+ str(self.tristateBox.checkState() return statusif _name_ = '_main_': app = QApplication(sys.argv) ex = CheckBox() ex.show() sys.exit(app.exec_()示例說(shuō)明: 通過(guò)復(fù)選按鈕的選擇,在textBrowser中顯示當(dāng)前各個(gè)控件的名稱和狀態(tài)。 代碼分析: 其他代碼部分可以參考上一篇Pyqt5系列(二 )-第一個(gè)PyQt程序中的說(shuō)明。L2426:self.checkBox1 = QCheckBox("&Checkbox 1")self.checkBox2 = QCheckBox("C&heckbox 2")self.checkBox2.setChecked(True)實(shí)例化checkBox1和

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論