s
Маусым 7, 2022, 12:01 Т.Қ.

Событие wheelEvent для виджета QLineEdit

QLineEdit, wheelEvent

Нашёл вот такой пример:

!/usr/bin/python3

from PyQt5.QtGui import
from PyQt5.QtCore import

from PyQt5.QtWidgets import
import sys
class LineEdit(QLineEdit):
KEY = Qt.Key_Shift
def init (self,
args, kwargs):
QLineEdit. init (self, *args,
kwargs)
self.isKeyPressed = False
def keyPressEvent(self, event):
if event.key() == LineEdit.KEY:
self.isKeyPressed = True
QLineEdit.keyPressEvent(self, event)
def keyReleaseEvent(self, event):
if event.key() == LineEdit.KEY:
self.isKeyPressed = False
QLineEdit.keyReleaseEvent(self, event)

def wheelEvent(self, event):
    #if self.isKeyPressed:
    delta = 1 if event.angleDelta().y() > 0 else -1
    fn = self.font()
    fn.setPointSize(fn.pointSize() +  delta)
    self.setFont(fn)
    event.accept()

class SurfViewer(QMainWindow):
def init (self, parent=None):
super(SurfViewer, self). init ()
self.parent = parent
self.centralTabs= QTabWidget()
self.setCentralWidget(self.centralTabs)
self.setFixedWidth(200)
self.setFixedHeight(200)
#tab Model selection
self.tab_ModelSelect = QWidget()
self.centralTabs.addTab(self.tab_ModelSelect,"Label")
self.groupscrolllayouttest = QHBoxLayout() ####
self.groupscrollbartest = QGroupBox() ####
self.mainHBOX_param_scene = QVBoxLayout()
for i in range(2):
le = LineEdit(str(i))
le.setFixedWidth(200)
self.mainHBOX_param_scene.addWidget(le)
self.installEventFilter(self)
scroll = QScrollArea()
widget = QWidget(self)
widget.setLayout(QVBoxLayout())
widget.layout().addWidget(self.groupscrollbartest)
scroll.setWidget(widget)
scroll.setWidgetResizable(True)
self.groupscrollbartest.setLayout(self.mainHBOX_param_scene)
self.groupscrolllayouttest.addWidget(scroll)
self.tab_ModelSelect.setLayout(self.groupscrolllayouttest)
def main():
app = QApplication(sys.argv)
ex = SurfViewer(app)
ex.setWindowTitle('window')
# ex.showMaximized()
ex.show()
sys.exit(app.exec_( ))
if name == ' main ':
main()

Здесь (что очевидно) наследованный виджет обладает обработкой события wheelEvent, да, но у меня вопрос, на который не нашёл ответа, а сам как то не могу догнать:
сейчас я создаю интерфейс в Qt5 Designer, конвертирую и импортирую соотвественно... каким образом событие wheelEvent прикрутить к такому импортированному виджету?
Подскажи пожалуйста.

2

Ол саған ұнайды ма? Әлеуметтік желілерде бөлісіңіз!

2
Evgenii Legotckoi
  • Маусым 7, 2022, 1:04 Т.Қ.

Если вы делаете интерфес с QLineEdit внутри, и вам нужен собственный CustomLineEdit, то наверное проще всего будет вручную в конвертированном файле щаменить QLineEdit на кастомный CustomLineEdit, поскольку Qt Designer работает с C++ Классами и там есть конечно функционал Promote To, когда в него добавляются кастомные виджеты, но нужно указывать заголовочный файл кастомного виджета, а это значит, что нужно написать C++ виджета, а это не ваш случай.
Так что лично мне ничего в голову кроме как ручной модификации конвертированного файла в голову не приходит.

    s
    • Маусым 7, 2022, 10:45 Т.Қ.

    вот что получилось:
    gui.py

    from PyQt5 import QtCore, QtGui, QtWidgets

    class LineEdit(QtWidgets.QLineEdit):
    def wheelEvent(self, event):
    #print("_")
    delta = 1 if event.angleDelta().y() > 0 else -1
    fn = int(self.text())
    fn = fn + delta
    self.setText(str(fn))
    event.accept()

    class Ui_MainWindow(object):
    def setupUi(self, MainWindow):
    MainWindow.setObjectName("MainWindow")
    MainWindow.resize(800, 101)
    self.centralwidget = QtWidgets.QWidget(MainWindow)
    self.centralwidget.setObjectName("centralwidget")
    self.horizontalLayout_2 = QtWidgets.QHBoxLayout(self.centralwidget)
    self.horizontalLayout_2.setObjectName("horizontalLayout_2")
    self.horizontalLayout = QtWidgets.QHBoxLayout()
    self.horizontalLayout.setObjectName("horizontalLayout")
    self.label = QtWidgets.QLabel(self.centralwidget)
    self.label.setObjectName("label")
    self.horizontalLayout.addWidget(self.label)
    self.lineEdit = LineEdit(self.centralwidget)
    self.lineEdit.setObjectName("lineEdit")
    self.horizontalLayout.addWidget(self.lineEdit)
    self.horizontalLayout_2.addLayout(self.horizontalLayout)
    MainWindow.setCentralWidget(self.centralwidget)
    self.menubar = QtWidgets.QMenuBar(MainWindow)
    self.menubar.setGeometry(QtCore.QRect(0, 0, 800, 21))
    self.menubar.setObjectName("menubar")
    MainWindow.setMenuBar(self.menubar)
    self.statusbar = QtWidgets.QStatusBar(MainWindow)
    self.statusbar.setObjectName("statusbar")
    MainWindow.setStatusBar(self.statusbar)

        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
    
    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        self.label.setText(_translate("MainWindow", "Число"))
    

    и main.py:

    from math import *
    import sys
    from PyQt5 import QtCore, QtGui, QtWidgets
    import gui

    class ExampleApp(QtWidgets.QMainWindow, gui.Ui_MainWindow):

    def __init__(self):
        super().__init__()
        self.setupUi(self)  
        self.lineEdit.setValidator(QtGui.QIntValidator(0, 30)) #wheelEvent.connect(self.evnt) # генерить панель
    

    def main():
    app = QtWidgets.QApplication(sys.argv)
    window = ExampleApp()
    window.show()
    app.exec_()

    if name == ' main ':
    main()

    Интересно что подключенный валидатор, не контролирует число в строке ввода, и мышью можно "накрутить" число ниже и выше пределов :)

      Пікірлер

      Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
      Кіріңіз немесе Тіркеліңіз