GF
Glep FingermanJan. 10, 2021, 11:52 a.m.

Сигналы и слоты в PyQt5

UI

Пример тестового интерфейса с описанием подключения слота и сигнала, но оно не срабатывает по непонятным причинам.

import sys, binascii, glob, asyncio 
from PyQt5.QtCore import QObject, pyqtSlot, QDateTime, Qt, QTimer 
from PyQt5 import QtCore, QtGui, QtWidgets 
from PyQt5.QtWidgets import (QApplication, QCheckBox, QComboBox, QDateTimeEdit,
        QDial, QDialog, QGridLayout, QGroupBox, QHBoxLayout, QLabel, QLineEdit,
        QProgressBar, QPushButton, QRadioButton, QScrollBar, QSizePolicy,
        QSlider, QSpinBox, QStyleFactory, QTableWidget, QTabWidget, QTextEdit,
        QVBoxLayout, QWidget, QMainWindow, QMessageBox) 

class Ui_MainWindow(object): 
    def setupUi(self, MainWindow): 
        MainWindow.setObjectName("MainWindow"); MainWindow.resize(400, 300);
        self.centralWidget = QtWidgets.QWidget(MainWindow); self.centralWidget.setObjectName("centralWidget");
        self.gridLayout = QtWidgets.QGridLayout(self.centralWidget); self.gridLayout.setContentsMargins(11,11,11,11);
        self.gridLayout.setSpacing(6); self.gridLayout.setObjectName("gridLayout");
        self.verticalLayout = QtWidgets.QVBoxLayout(); self.verticalLayout.setSpacing(6);
        self.verticalLayout.setObjectName("verticalLayout");
        self.pushButtonFirst = QtWidgets.QPushButton(self.centralWidget);
        self.pushButtonFirst.setObjectName("pushButtonFirst");self.verticalLayout.addWidget(self.pushButtonFirst);
        self.pushButtonSecond = QtWidgets.QPushButton(self.centralWidget);
        self.pushButtonSecond.setObjectName("pushButtonSecond");self.verticalLayout.addWidget(self.pushButtonSecond);
        self.checkBox = QtWidgets.QCheckBox(self.centralWidget);
        self.checkBox.setObjectName("checkBox"); self.verticalLayout.addWidget(self.checkBox);
        self.lineEdit = QtWidgets.QLineEdit(self.centralWidget);
        self.lineEdit.setObjectName("lineEdit"); self.verticalLayout.addWidget(self.lineEdit);
        self.gridLayout.addLayout(self.verticalLayout,0,0,1,1);MainWindow.setCentralWidget(self.centralWidget); 
        self.menuBar = QtWidgets.QMenuBar(MainWindow);self.menuBar.setGeometry(QtCore.QRect(0,0,400,21));
        self.menuBar.setObjectName("menuBar");MainWindow.setMenuBar(self.menuBar);
        self.mainToolBar = QtWidgets.QToolBar(MainWindow);self.mainToolBar.setObjectName("mainToolBar");
        MainWindow.addToolBar(QtCore.Qt.TopToolBarArea, self.mainToolBar);
        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.pushButtonFirst.setText(_translate("MainWindow", "PushButton"))
        self.pushButtonSecond.setText(_translate("MainWindow", "PushButton"))
        self.checkBox.setText(_translate("MainWindow", "CheckBox"))

class MainWindow(QtWidgets.QMainWindow, Ui_MainWindow):
    def __init__(self, parent=None):
        super(MainWindow, self).__init__(parent); self.setupUi(self);
        self.pushButtonFirst.released.connect(self.pushButtonClicked)
        #self.pushButtonFirst.clicked.connect(self.pushButtonClicked) 

    @QtCore.pyqtSlot() 
    def pushButtonClicked(self):
        try:
            sender = self.sender();
            self.statusBar().showMessage(sender.text() + ' was pressed')
            msg = QMessageBox();
            msg.setIcon(QMessageBox.Information);
            msg.setText("This is a message box");
            msg.setInformativeText("This is additional information");
            msg.setWindowTitle("MessageBox demo");
            msg.setDetailedText("The details are as follows:");
            msg.setStandardButtons(QMessageBox.Ok | QMessageBox.Cancel);
            msg.exec_(); 
        except  Exception as e: 
            return str(e);

if __name__ == "__main__":
    app=QtWidgets.QApplication(sys.argv); w=MainWindow(); w.show(); sys.exit(app.exec_())

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.
2

Попробуйте сделать всю работу с одном в одном классе. И лучше проверяйте нажатие кнопки.

GF

Решение стало следующим: после конвертации файла Ui из QtDesigner мне никак не выгодно продолжать работать в этом же файле, т.к. я постоянно продолжаю дорабатывать интерфейс, а его поведение я описываю в другом файле, поэтому я делаю следующее описание

# Импорт класса графического интерфейса 
import GUISignalWriter as GUI 

Затем я создаю класс, в котором описываю подключение интерфейса и создание слотов для элементов управления

#%% Точка входа в программу 
class MainWindow(QtWidgets.QMainWindow, GUI.Ui_MainWindow): 
    def __init__(self, parent=None): 
        # инициализация интерфейса 
        super(MainWindow, self).__init__(parent); self.setupUi(self);

В таком случае я безпрепятственно постоянно могу корректировать интерфейс и безпрепятственно ориентироваться в другом классе для управления поведением новыми элементами управления.

Comments

Only authorized users can post comments.
Please, Log in or Sign up
Timeweb

Let me recommend you the excellent hosting on which EVILEG is located.

For many years, Timeweb has been proving his stability.

For projects on Django I recommend VDS hosting

View Hosting
NI

C ++ - Test 004. Pointers, Arrays and Loops

  • Result:90points,
  • Rating points8
NI

C++ - Тест 003. Условия и циклы

  • Result:92points,
  • Rating points8
NI

C++ - Test 001. The first program and data types

  • Result:80points,
  • Rating points4
Last comments
D

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

А почему нельзя? Где можно об этом почитать? Киньте, пожалуйста, в меня ссылкой.
D

Django - Tutoral 049. Optimizing Django Performance with a Real Project

Огромное спасибо вам за статью! Для меня стали открытием select_related и prefetch_related
t
  • t1m4
  • Feb. 24, 2021, 2:56 a.m.

Django - Tutorial 052. Redefining a User Model

В данном случае я заходил под superuser но все равно не появлялись эти поля

Django - Tutorial 001. Deploying a site on Django + PostgreSQL + Gunicorn + Nginx

Поднял сервис с помощью systemd, вот по этому мануалу: https://habr.com/ru/post/501414/
t
  • t1m4
  • Feb. 23, 2021, 7:11 a.m.

Django - Tutorial 052. Redefining a User Model

А как дать ему эти права?
Now discuss on the forum
  • BlinCT
  • March 6, 2021, 10:57 a.m.

Работа с QJsonObject и получение данных из него

Вопрос решен. Оказалось что я не очень внимательно прочитал описание метода root.take("devices") Оказывается он удаляте ключ, а занчит и все данные по нему. И по этому после этого…

Как совместить таблицу и дерево в Qt

Добрый день. Имеется таблица QTableView, нужно у некоторых строк сделать возможность раскрытий, как в QTreeVidget и отоборажать в них аналогичные строки. Скажите пожалуйста, как это мо…
KM

не получаеться добавить списки в списокб ошибка в петле

решение: с line 99: listy = [] lista = [] for single_lp in max_list_from_all_plates: suma = 0 lists = [] for sign in single_lp: Highest_score=0 bigl…
KM

Не отдаётся статика на виртуальной машине

В итоге выставил 775 на все файлы проекта и всё заработало. Но я не уверен, что так правильно.
About
Services
© EVILEG 2015-2020
Recommend hosting TIMEWEB