Подкласс Абстрактный класс - PullRequest
0 голосов
/ 17 апреля 2019

Мне нужно перехватить пошаговые и пошаговые действия кнопок spinbox, чтобы запустить какой-то код. Тем не менее, я считаю, что должен подкласс абстрактного класса, но я не совсем уверен, как сделать это правильно.

Я еще не пытался его кодировать, не смог найти хороших примеров с помощью поиска в Google. Я считаю, что в файле 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)

spinbox.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. Я использую спинбокс в качестве перелистывания страниц для поля редактирования простого текста, так как спин-блок увеличивается или уменьшается, он меняет «страницу» в редакторе простого текста. У меня есть код, который нужно запустить на той странице, на которой он был последним, прежде чем перейти на следующую «страницу».

1 Ответ

1 голос
/ 17 апреля 2019

Вам не нужно:

  • Наследуется от QAbstractSpinBox, потому что создание класса с тем же именем, от которого наследуется QSpinBox, не изменит его поведение

  • Перезаписать метод stepUp(), поскольку этот метод вызывает только метод stepBy() разработчика, вместо этого вы должны перезаписать метод stepBy() и убедиться, что шаги положительные или равны 1, как вам нужно.

spinbox.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)

main.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)


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

Если вы хотите выполнить функцию в main.py, лучше всего создать сигнал:

spinbox.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)

main.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)
        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_())
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...