s
spyAndrey7 июня 2022 г. 2: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 прикрутить к такому импортированному виджету?
Подскажи пожалуйста.

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

2
Evgenii Legotckoi
  • 7 июня 2022 г. 3:04

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

    s
    • 7 июня 2022 г. 12: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()

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

      Комментарии

      Только авторизованные пользователи могут публиковать комментарии.
      Пожалуйста, авторизуйтесь или зарегистрируйтесь
      ОК

      Qt - Тест 001. Сигналы и слоты

      • Результат:47баллов,
      • Очки рейтинга-6
      A
      • Alena
      • 19 января 2025 г. 11:41

      C++ - Тест 005. Структуры и Классы

      • Результат:58баллов,
      • Очки рейтинга-2
      OI
      • Ora Iro
      • 24 декабря 2024 г. 6:38

      C++ - Тест 001. Первая программа и типы данных

      • Результат:40баллов,
      • Очки рейтинга-8
      Последние комментарии
      ИМ
      Игорь Максимов22 ноября 2024 г. 11:51
      Django - Урок 017. Кастомизированная страница авторизации на Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
      Evgenii Legotckoi
      Evgenii Legotckoi31 октября 2024 г. 14:37
      Django - Урок 064. Как написать расширение для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
      A
      ALO1ZE19 октября 2024 г. 8:19
      Читалка fb3-файлов на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
      ИМ
      Игорь Максимов5 октября 2024 г. 7:51
      Django - Урок 064. Как написать расширение для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
      d
      dblas55 июля 2024 г. 11:02
      QML - Урок 016. База данных SQLite и работа с ней в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      Сейчас обсуждают на форуме
      n
      nkly3 января 2025 г. 2:52
      Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
      M
      Marsel16 августа 2023 г. 14:26
      OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
      Evgenii Legotckoi
      Evgenii Legotckoi24 июня 2024 г. 15:11
      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
      t
      tonypeachey115 ноября 2024 г. 6:04
      google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
      NSProject
      NSProject4 июня 2022 г. 3:49
      Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

      Следите за нами в социальных сетях