首页 > 解决方案 > 子类抽象类

问题描述

我需要拦截旋转框按钮的升压和降压动作来启动一些代码来运行。但是,我相信我必须继承抽象类,但我不完全确定如何正确地去做。

我还没有尝试对其进行编码,无法通过谷歌搜索找到任何好的示例。我相信 spinbox.py 文件中有正确的方向,但不确定我需要做什么。

spinboxui.py

from PyQt5 import QtCore, QtGui, QtWidgets

class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(200, 150)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.gridLayout = QtWidgets.QGridLayout(self.centralwidget)
        self.gridLayout.setObjectName("gridLayout")
        self.groupBox = QtWidgets.QGroupBox(self.centralwidget)
        self.groupBox.setObjectName("groupBox")
        self.gridLayout_2 = QtWidgets.QGridLayout(self.groupBox)
        self.gridLayout_2.setObjectName("gridLayout_2")
        self.spinBox = QtWidgets.QSpinBox(self.groupBox)
        self.spinBox.setObjectName("spinBox")
        self.gridLayout_2.addWidget(self.spinBox, 0, 0, 1, 1)
        self.label = QtWidgets.QLabel(self.groupBox)
        self.label.setText("")
        self.label.setObjectName("label")
        self.gridLayout_2.addWidget(self.label, 0, 1, 1, 1)
        self.gridLayout.addWidget(self.groupBox, 0, 0, 1, 1)
        MainWindow.setCentralWidget(self.centralwidget)

旋转盒.py

import sys
from spinboxui import Ui_MainWindow
from PyQt5 import QtCore, QtGui, QtWidgets

class Main(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self, parent=None):
        super().__init__()
        self.setupUi(self)

    def do_something(self):
        pass


class QAbstractSpinBox(QtWidgets.QAbstractSpinBox):

    def __init__(self):
        QAbstractSpinBox.__init__(self)

    def stepUp(self):
        pass


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    spinbox = Main()
    spinbox.show()
    sys.exit(app.exec_())

我想拦截 step up 命令,运行一些代码,然后让 spinbox 执行。我将旋转框用作纯文本编辑字段的翻页器,随着旋转框的增加或减少,它会更改纯文本编辑器上的“页面”。在移动到下一个“页面”之前,我的代码需要在最后一个页面上运行。

标签: pythonpyqtpyqt5

解决方案


你不必:

  • 从 QAbstractSpinBox 继承,因为创建一个与 QSpinBox 继承的同名的类不会改变其行为

  • 覆盖该stepUp()方法,因为该方法仅stepBy()由开发人员调用该方法,相反,您必须覆盖该stepBy()方法并验证步骤是否为正或 1,如您所愿。

旋转盒.py

from PyQt5 import QtWidgets


class SpinBox(QtWidgets.QSpinBox):
    def stepBy(self, steps):
        if steps > 0:
            print("execute function")
        super(SpinBox, self).stepBy(steps)

spinboxui.py

from PyQt5 import QtCore, QtGui, QtWidgets

from spinbox import SpinBox


class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(200, 150)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.gridLayout = QtWidgets.QGridLayout(self.centralwidget)
        self.gridLayout.setObjectName("gridLayout")
        self.groupBox = QtWidgets.QGroupBox(self.centralwidget)
        self.groupBox.setObjectName("groupBox")
        self.gridLayout_2 = QtWidgets.QGridLayout(self.groupBox)
        self.gridLayout_2.setObjectName("gridLayout_2")
        self.spinBox = SpinBox(self.groupBox)
        self.spinBox.setObjectName("spinBox")
        self.gridLayout_2.addWidget(self.spinBox, 0, 0, 1, 1)
        self.label = QtWidgets.QLabel(self.groupBox)
        self.label.setText("")
        self.label.setObjectName("label")
        self.gridLayout_2.addWidget(self.label, 0, 1, 1, 1)
        self.gridLayout.addWidget(self.groupBox, 0, 0, 1, 1)
        MainWindow.setCentralWidget(self.centralwidget)

主文件

import sys
from spinboxui import Ui_MainWindow
from PyQt5 import QtCore, QtGui, QtWidgets


class Main(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self, parent=None):
        super().__init__()
        self.setupUi(self)


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    spinbox = Main()
    spinbox.show()
    sys.exit(app.exec_())

如果要执行main.py中的函数,最好创建一个信号:

旋转盒.py

from PyQt5 import QtCore, QtWidgets


class SpinBox(QtWidgets.QSpinBox):
    upSignal = QtCore.pyqtSignal()

    def stepBy(self, steps):
        if steps > 0:
            self.upSignal.emit()
        super(SpinBox, self).stepBy(steps)

主文件

import sys
from spinboxui import Ui_MainWindow
from PyQt5 import QtCore, QtGui, QtWidgets


class Main(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self, parent=None):
        super().__init__()
        self.setupUi(self)
        self.spinBox.upSignal.connect(self.on_up)

    @QtCore.pyqtSlot()
    def on_up(self):
        print("up")


if __name__ == '__main__':
    app = QtWidgets.QApplication(sys.argv)
    spinbox = Main()
    spinbox.show()
    sys.exit(app.exec_())

推荐阅读