Событие wheelEvent для виджета QLineEdit
Нашёл вот такой пример:
!/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 прикрутить к такому импортированному виджету?
Подскажи пожалуйста.
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.Do you like it? Share on social networks!
- Akiv Doros
- Nov. 11, 2024, 2:58 p.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:50points,
- Rating points-4
- molni99
- Oct. 26, 2024, 1:37 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:80points,
- Rating points4
- molni99
- Oct. 26, 2024, 1:29 a.m.
C ++ - Test 004. Pointers, Arrays and Loops
- Result:20points,
- Rating points-10
Если вы делаете интерфес с QLineEdit внутри, и вам нужен собственный CustomLineEdit, то наверное проще всего будет вручную в конвертированном файле щаменить QLineEdit на кастомный CustomLineEdit, поскольку Qt Designer работает с C++ Классами и там есть конечно функционал Promote To, когда в него добавляются кастомные виджеты, но нужно указывать заголовочный файл кастомного виджета, а это значит, что нужно написать C++ виджета, а это не ваш случай.
Так что лично мне ничего в голову кроме как ручной модификации конвертированного файла в голову не приходит.
вот что получилось:
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)
и main.py:
from math import *
import sys
from PyQt5 import QtCore, QtGui, QtWidgets
import gui
class ExampleApp(QtWidgets.QMainWindow, gui.Ui_MainWindow):
def main():
app = QtWidgets.QApplication(sys.argv)
window = ExampleApp()
window.show()
app.exec_()
if name == ' main ':
main()
Интересно что подключенный валидатор, не контролирует число в строке ввода, и мышью можно "накрутить" число ниже и выше пределов :)