python - 子类抽象类
问题描述
我需要拦截旋转框按钮的升压和降压动作来启动一些代码来运行。但是,我相信我必须继承抽象类,但我不完全确定如何正确地去做。
我还没有尝试对其进行编码,无法通过谷歌搜索找到任何好的示例。我相信 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 执行。我将旋转框用作纯文本编辑字段的翻页器,随着旋转框的增加或减少,它会更改纯文本编辑器上的“页面”。在移动到下一个“页面”之前,我的代码需要在最后一个页面上运行。
解决方案
你不必:
从 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_())
推荐阅读
- ios - 在 SwiftUI Xcode 13 iOS15 中编辑时,内容未显示在 TextFields 中
- reactjs - NextJs 基于正则表达式的重定向
- r - 日期:尚未针对此非数字和非字符类型实现 NAbounds=TRUE
- javascript - ReactJS CSS 属性重复
- javascript - 如何加载数组以映射到具有多行的列?
- javascript - Datepicker 仅显示上一个日期,而不是最近选择的日期
- python - 如何在二进制文件中创建新行,python
- javascript - 拒绝应用来自 'xxx/style.css' 的样式,因为它的 MIME 类型 ('text/html') 不是受支持的样式表 MIME 类型
- python - 在 Python 3.10 上启动 Spyder IDE 时出错
- python - 列表理解 - 结合重复词的定义,使每个词都是唯一的,但可能有多个定义