PyQt5 教程系列(七)控件

作者: haiyang 分类: Python 发布时间: 2019-08-03 08:58

控件是构建应用程序的基本模板,PyQt5提供各种各样的控件,包括按钮、复选框、滑动条、列表框等在这部分的教程中,我们将详细介几个常用的控件:QcheckBox(复选框)、切换按钮、QSlider(
滑动条)、QPrQPogressBar(进度条)、 QCalendarWidget(日历控件)

QcheckBox  复选框控件

QcheckBox 复选框控件,它有两个状态:打开和关闭,它是一个带有文本标签的控件复选框常用于表示程序中可以启用或禁用功能

import sys
from PyQt5.QtWidgets import QWidget, QCheckBox, QApplication
from PyQt5.QtCore import Qt
 
 
class Example(QWidget):
    
    def __init__(self):
        super().__init__()
        
        self.initUI()
        
        
    def initUI(self):      
 
        cb = QCheckBox('Show title', self)
        cb.move(20, 20)
        cb.toggle()
        cb.stateChanged.connect(self.changeTitle)
        
        self.setGeometry(300, 300, 250, 150)
        self.setWindowTitle('QCheckBox')
        self.show()
        
        
    def changeTitle(self, state):
      
        if state == Qt.Checked:
            self.setWindowTitle('QCheckBox')
        else:
            self.setWindowTitle('')
            
        
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

在我的示例中,我将创一个复选框,将切换窗口标题。

cb = QCheckBox('Show title', self)

这是QCheckBox的构造行数

cb = cb.toggle()

我有设置窗口标题,所有我也必须检查复选框。默认情况下,没有设置窗口标题也没有勾选复选框。

cb.stateChanged.connect(self.changeTitle)

我将自定义的changeTitle() 方法连接到 stateChanged 信号。这个方法切换窗口标题。

def changeTitle(self, state):
        if state == Qt.Checked:
            self.setWindowTitle('QCheckBox')
        else:
            self.setWindowTitle('')

复选框的状态经由状态参数传入changeTitle() 方法。在勾选复选框时设置窗体标题,取消勾选时就将标题设为空字符串。

勾选复选框时设置窗体标题
取消 勾选复选框窗体标题

开关按钮切换按钮

切换按钮是QPushButton 的一种特殊模式它是一个有两种状体的按钮:按下与未按。下面通过点击这两种状态来回切换这种功能在某些场景会很使用。

import sys
from PyQt5.QtWidgets import (QWidget, QPushButton, 
    QFrame, QApplication)
from PyQt5.QtGui import QColor
 
 
class Example(QWidget):
    
    def __init__(self):
        super().__init__()
        
        self.initUI()
        
        
    def initUI(self):      
 
        self.col = QColor(0, 0, 0)       
 
        redb = QPushButton('Red', self)
        redb.setCheckable(True)
        redb.move(10, 10)
 
        redb.clicked[bool].connect(self.setColor)
 
        greenb = QPushButton('Green', self)
        greenb.setCheckable(True)
        greenb.move(10, 60)
 
        greenb.clicked[bool].connect(self.setColor)
 
        blueb = QPushButton('Blue', self)
        blueb.setCheckable(True)
        blueb.move(10, 110)
 
        blueb.clicked[bool].connect(self.setColor)
 
        self.square = QFrame(self)
        self.square.setGeometry(150, 20, 100, 100)
        self.square.setStyleSheet("QWidget { background-color: %s }" %  
            self.col.name())
        
        self.setGeometry(300, 300, 280, 170)
        self.setWindowTitle('Toggle button')
        self.show()
        
        
    def setColor(self, pressed):
        
        source = self.sender()
        
        if pressed:
            val = 255
        else: val = 0
                        
        if source.text() == "Red":
            self.col.setRed(val)                
        elif source.text() == "Green":
            self.col.setGreen(val)             
        else:
            self.col.setBlue(val) 
            
        self.square.setStyleSheet("QFrame { background-color: %s }" %
            self.col.name())  
       
       
if __name__ == '__main__':
    
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

示例中我创建了三个切换按钮与一个Qwidget的。我将Qwidget中的背景色设为黑色。ToggleButton 会切换颜色值中的红色、绿色、蓝色部分。Qwidget的背景颜色依赖按下的按钮。

self.col = QColor(0, 0, 0)

这是初始颜黑颜色的值。

redb = QPushButton(‘Red’, self)
redb.setCheckable(True)
redb.move(10, 10)

我们创建一个QPushButton 并通过其setCheckable() 方法来得到一个切换按钮。

read.clicked[bool].connet(self.setColor)

将点击信号连接到用户自定义的方法。我们通过点击信号操作一个布尔值。

if source.text() == "Red":
   self.col.setRed(val)

我们得到了按下的按钮

if source.text() == "Red":
   self.col.setRed(val) 

如果按下的是红色按钮,我们要相应地更新颜色中的红包部分。

self.square.setStyleSheet("QFrame {background-color: %s}"%
     self.col.name())
初始化的窗口
点击 Red 按钮的窗口

Qsilder 滑动条

Qsilder 是一个带有简单滑块的控件。滑块可以前后拖动。我们可以通过拖动选择一个特定的值。有时使用滑动条比直接输入数字或使用旋转框更加自然。

在下面的例子中,会显示一个滑动条与一个标签,标签用于显示图片,并通过滑动条控件图片的显示。

注意这里的图片只能用ICO格式的,PNG格式的图片时不会显示的。

import sys
from PyQt5.QtWidgets import (QWidget, QSlider, 
    QLabel, QApplication)
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QPixmap
 
 
class Example(QWidget):
    
    def __init__(self):
        super().__init__()
        
        self.initUI()
        
        
    def initUI(self):      
 
        sld = QSlider(Qt.Horizontal, self)
        sld.setFocusPolicy(Qt.NoFocus)
        sld.setGeometry(30, 40, 100, 30)
        sld.valueChanged[int].connect(self.changeValue)
        
        self.label = QLabel(self)
        self.label.setPixmap(QPixmap('audio.ico'))
        self.label.setGeometry(160, 40, 80, 30)
        
        self.setGeometry(300, 300, 280, 170)
        self.setWindowTitle('QSlider')
        self.show()
        
        
    def changeValue(self, value):
 
        if value == 0:
            self.label.setPixmap(QPixmap('audio.ico'))
        elif value > 0 and value <= 30:
            self.label.setPixmap(QPixmap('min.ico'))
        elif value > 30 and value < 80:
            self.label.setPixmap(QPixmap('med.ico'))
        else:
            self.label.setPixmap(QPixmap('max.ico'))
            
 
if __name__ == '__main__':
 
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())  

例子中我模拟了一个音量控制。通过拖动滑块来该变标签上的图像。

sld = QSlider(Qt.Horizontal,slef)

创建一个水平滑块

self.label = QLabel(self)
self.label.setPixmap(QPixmap('mute.png'))

创建了一个QLabel控件并为它设置了一个初始音量图像。

sld.valueChanged[int].connect(self.changeValue)

我们将的valueChanged 信号连接到自定义的changeValue() 方法。

if value == 0:
   self.label.setPixmap(QPixmap('mute.pn

根据滑动条的值来设置标签的图像。在上面的代码中,当滑动条的值为0时我们为标签设置audio.ico图像。

QPrQPogressBar 进度条

一个进度条时一个显示任务进度的控件 . QPrQPogressBar 控件提供了一个水平或垂直PyQt5工具包的进度条。可以设置进度条的最小和最大值。默认值时0到99。

import sys
from PyQt5.QtWidgets import (QWidget, QProgressBar,
                             QPushButton, QApplication)
from PyQt5.QtCore import QBasicTimer
 
 
class Example(QWidget):
    def __init__(self):
        super().__init__()
 
        self.initUI()
 
    def initUI(self):
 
        self.pbar = QProgressBar(self)
        self.pbar.setGeometry(30, 40, 200, 25)
 
        self.btn = QPushButton('Start', self)
        self.btn.move(40, 80)
        self.btn.clicked.connect(self.doAction)
 
        self.timer = QBasicTimer()
        self.step = 0
 
        self.setGeometry(300, 300, 280, 170)
        self.setWindowTitle('QProgressBar')
        self.show()
 
    def timerEvent(self, e):
 
        if self.step >= 100:
            self.timer.stop()
            self.btn.setText('Finished')
            return
 
        self.step = self.step + 1
        self.pbar.setValue(self.step)
 
    def doAction(self):
 
        if self.timer.isActive():
            self.timer.stop()
            self.btn.setText('Start')
        else:
            self.timer.start(100, self)
            self.btn.setText('Stop')
 
 
if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

在上面示例中显示一个进度条和一个按钮,通过点击按钮和停止进度条

self.pbar = QProgreQpssBar(self)

QProgreQpssBar的构造方法

self.timer = QtCore.QBasicTimer()

使用定时器来激活QProgreQpssBar

self.timer.start(100, self)

调用启动一个计时器方法有两个参数:超时和对象接收事件。

def timerEvent(self, e):
        if self.step >= 100:
            self.timer.stop()
            self.btn.setText('Finished')
            return
        self.step = self.step + 1
        self.pbar.setValue(self.step)

每个QObject及其子类都有一个timerEvent() 事件处理器。我们要重新实现这个事件处理器来响应定时器事件。

def doAction(self):
        if self.timer.isActive():
            self.timer.stop()
            self.btn.setText('Start')
        else:
            self.timer.start(100, self)
            self.btn.setText('Stop')

我们在doAction() 方法中启动/停止定时器


QCalendarWidget 日历控件

QCalendarWidget 提供了一个基于月份的日历控制。它是用户以一种简单直观的方式来选在日期

import sys
from PyQt5.QtWidgets import (QWidget, QCalendarWidget,
                             QLabel, QApplication)
from PyQt5.QtCore import QDate
 
 
class Example(QWidget):
    def __init__(self):
        super().__init__()
 
        self.initUI()
 
    def initUI(self):
        cal = QCalendarWidget(self)
        cal.setGridVisible(True)
        cal.move(20, 20)
        cal.clicked[QDate].connect(self.showDate)
 
        self.lbl = QLabel(self)
        date = cal.selectedDate()
        self.lbl.setText(date.toString())
        self.lbl.move(130, 260)
 
        self.setGeometry(300, 300, 350, 300)
        self.setWindowTitle('Calendar')
        self.show()
 
    def showDate(self, date):
        self.lbl.setText(date.toString())
 
 
if __name__ == '__main__':
    app = QApplication(sys.argv)
    ex = Example()
    sys.exit(app.exec_())

示例中创建一个日历控件和一个标签控件。选择的日期会显示在标签空间中。

cal = QCalendarWidget(self)

QCalendarWidget 被创建

cal.clicked[Qdate].connet(self.showDate)

从部件选择一个日期,点击[QDATE] 发出信号。我们将这个信号连接到用户定义的 shouwdate 相似的方法

def showDate(self, date):
    
    self.lbl.setText(date.toString())

检索所选的日期通过selectedDate() 方法。然后我们将日期对象转换为字符串,并将其设置为小部件的标签。

如果觉得我的文章对您有用,请随意赞赏。您的支持将鼓励我继续创作!

发表评论

电子邮件地址不会被公开。 必填项已用*标注