窗口组件是应用程序的基本构建块。PyQt4编程工具包拥有范围广泛的各种窗口组件。按钮、选择框、滑块、列表框等等,程序员工作所需要的一切。在教程的这部分中,我们将介绍一些有用的窗口组件。
QCheckBox
QCheckBox (复选框) 是一个由两种状态的窗口组件。 On 和 Off 。他是一个带标签的框。每段一个复选框被选中和或者清楚时,都将发射信号 stateChanged() 。
#!/usr/bin/python
# -*- coding: utf-8 -*-
# checkbox.py
import sys
from PyQt4 import QtGui
from PyQt4 import QtCore
class Example(QtGui.QWidget):
def __init__(self):
super(Example, self).__init__()
self.initUI()
def initUI(self):
self.setGeometry(300, 300, 250, 150)
self.setWindowTitle('Checkbox')
self.cb = QtGui.QCheckBox('Show title', self)
self.cb.setFocusPolicy(QtCore.Qt.NoFocus)
self.cb.move(10, 10)
self.cb.toggle()
self.connect(self.cb, QtCore.SIGNAL('stateChanged(int)'),
self.changeTitle)
def changeTitle(self, value):
if self.cb.isChecked():
self.setWindowTitle('Checkbox')
else:
self.setWindowTitle('')
if __name__ == '__main__':
app = QtGui.QApplication(sys.argv)
ex = Example()
ex.show()
app.exec_()
在我们的例子中,我们将创建一个复选框来切换窗口标题。
self.cb = QtGui.QCheckBox('Show title', self)
构建 QCheckBox 。
self.cb.setFocusPolicy(QtCore.Qt.NoFocus)
禁用 QCheckBox 的焦点。获由焦点的 QCheckBox 可以通过空格选择或者取消选择。
self.cb.toggle()
设置窗口标题,必须选中复选框。默认情况下,不设置窗口标题,复选框设为未选择。
self.connect(self.cb, QtCore.SIGNAL('stateChanged(int)'), self.changeTitle)
连接用户定义的 changeTitle() 到 stateChanged() 信号。 changeTitle() 方法将切换窗口标题。
切换按钮
PyQt4没有切换按钮的窗口组件,为了创建切换按钮,我们使用特殊模式的 QPushButton 。切换按钮是指一个两种状态的按钮,按下和非按下。通过点击切换两种状态。在某种状态下来这种方式很合适。
#!/usr/bin/python
# -*- coding: utf-8 -*-
# togglebutton.py
import sys
from PyQt4 import QtGui
from PyQt4 import QtCore
class Example(QtGui.QWidget):
def __init__(self):
super(Example, self).__init__()
self.initUI()
def initUI(self):
self.color = QtGui.QColor(0, 0, 0)
self.red = QtGui.QPushButton('Red', self)
self.red.setCheckable(True)
self.red.move(10, 10)
self.connect(self.red, QtCore.SIGNAL('clicked()'), self.setColor)
self.green = QtGui.QPushButton('Green', self)
self.green.setCheckable(True)
self.green.move(10, 60)
self.connect(self.green, QtCore.SIGNAL('clicked()'), self.setColor)
self.blue = QtGui.QPushButton('Blue', self)
self.blue.setCheckable(True)
self.blue.move(10, 110)
self.connect(self.blue, QtCore.SIGNAL('clicked()'), self.setColor)
self.square = QtGui.QWidget(self)
self.square.setGeometry(150, 20, 100, 100)
self.square.setStyleSheet("QWidget { background-color: %s }" %
self.color.name())
self.setWindowTitle('ToggleButton')
self.setGeometry(300, 300, 280, 170)
def setColor(self):
source = self.sender()
if source.text() == "Red":
if self.red.isChecked():
self.color.setRed(255)
else: self.color.setRed(0)
elif source.text() == "Green":
if self.green.isChecked():
self.color.setGreen(255)
else: self.color.setGreen(0)
else:
if self.blue.isChecked():
self.color.setBlue(255)
else: self.color.setBlue(0)
self.square.setStyleSheet("QWidget { background-color: %s }" %
self.color.name())
if __name__ == '__main__':
app = QtGui.QApplication(sys.argv)
ex = Example()
ex.show()
app.exec_()
这个例子中,我们创建了三个切换按钮和一个窗口组件,设置窗口组件的背景为黑色。这些切换按钮将切换颜色值的红绿蓝部分。背景色依赖于我们按下哪个切换按钮。
self.color = QtGui.QColor(0, 0, 0)
这是初始颜色,没有红绿蓝等于黑色。
self.red = QtGui.QPushButton('Red', self)
self.red.setCheckable(True)
为了创建一个切换按钮,我们创建了一个 QPushButton 并通过 setCheckable 方法使之可选择。
self.connect(self.red, QtCore.SIGNAL('clicked()'), self.setColor)
连接 clicked 信号到自定义的方法。
source = self.sender()
获得切换的按钮。
if source.text() == "Red":
if self.red.isChecked():
self.color.setRed(255)
else: self.color.setRed(0)
如果是红色按钮,我们更新颜色的红色部分。
self.square.setStyleSheet("QWidget { background-color: %s }" %
self.color.name())
通过样式表修改背景色。
本站文章为 宝宝巴士 SD.Team 原创,转载务必在明显处注明:(作者官方网站: 宝宝巴士 )
转载自【宝宝巴士SuperDo团队】 原文链接: http://www.cnblogs.com/superdo/p/4542694.html