Cours:InterfaceQT : Différence entre versions

De troyesGEII
Aller à : navigation, rechercher
(2ème bouton => notre slot !)
 
(4 révisions intermédiaires par le même utilisateur non affichées)
Ligne 1 : Ligne 1 :
 
  [[Cours:3105|{{Rouge|'''Retour à la liste des Tds'''}}]]
 
  [[Cours:3105|{{Rouge|'''Retour à la liste des Tds'''}}]]
 
=Projet QtCreator pour raspberryPi=
 
 
*Nouveau Projet
 
*application Qt avec Widgets
 
*select kits
 
**Rpi
 
**cliquer sur manage
 
**appareil mobiles
 
**choisir périphérique rpi
 
**modifier nom d'hôte : ras-pi-xx
 
**xx est le numéro de la carte : par ex 05
 
**valider
 
*ajouter dans le fichier .pro les lignes suivantes après la ligne target= :
 
target.path = /root
 
INSTALLS = target
 
 
Consulter [[Cours:configQtRaspi|cette page pour des explications plus détaillées]]
 
 
{{Todo|Lancer l'application pour vérifier la configuration}}
 
  
 
=Premier bouton=
 
=Premier bouton=
Ligne 38 : Ligne 18 :
 
*une fenêtre s'ouvre
 
*une fenêtre s'ouvre
 
**à gauche, on choisit quel événement déclenche une action : c'est un {{Rouge|signal}} émit par l'objet
 
**à gauche, on choisit quel événement déclenche une action : c'est un {{Rouge|signal}} émit par l'objet
**à droite, on choisir l'action effectuée, la méthode à exécuter : c'est un {{Rouge|slot}}
+
**à droite, on choisit l'action effectuée, la méthode à exécuter : c'est un {{Rouge|slot}}
 
*fermons la fenêtre lors de l'appui sur le bouton :
 
*fermons la fenêtre lors de l'appui sur le bouton :
 
**cocher : afficher les signaux/slots hérités
 
**cocher : afficher les signaux/slots hérités
Ligne 45 : Ligne 25 :
  
 
{{Todo|Valider le fonctionnement}}
 
{{Todo|Valider le fonctionnement}}
 
  
 
=2ème bouton => notre slot ! =
 
=2ème bouton => notre slot ! =
Ligne 93 : Ligne 72 :
 
==Le graphisme==
 
==Le graphisme==
  
*On repasse sur l'interface graphique, passer un mode "Edit widget" au besoin (les boutons du haut).
+
*On repasse sur l'interface graphique, passer en mode "Edit widget" au besoin (les boutons du haut).
 
*On ajoute un 2ème bouton.
 
*On ajoute un 2ème bouton.
 
*On repasse en édition de signaux
 
*On repasse en édition de signaux
Ligne 151 : Ligne 130 :
  
 
{{Question|Ajouter la gestion de ce bouton supplémentaire}}
 
{{Question|Ajouter la gestion de ce bouton supplémentaire}}
 +
 +
=Projet QtCreator pour raspberryPi=
 +
 +
*Nouveau Projet
 +
*application Qt avec Widgets
 +
*select kits
 +
**Rpi
 +
**cliquer sur manage
 +
**appareil mobiles
 +
**choisir périphérique rpi
 +
**modifier nom d'hôte : ras-pi-xx (ou utiliser la correspondance carte n°1 => 10.98.9.20)
 +
**xx est le numéro de la carte : par ex 05
 +
**valider
 +
*ajouter dans le fichier .pro les lignes suivantes après la ligne target= :
 +
target.path = /root
 +
INSTALLS = target
 +
 +
Consulter [[Cours:configQtRaspi|cette page pour des explications plus détaillées]]
 +
 +
{{Todo|Lancer l'application pour vérifier la configuration}}
 +
 +
 +
=Pb sur la carte rpi=
 +
 +
Si le message suivant apparaît :
 +
QFontDatabase: Cannot find font directory /usr/local/qt5pi/lib/fonts
 +
 +
*se connecter sur la pi : ssh root@10.98.35.xxx
 +
*lancer la commande : ln -snf /usr/share/fonts/truetype/dejavu /usr/local/qt5pi/lib/fonts

Version actuelle datée du 15 septembre 2022 à 08:28

Retour à la liste des Tds

Premier bouton

Partie Graphique

  • Navigateur de projet
  • Forms
  • mainwindows.ui
  • glisser un pushbutton sur la fenêtre
  • redimensionner éventuellement

Todo.jpg Terminé ! Lancer l'application

Utilisation du bouton, signal/slot

  • ouvrir au besoin l'interface graphique, de son petit nom qtDesigner
  • dans les icônes du haut, cliquer sur Edit signals/slots
  • cliquer sur le bouton, et relâcher lorsque lorsque vous voyez un symbole de "masse"
  • une fenêtre s'ouvre
    • à gauche, on choisit quel événement déclenche une action : c'est un signal émit par l'objet
    • à droite, on choisit l'action effectuée, la méthode à exécuter : c'est un slot
  • fermons la fenêtre lors de l'appui sur le bouton :
    • cocher : afficher les signaux/slots hérités
    • signal : clicked()
    • slot : close()

Todo.jpg Valider le fonctionnement

2ème bouton => notre slot !

N'oublions par que nous faisons de la Programmation Orientée Objet.

Si nous regardons dans l'arborescence du projet, il y a 2 fichiers mainwindow.cpp mainwindow.h qui définissent la classe MainWindow.

La fenêtre qui s'affiche est un objet de la classe MainWindow, comme vous pouvez le constater dans le fichier main.cpp :

    ...
    MainWindow w;
    w.show();
    ...

Un slot, c'est une méthode particulière, c'est donc une fonctionnalité que nous ajoutons à notre objet.

On va donc ajouter un slot à la classe MainWindow pour associer une action particulière à un 2ème bouton

Le code :

On ajoute dans le fichier mainwindows.h la déclaration de ce slot juste avant la fin de la classe:

...
class MainWindow : public QMainWindow
{
...
public slots:
    void monAction();
};

On définit ensuite ce slot dans le fichier mainwindows.cpp

...
//permet d'afficher des messages :
#include <QDebug>
...
void MainWindow::monAction()
{
    qDebug() << "clic !";
}

Le graphisme

  • On repasse sur l'interface graphique, passer en mode "Edit widget" au besoin (les boutons du haut).
  • On ajoute un 2ème bouton.
  • On repasse en édition de signaux
    • au signal clicked
    • on associe le slot :
      • il n'apparaît pas dans la liste !
      • editer
      • bouton + dans la liste de slots
      • nom du slot : monAction()

Todo.jpg Let's try it and see

graphisme, à vous de jouer

Modifier la couleur d'un bouton

Voici le principe général pour changer la couleur d'un bouton

 monBouton.setStyleSheet("background-color: black;");

Dans une application graphique QT classique, l'objet ui représente le "conteneur" des widgets. On aura donc :

 ui->myPushButton->setStyleSheet("background-color: red;");

La liste des couleurs prédéfinies se trouve sur le site de documentation de QT.

Pour choisir dans l'espace RGB la couleur désirée, on peut faire de la façon suivante :

 QString style = "background-color: rgb(%1, %2, %3);";
 ui->myPushButton->setStyleSheet(style.arg(valRouge).arg(valeurVerte).arg(valeurBleu));

Utilisation

Question.jpg Modifier votre slot monAction pour changer la couleur d'un des 2 boutons.

4 boutons

On place sur l'interface graphique 4 boutons :

  • 1 pour quitter l'application
  • 1 qui ne servira à rien mais dont la couleur pourra changer : on l’appellera bpLampe
  • 1 bouton qui mettra en rouge le bouton bpLampe
  • 1 bouton qui mettra en noir le bouton bpLampe

Question.jpg Il faudra nécessairement ajouter un second slot, faire les modifications

bouton toggle

On souhaite ajouter un bouton supplémentaire qui devra faire basculer la couleur de rouge à noir.

Il faudra pour cela ajouter un attribut dans la classe MainWindow qui permettra de "mémoriser" l'état de la lampe.

Vous pouvez par exemple ajouter un attribut de type booléen avec une valeur initiale :

bool allumee=false;

Question.jpg Ajouter la gestion de ce bouton supplémentaire

Projet QtCreator pour raspberryPi

  • Nouveau Projet
  • application Qt avec Widgets
  • select kits
    • Rpi
    • cliquer sur manage
    • appareil mobiles
    • choisir périphérique rpi
    • modifier nom d'hôte : ras-pi-xx (ou utiliser la correspondance carte n°1 => 10.98.9.20)
    • xx est le numéro de la carte : par ex 05
    • valider
  • ajouter dans le fichier .pro les lignes suivantes après la ligne target= :
target.path = /root
INSTALLS = target

Consulter cette page pour des explications plus détaillées

Todo.jpg Lancer l'application pour vérifier la configuration


Pb sur la carte rpi

Si le message suivant apparaît :

QFontDatabase: Cannot find font directory /usr/local/qt5pi/lib/fonts
  • se connecter sur la pi : ssh root@10.98.35.xxx
  • lancer la commande : ln -snf /usr/share/fonts/truetype/dejavu /usr/local/qt5pi/lib/fonts