PyQt - QPushButton 控件



在任何 GUI 设计中,命令按钮是最重要和最常用的控件。带有“保存”、“打开”、“确定”、“是”、“否”和“取消”等标题的按钮对任何计算机用户都很熟悉。在 PyQt API 中,QPushButton 类对象表示一个按钮,单击该按钮可以编程为调用某个函数。

继承关系图

QPushButton 类继承其核心功能自 QAbstractButton 类,后者又继承自 QWidgets 类。命令按钮是矩形的,通常显示描述其操作的文本标签。它还可以使用文本中的&符号指定快捷键,从而启用键盘激活。

pyqt_qpushbutton_inheritance

示例

button = QPushButton("&Download", self)

在上例中,如果我们按下 Alt+D,则按钮将被激活。

QPushButton 的工作原理

QPushButton 可以显示文本标签和图标。我们可以在初始化期间设置按钮的这些属性,或者稍后使用 setText()setIcon() 等方法修改它们。当按钮被禁用时,文本和图标的外观会调整以指示按钮处于禁用状态。

QPushButton 在通过鼠标、空格键或键盘快捷键激活时会发出 clicked() 信号。此信号连接到执行按钮的相关操作。此外,它还提供 pressed()released() 等信号,用于不太常见的用例。

在对话框中,命令按钮设置为自动默认按钮,即当它们接收键盘焦点时,它们会自动成为默认按钮。当用户在对话框中按下 Enter 或 Return 键时,将激活默认按钮。可以使用 setAutoDefault() 自定义此行为。

Explore our latest online courses and learn new skills at your own pace. Enroll and become a certified expert to boost your career.

QPushButton 的用法

推送按钮可用于通过用户交互触发的操作,例如“应用”、“取消”或“帮助”。按钮具有宽矩形形状和文本标签。对于改变窗口状态的小型方形按钮,工具按钮 (QToolButton) 更为合适。

变体和自定义

QPushButton 提供各种自定义选项,包括切换行为 (setCheckable())、自动重复功能 (setAutoRepeat()) 和控制按钮外观。它支持不同的状态,例如可用或不可用,标准按钮或菜单按钮,打开或关闭(用于切换按钮),默认或普通,自动重复或不自动重复,以及按下或未按下。

QPushButton 类的常用方法

以下是 QPushButton 类的一些最常用的方法:

序号 方法及描述
1

setCheckable()

如果设置为 true,则识别按钮的按下和释放状态

2

toggle()

在可选中状态之间切换

3

setIcon()

显示由图像文件的像素图形成的图标

4

setEnabled()

设置为 false 时,按钮将被禁用,因此单击它不会发出信号

5

isChecked()

返回按钮的布尔状态

6

setDefault()

将按钮设置为默认按钮

7

setText()

以编程方式设置按钮的标题

8

text()

检索按钮的标题

示例

四个 QPushButton 对象设置了一些上述属性。该示例以面向对象的形式编写,因为需要将事件源作为参数传递给槽函数。

四个 QPushButton 对象在类中定义为实例变量。第一个按钮 b1 通过以下语句转换为切换按钮:

self.b1.setCheckable(True) self.b1.toggle()

此按钮的 clicked 信号连接到成员方法 btnstate(),该方法通过检查 isChecked() 属性来识别按钮是按下还是释放。

def btnstate(self): if self.b1.isChecked(): print "button pressed" else: print "button released"

第二个按钮 b2 在表面上显示一个图标。setIcon() 方法采用任何图像文件的像素图对象作为参数。

b2.setIcon(QIcon(QPixmap("python.gif")))

按钮 b3 使用 setEnabled() 方法设置为禁用:

b3.setEnabled(False)

PushButton b4 通过 setDefault() 方法设置为默认按钮。其标题的快捷键是通过在标题前添加 & 创建的 (&Default)。结果,通过使用键盘组合 Alt+D,将调用连接的槽方法。

按钮 b1 和 b4 连接到 whichbtn() 槽方法。由于该函数旨在检索被单击按钮的标题,因此应将按钮对象作为参数传递。这是通过使用 lambda 函数实现的。

例如:

b4.clicked.connect(lambda:self.whichbtn(self.b4))

完整的代码如下:

import sys from PyQt6.QtCore import * from PyQt6.QtGui import * from PyQt6.QtWidgets import QDialog,QApplication, QPushButton,QVBoxLayout class Form(QDialog): def __init__(self, parent=None): super(Form, self).__init__(parent) layout = QVBoxLayout() self.b1 = QPushButton("Button1") self.b1.setCheckable(True) self.b1.toggle() self.b1.clicked.connect(lambda:self.whichbtn(self.b1)) self.b1.clicked.connect(self.btnstate) layout.addWidget(self.b1) self.b2 = QPushButton() self.b2.setIcon(QIcon(QPixmap("python.gif"))) self.b2.clicked.connect(lambda:self.whichbtn(self.b2)) layout.addWidget(self.b2) self.setLayout(layout) self.b3 = QPushButton("Disabled") self.b3.setEnabled(False) layout.addWidget(self.b3) self.b4 = QPushButton("&Default") self.b4.setDefault(True) self.b4.clicked.connect(lambda:self.whichbtn(self.b4)) layout.addWidget(self.b4) self.setWindowTitle("Button demo") def btnstate(self): if self.b1.isChecked(): print ("button pressed") else: print ("button released") def whichbtn(self,b): print ("clicked button is "+b.text()) def main(): app = QApplication(sys.argv) ex = Form() ex.show() sys.exit(app.exec()) if __name__ == '__main__': main()

输出

以上代码产生以下输出。

qpushbutton widget output
clicked button is Button1
button released
clicked button is Button1
button pressed
clicked button is &Default

示例:带有菜单的 QPushButton

让我们创建一个带有菜单选项的 QPushButton。

import sys from PyQt6.QtWidgets import QApplication, QWidget, QPushButton, QMenu class Example(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): btn = QPushButton('Menu', self) menu = QMenu(self) menu.addAction('Option 1') menu.addAction('Option 2') btn.setMenu(menu) self.setGeometry(300, 300, 300, 200) self.setWindowTitle('Menu QPushButton') self.show() def main(): app = QApplication(sys.argv) ex = Example() sys.exit(app.exec()) if __name__ == '__main__': main()

输出

以上代码产生以下结果:

qpushbutton with menu
广告