阅读量:0
在 PyQt5 中,QPushButton 是一个常用的 GUI 组件,它可以触发特定的操作
以下是一个简单的示例,展示了如何使用 QPushButton 的信号和槽机制:
import sys from PyQt5.QtWidgets import QApplication, QWidget, QPushButton, QVBoxLayout, QLabel class MyApp(QWidget): def __init__(self): super().__init__() self.initUI() def initUI(self): self.setWindowTitle('QPushButton Signal and Slot') # 创建一个 QPushButton 实例 self.button = QPushButton('Click me', self) # 创建一个 QLabel 实例,用于显示按钮被点击的次数 self.label = QLabel('Button clicked 0 times', self) # 创建一个 QVBoxLayout 实例,用于布局按钮和标签 layout = QVBoxLayout() layout.addWidget(self.button) layout.addWidget(self.label) # 将布局设置为窗口的布局 self.setLayout(layout) # 连接 QPushButton 的 clicked 信号到自定义的槽函数 self.button.clicked.connect(self.on_button_clicked) def on_button_clicked(self): # 获取当前标签文本 text = self.label.text() # 解析出按钮被点击的次数 count = int(text.split()[-1]) # 更新按钮被点击的次数 count += 1 # 更新标签文本 self.label.setText(f'Button clicked {count} times') if __name__ == '__main__': app = QApplication(sys.argv) ex = MyApp() ex.show() sys.exit(app.exec_())
在这个示例中,我们创建了一个名为 MyApp
的类,它继承自 QWidget
。在 initUI
方法中,我们创建了一个 QPushButton 实例和一个 QLabel 实例。然后,我们将这两个组件添加到一个 QVBoxLayout 实例中,并将该布局设置为窗口的布局。
接下来,我们连接 QPushButton 的 clicked
信号到自定义的槽函数 on_button_clicked
。当按钮被点击时,这个槽函数会被调用,更新 QLabel 的文本以显示按钮被点击的次数。
最后,我们创建了一个 QApplication 实例,并将 MyApp 实例显示出来。程序将持续运行,直到用户关闭窗口。