PyQt5 - Signaux et slots

Contrairement à une application en mode console, qui est exécutée de manière séquentielle, une application basée sur l'interface graphique est pilotée par les événements. Les fonctions ou méthodes sont exécutées en réponse aux actions de l'utilisateur comme cliquer sur un bouton, sélectionner un élément dans une collection ou un clic de souris, etc., appeléevents.

Les widgets utilisés pour créer l'interface GUI agissent comme la source de ces événements. Chaque widget PyQt, qui est dérivé de la classe QObject, est conçu pour émettre‘signal’en réponse à un ou plusieurs événements. Le signal seul n'effectue aucune action. Au lieu de cela, il est `` connecté '' à un‘slot’. L'emplacement peut être n'importe quelcallable Python function.

Utilisation de l'éditeur de signal / slot de Qt Designer

Commencez par concevoir un formulaire simple avec un contrôle LineEdit et un PushButton.

Il est souhaitable que si le bouton est enfoncé, le contenu de la zone de texte soit effacé. Le widget QLineEdit a une méthode clear () à cet effet. Par conséquent, le boutonclicked le signal doit être connecté à clear() méthode de la zone de texte.

Pour commencer, choisissez Modifier les signaux / slots dans le menu Edition (ou appuyez sur F4). Sélectionnez ensuite le bouton avec la souris et faites glisser le curseur vers la zone de texte

Lorsque la souris est relâchée, une boîte de dialogue affichant les signaux du bouton et les méthodes de l'emplacement s'affiche. Sélectionnez le signal cliqué et la méthode clear ()

La fenêtre Signal / Slot Editor en bas à droite affichera le résultat -

Enregistrez le code ui et Build et Python à partir du fichier ui comme indiqué dans le code ci-dessous -

pyuic5 -x signalslot.ui -o signalslot.py

Le code Python généré aura la connexion entre le signal et le slot par l'instruction suivante -

self.pushButton.clicked.connect(self.lineEdit.clear)

Exécutez signauxlot.py et entrez du texte dans LineEdit. Le texte sera effacé si le bouton est enfoncé.

Connexion de signal-slot de bâtiment

Au lieu d'utiliser Designer, vous pouvez établir directement une connexion signal-slot en suivant la syntaxe -

widget.signal.connect(slot_function)

Supposons si une fonction doit être appelée lorsqu'un bouton est cliqué. Ici, le signal cliqué doit être connecté à une fonction appelable. Il peut être réalisé dans l'une des techniques suivantes -

button.clicked.connect(slot_function)

Exemple

Dans l'exemple suivant, deux objets QPushButton (b1 et b2) sont ajoutés dans la fenêtre QDialog. Nous voulons appeler les fonctions b1_clicked () et b2_clicked () en cliquant respectivement sur b1 et b2.

Lorsque b1 est cliqué, le signal clicked () est connecté à la fonction b1_clicked () -

b1.clicked.connect(b1_clicked())

Lorsque b2 est cliqué, le signal clicked () est connecté à la fonction b2_clicked ().

import sys
from PyQt5.QtCore import *
from PyQt5.QtGui import *
from PyQt5.QtWidgets import *

def window():
   app = QApplication(sys.argv)
   win = QDialog()
   b1 = QPushButton(win)
   b1.setText("Button1")
   b1.move(50,20)
   b1.clicked.connect(b1_clicked)
   
   b2 = QPushButton(win)
   b2.setText("Button2")
   b2.move(50,50)
   b2.clicked.connect(b2_clicked)
   
   win.setGeometry(100,100,200,100)

   win.setWindowTitle("PyQt5")
   win.show()
   sys.exit(app.exec_())

def b1_clicked():
   print ("Button 1 clicked")

def b2_clicked():
   print ("Button 2 clicked")

if __name__ == '__main__':
   window()

Le code ci-dessus produit la sortie suivante -

Production

Button 1 clicked
Button 2 clicked