PyQt5基本窗口控件(五)按钮类控件

五、按钮类控件

1、QAbstractButton

  • 这个类是所有按钮类的基类,是抽象类,不能实例化,必须由其他按钮类继承来实现不同的功能。
  • QAbstractButton提供的状态
状态含义
isDown()提示按钮是否被按下
ischecked()提示按钮是否已经标记
isEnable()提示按钮是否可以被用户点击
ischeckAble()提示按钮是否为可标记的
setautoRepeat()设置按钮是否在用户长按时可以自动重复执行
  • QAbstractButton提供的信号
信号含义
Pressed当鼠标指针在按钮上并按下左键时触发该信号
Released当鼠标左键被释放时触发该信号
Clicked当鼠标左键被按下然后释放时,或者快捷键被释放时触发该信号
Toggled当按钮的标记状态发生改变时触发该信号

2、QPushButton

  • QPushButton类继承自QAbstractButton类,其形状是长方形,文本标题或图标可以显示在长方形上。它也是一种命令按钮,可以单击该按钮执行一些命令,或者响应一些事件。常见的有“确认”“申请”“取消”“关闭”“是”“否”等按钮。

  • 命令按钮通常通过文本来描述执行的动作,有时候也会通过快捷键来执行对应按钮的命令。

(1)QPushButton类的常用方法
方法描述
setCheckable()设置按钮是否已经被选中,设置为True表示按钮将保持已点击和释放状态
toggle()在按钮状态之间进行切换
setIcon()设置按钮上的图标
setEnabled()设置按钮是否可以使用,当设置为False时,按钮变成不可用状态
ischedked()返回按钮的状态,返回值为True或False
setDefault()设置按钮的默认状态
setText()设置按钮的显示文本
text()返回按钮的显示文本
(2)为QPushButton设置快捷键
  • 通过按钮名字设置,如名字“&Download”,它的快捷键是“Alt+D”,首字母D带下划线。代码如下。
self.button = QPushButton("&Download") 	
self.button.setDefault(True)
案例十四 QPushButton按钮的使用
# -*- coding:utf-8 -*-
"""
    # @Time:2022/12/9 0009 6:59
    # @Author:晚秋拾叶
    # @File:qt04_QButton.py
    # @PyCharm之Python
"""
import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *


class Form(QDialog):
    def __init__(self, parent=None):
        super(Form, self).__init__(parent)

        VBlayout = QVBoxLayout()
        self.setLayout(VBlayout)

        self.btn1 = QPushButton("Button1")
        self.btn1.setCheckable(True)    # 设置是否被选中,True为选中
        self.btn1.toggle()  ## 切换按钮状态
        self.btn1.clicked.connect(lambda: self.whichbtn(self.btn1))
        self.btn1.clicked.connect(self.btnstate)
        VBlayout.addWidget(self.btn1)

        self.btn2 = QPushButton('image')
        self.btn2.setIcon(QIcon("./images/头像.ico"))
        self.btn2.clicked.connect(lambda: self.whichbtn(self.btn2))
        VBlayout.addWidget(self.btn2)


        self.btn3 = QPushButton("Disabled")
        self.btn3.setEnabled(False)
        VBlayout.addWidget(self.btn3)

        self.btn4 = QPushButton('&Download')
        self.btn4.setDefault(True)
        self.btn4.clicked.connect(lambda: self.whichbtn(self.btn4))
        VBlayout.addWidget(self.btn4)
        self.setWindowTitle("Button Demo")

    def btnstate(self):
        if self.btn1.isChecked():
            print("Button pressed按下")
        else:
            print("Button released释放")

    def whichbtn(self, btn):
        print("Clicked button is " + btn.text())


if __name__ == '__main__':
    app = QApplication(sys.argv)
    win = Form()
    win.show()
    sys.exit(app.exec_())

  • 代码分析
  • 在这个例子中,创建了 btn1、btn2、btn3 和 btn4 四个按钮,这四个QPushButtom对象被定义为类的实例变量。上面的代码符合面向对象的设计思想。每个按钮都将clicked 信号发送给指定的槽函数,以响应按钮点击事件。
  • 第1个按钮 btn1,通过toggle()函数来切换按钮状态。其核心代码是:
self.btn1 =QPushButton("Button1") 
self.btnl.setCheckable(True) 
self.btn1.toggle()
  • 当点击这个按钮时,将 clicked 信号发送给槽函数 btnstate(),通过btn.isCheckec来获得按钮是否被点击或释放的状态。其核心代码是:
self.btn1.clicked.connect(self.btnstate)
  • 还可以通过 lambda 的方式来传递额外的参数 btn1,将clicked 信号发送给槽函数 whichbtn()。其核心代码是:
self.btn1.clicked.connect(lambda:self.whichbtn(self.btn1))
  • 第 2个按钮 btn2,上面显示一个图标。使用 setIcon()方法接收一个 QPixmap对象的图像文件作为输入参数。其核心代码是:
self.btn2.setIcon(QIcon(QPixmap("./images/头像.ico")))
  • 第 3个按钮 btn3,使用 setEnabled()方法来禁用 bnt3 按钮
self.bcn3.setEnabled(False)
  • 第4个按钮 btn4,使用setDefault()方法来设置按钮的默认状态。快捷键是“&+文本”(&Download),通过“Alt+D”快捷键来调用槽函数。
self.btn4 = QPushButton('&Download')

3、QRadioButton

  • 单选按钮是一种开关按钮,切换为on或off,即checked或unchecked,多选一。
  • 多个单选按钮应该属于同一个按钮组合来使用,放置在QGroupBox或QButtonBox或QButtonGroup中。
  • 当单选按钮切换on或off,状态发生变化时,就会发送toggled信号,触发事件。
  • QRadioButton的常用方法
方法描述
setCheckable()设置按钮是否已经被选中,可以改变单选钮的选中状态,如果设置为 True,则表示单选钮将保持己点击和释放状态
ischecked()返回单选钮的状态。返回值为True或 False
setText()设置单选按钮的显示文本
text()返回单选按钮的显示文本
  • 在 QRadioButton中,toggled信号是在切换单选钮状态(开、关)时发射的,而clicked信号则在每次点击单选钮时都会发射。在实际中,一般只有状态改变时才有必要去响应,因此toggled信号更适合用于状态监控。
  • 效果如图
    在这里插入图片描述
案例十五 QRadioButton按钮的使用
# -*- coding:utf-8 -*-
"""
# -*- coding:utf-8 -*-
"""
    # @Time:2022/12/9 0009 7:32
    # @Author:晚秋拾叶
    # @File:qt04_QRadio.py
    # @PyCharm之Python
"""
import sys
from PyQt5.QtWidgets import *


class Radiodemo(QWidget):
    def __init__(self, parent=None):
        super(Radiodemo, self).__init__(parent)
        HBlayout = QHBoxLayout()
        self.setLayout(HBlayout)
        self.setWindowTitle("RadioButton Demo")
        self.resize(500, 200)

        self.btn1 = QRadioButton("Button1")
        self.btn1.setChecked(True)
        self.btn1.toggled.connect(lambda: self.btnstate(self.btn1))
        HBlayout.addWidget(self.btn1)

        self.btn2 = QRadioButton("Button2")
        self.btn2.toggled.connect(lambda: self.btnstate(self.btn2))
        HBlayout.addWidget(self.btn2)

    def btnstate(self, btn):
        if btn.text() == "Button1":
            if btn.isChecked():
                print(btn.text() + "is selected")
            else:
                print(btn.text() + "is deselected")

        if btn.text() == "Button2":
            if btn.isChecked():
                print(btn.text() + "is selected")
            else:
                print(btn.text() + "is deselected")


if __name__ == '__main__':
    app = QApplication(sys.argv)
    win = Radiodemo()
    win.show()
    sys.exit(app.exec_())


  • 代码分析
    • 发送信号,调用的槽函数有if判断的时候,connect参数要用Lambda语句
    self.btn1.toggled.connect(lambda: self.btnstate(self.btn1))
    
  • 效果如图
    在这里插入图片描述

4、QCheckbox

  • QCheckBox类继承自QAbstractButton类,它提供了一组带文本标签的复选框,用户可以选择多个选项。和QPushButton一样,复选框可以显示文本或者图标,其中文本可以通过构造函数或者 setText()来设置;图标可以通过 setIcon()来设置。在视觉上,QButtonGroup可以把许多复选框组织在一起。

  • OCheckBox(复选框)和 QRadioButton(单选钮)都是选项按钮,因为它们都可以在开(选中)或者关(未选中)之间切换。它们的区别是对用户选择的限制:单选钮提供了“多选一”的选择;而复选框提供的是“多选多”的选择。

  • QCheckBox通常被应用在需要用户选择一个或多个可用的选项的场景中。只要复选框被选中或者取消选中,都会发射一个stateChanged信号。如果想在复选框状态改变时触发相应的行为,请连接这个信号,可以使用isChecked()来查询复选框是否被选中。

  • 除了常用的选中和未选中两种状态,OCheckBox还提供了第三种状态(半选中)来表明“没有变化”。当需要为用户提供一个选中或者未选中复选框的选择时,这种状态是很有用的。如果需要第三种状态,则可以通过setTristate()来使它生效,并使用checkState()来查询当前的切换状态。

  • QcheckBox的常用方法

方法描述
setChecked()设置复选框的状态,设置为True时表示选中复选框,设置为 False时表示取消选中复选框
setText()设置复选框的显示文本
text()返回复选框的显示文本
ischecked()检查复选框是否被选中
setTriState()设置复选框为一个三态复选框
  • 三态复选框有三种状态
名称含义
Qt.Checked2组件没有被选中(默认)
Qt.PartiallyChecked1组件被半选中
Qt.Unchecked0组件被选中
案例十六 QCheckBox按钮的使用
# -*- coding:utf-8 -*-
"""
    # @Time:2022/12/9 0009 11:13
    # @Author:晚秋拾叶
    # @File:qt04_QCheckBox.py
    # @PyCharm之Python
"""
import sys

from PyQt5.QtCore import Qt
from PyQt5.QtWidgets import *


class CheckBoxDemo(QWidget):
    def __init__(self, parent=None):
        super(CheckBoxDemo, self).__init__(parent)

        groupBox = QGroupBox("Checkboxes")
        groupBox.setFlat(True)

        HBlayout = QHBoxLayout()
        self.checkBox1 = QCheckBox('&Checkbox1')
        self.checkBox1.setChecked(True)
        self.checkBox1.stateChanged.connect(lambda: self.btnstate())
        HBlayout.addWidget(self.checkBox1)

        self.checkBox2 = QCheckBox("Checkbox2")
        self.checkBox2.toggled.connect(lambda: self.btnstate())
        HBlayout.addWidget(self.checkBox2)

        self.checkBox3 = QCheckBox("Checkbox3")
        self.checkBox3.setTristate(True)
        self.checkBox3.setCheckState(Qt.PartiallyChecked)
        self.checkBox3.stateChanged.connect(lambda: self.btnstate())
        HBlayout.addWidget(self.checkBox3)

        groupBox.setLayout(HBlayout)
        VBLayout = QVBoxLayout()
        VBLayout.addWidget(groupBox)

        self.setLayout(VBLayout)
        self.setWindowTitle("CheckBox demo")

    def btnstate(self):
        chk1Status = self.checkBox1.text() + ",is checked = " + str(
            self.checkBox1.isChecked()) + ',checkstate = ' + str(self.checkBox1.checkState()) + "\n"
        chk2Status = self.checkBox2.text() + ",is checked = " + str(
            self.checkBox2.isChecked()) + ',checkstate = ' + str(self.checkBox2.checkState()) + "\n"
        chk3Status = self.checkBox3.text() + ",is checked = " + str(
            self.checkBox3.isChecked()) + ',checkstate = ' + str(self.checkBox3.checkState()) + "\n"
            
        print(chk1Status + chk2Status + chk3Status)


if __name__ == '__main__':
    app = QApplication(sys.argv)
    win = CheckBoxDemo()
    win.show()
    sys.exit(app.exec_())
  • 代码分析
  • 这个例子先将三个复选框添加到一个水平布局中,再把这个水平布局再放到垂直布局中。
  • 三个复选框的控件说明
控件类型控件名称显示的文本功能
QCheckBoxcheckBox1Checkbox1两种状态选择
QCheckBoxcheckBox2Checkbox2两种状态选择
QCheckBoxcheckBox3Checkbox3三种状态选择
  • 实例化三个复选框控件,第一个setChecked(True)状态,而且可以“Alt+C”快捷键,选择发送改变时,发送信号到按钮状态的槽函数btnstate()。第二个没做特殊设置,但状态改变时,发送信号到按钮状态的槽函数btnstate()
self.checkBox1 = QCheckBox('&Checkbox1')
self.checkBox1.setChecked(True)
self.checkBox2 = QCheckBox("Checkbox2")
self.checkBox2.toggled.connect(lambda: self.btnstate())
  • 第三个复选框按钮,使用setTristate()开启三态模式(没选、半选、全选)
self.checkBox3 = QCheckBox("Checkbox3")
self.checkBox3.setTristate(True)
# 预定义半选模式
self.checkBox3.setCheckState(Qt.PartiallyChecked)
  • 效果如图
    在这里插入图片描述
  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

朝兮暮兮

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值