Python Qt GUI设计:QPushButton、QRadioButton和QCheckBox按钮类(基础篇—12)

本文详细介绍了PyQt中的三种重要按钮类型:QPushButton(命令按钮)、QRadioButton(单选按钮)和QCheckBox(复选框)。讲解了它们的使用场景、方法和信号处理,以及实战示例代码。
摘要由CSDN通过智能技术生成

目录

1、QPushButton按钮类

2、QRadioButton按钮类

3、QCheckBox按钮类


在GUI设计中,按钮都是最重要的和常用的触发动作请求的方式,用来与用户进行交互操作。在PyQt中根据不同的使用场景将按钮划分为不同的表现形式。

按钮的基类是QAbstractButton,提供了按钮的通用性功能。但是它不能实例化,必须由其他的按钮类继承QAbstractButton类,来实现不同的功能、不同的表现形式。

常见的按钮类包括:QPushButton、QRadioButton和QCheckBox等。这些按钮类均继承自QAbstractButton类,根据各自的使用场景通过图形展现出来。

QAbstractButton提供的状态如下表所示:

QAbstractButton提供的信号如下表所示: 

1、QPushButton按钮类

QPushButton类继承自QAbstractButton类,其形状是长方形,文本标题或图标可以显示在长方形上。

QPushButton类是一种命令按钮,可以单击该按钮执行一些命令,或者响应一些事件,常见的有:“确认"、"申请"、"取消"、"关闭"、"是"、"否"等按钮。

QPushButton类中的常用方法如下表所示:

来看看QPushButton按钮类的示例,效果如下所示:

在这个例子中,创建了btn1、btn2、btn3和btn4四个按钮,这四个QPushButton对象被定义为类的实例变量。每个按钮都将clicked信号发送给指定的槽函数,以响应按钮点击事件。

  • 第1个按钮btn1,通过toggle()函数来切换按钮状态。当点击这个按钮时,将clicked信号发送给槽函数btnstate(),通过btn.isChecked来获得按钮是否被点击或释放的状态。还可以通过lambda的方式来传递额外的参数btn1,将clicked信号发送给槽函数whichbtn()。
  • 第2个按钮btn2,上面显示一个图标。使用setlcon()方法接收一个QPixmap对象的图像文件作为输入参数。
  • 第3个按钮btn3,使用setEnabled()方法来禁用bnt3按钮。
  • 第4个按钮btn4,使用setDefault()方法来设置按钮的默认状态。快捷键是“&+文本”(&Download),通过“Alt+D”快捷键来调用槽函数。

实现代码如下所示:

 
  1. import sys

  2. from PyQt5.QtCore import *

  3. from PyQt5.QtGui import *

  4. from PyQt5.QtWidgets import *

  5. class Form(QDialog):

  6. def __init__(self, parent=None):

  7. super(Form, self).__init__(parent)

  8. layout = QVBoxLayout()

  9. self.btn1 = QPushButton("Button1")

  10. self.btn1.setCheckable(True)

  11. self.btn1.toggle()

  12. self.btn1.clicked.connect(lambda:self.whichbtn(self.btn1) )

  13. self.btn1.clicked.connect(self.btnstate)

  14. layout.addWidget(self.btn1)

  15. self.btn2 = QPushButton('image')

  16. self.btn2.setIcon(QIcon(QPixmap("./python.png")))

  17. self.btn2.clicked.connect(lambda:self.whichbtn(self.btn2) )

  18. layout.addWidget(self.btn2)

  19. self.setLayout(layout)

  20. self.btn3 = QPushButton("Disabled")

  21. self.btn3.setEnabled(False)

  22. layout.addWidget(self.btn3)

  23. self.btn4= QPushButton("&Download")

  24. self.btn4.setDefault(True)

  25. self.btn4.clicked.connect(lambda:self.whichbtn(self.btn4))

  26. layout.addWidget(self.btn4)

  27. self.setWindowTitle("Button demo")

  28. def btnstate(self):

  29. if self.btn1.isChecked():

  30. print("button pressed" )

  31. else:

  32. print("button released" )

  33. def whichbtn(self,btn):

  34. print("clicked button is " + btn.text() )

  35. if __name__ == '__main__':

  36. app = QApplication(sys.argv)

  37. btnDemo = Form()

  38. btnDemo.show()

  39. sys.exit(app.exec_())

2、QRadioButton按钮类

QRadioButton类提供了一组可供选择的按钮和文本标签,用户可以选择其中一个选项,标签用于显示对应的文本信息。单选钮是一种开关按钮,可以切换为on或者off,即checked或者unchecked,主要是为用户提供"多选一"的选择。

QRadioButton是单选钮控件默认是独占的(Exclusive)。对于继承自同一个父类Widget的多个单选钮,它们属于同一个按钮组合,在单选钮组里,一次只能选择一个单选钮。如果需要多个独占的按钮组合,则需要将它们放在QGroupBox或QButtonGroup中。

QRadioButton类中的常用方法如下表所示:

在QRadioButton中,toggled信号是在切换单选钮状态(开、关)时发射的,而clicked信号则在每次点击单选钮时都会发射。在实际中,一般只有状态改变时才有必要去响应,因此toggled信号更适合用于状态监控。

来看看QRadioButton按钮类的示例,效果如下所示:

在这个例子中,两个互斥的单选钮被放置在窗口中。

第1个单选钮btn1,被设置成默认选中状态。

self.btn1.setChecked(True)

当选择两个按钮相互切换时,按钮的状态发生改变,将触发toggle信号,并与槽函数btnstate()连接。使用lambda的方式允许将源信号传递给槽函数,将按钮作为参数。

 
  1. self.btn1.toggled.connect(lambda:self.btnstate(self.btn1))

  2. self.btn2.toggled.connect(lambda:self.btnstate(self.btn2))

当发射toggled信号后,使用btnstate()函数来检查按钮的状态。

实现代码如下所示:

 
  1. import sys

  2. from PyQt5.QtCore import *

  3. from PyQt5.QtGui import *

  4. from PyQt5.QtWidgets import *

  5. class Radiodemo(QWidget):

  6. def __init__(self, parent=None):

  7. super(Radiodemo, self).__init__(parent)

  8. layout = QHBoxLayout()

  9. self.btn1 = QRadioButton("Button1")

  10. self.btn1.setChecked(True)

  11. self.btn1.toggled.connect(lambda:self.btnstate(self.btn1))

  12. layout.addWidget(self.btn1)

  13. self.btn2 = QRadioButton("Button2")

  14. self.btn2.toggled.connect(lambda:self.btnstate(self.btn2))

  15. layout.addWidget(self.btn2)

  16. self.setLayout(layout)

  17. self.setWindowTitle("RadioButton demo")

  18. def btnstate(self,btn):

  19. if btn.text()=="Button1":

  20. if btn.isChecked() == True:

  21. print( btn.text() + " is selected" )

  22. else:

  23. print( btn.text() + " is deselected" )

  24. if btn.text()=="Button2":

  25. if btn.isChecked()== True :

  26. print( btn.text() + " is selected" )

  27. else:

  28. print( btn.text() + " is deselected" )

  29. if __name__ == '__main__':

  30. app = QApplication(sys.argv)

  31. radioDemo = Radiodemo()

  32. radioDemo.show()

  33. sys.exit(app.exec_())

3、QCheckBox按钮类

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

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

QCheckBox通常被应用在需要用户选择一个或多个可用的选项的场景中。

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

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

QCheckBox类中的常用方法如下表所示:

。。。。。。。。。。。。。。。。。

版权原因,完整文章,请参考如下:

Python Qt GUI设计:QPushButton、QRadioButton和QCheckBox按钮类(基础篇—12)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值