ntro.ca

        • Contrats de classe
        • Liens utiles
        • Calendrier
        • Calendrier groupe 2
        • Calendrier groupes 1, 3
        • Structure du cours
        • Évaluations
        • Matériel à se procurer
        • Les profs
          • Marc-Olivier Tremblay
          • Mathieu Bergeron
        • Module 1.1: installation + trier des cartes
        • Module 1.2: rappels POO
        • Module 1.3: tableau d'objets
        • Examen 1
        • Module 2.1: données JSON
        • Module 2.2: données en Java
        • Module 2.3: récursivité
        • Examen 2
        • Module 3.1: structure générique
        • Module 3.2: efficacité (1)
        • Module 3.3: efficacité (2)
        • Examen 3
        • Module 4.1: liste naïve
        • Module 4.2: liste par tableau
        • Module 4.3: liste chaînée
        • Examen 4
        • Module 5.1: mappage naïf
        • Module 5.2: mappage par hachage
        • Module 5.3: mappage par arbre
        • Examen 5
        • Équipes
          • Horaire groupe 1
          • Horaire groupe 2
          • Horaire groupe 3
          • Groupe 1
          • Groupe 2
          • Groupe 3
        • Projets vedettes 2022
        • Projets vedettes 2023
        • Projets vedettes 2024
        • Survol
        • Structure
        • Calendrier
        • Calendrier des séances
        • Évaluations
        • Exemples de jeu
        • Exemples de pages
        • Réponses à vos questions
        • Module 1: créer le projet
        • Module 2: concevoir l'application
        • Module 3: vues NtroFx
        • Module 4: modèle et navigation
        • Module 5: ajouter le dorsal, modifier le modèle
        • Module 7: améliorer l'affichage
        • Module 8: jeu en 2d
        • Module 9: client/serveur
        • Module 10: plusieurs instances du même modèle
        • TP1
        • Examen 1
        • TP2
        • Examen 2
        • Projet de fin de session
      • Ajout Format JSON
        • Calendrier
        • Évaluations
        • Structure du cours
        • Contrat de classe
        • Le prof
        • 01: Windows et Word
          • Astuces et raccourcis
        • 02: Word
        • 03: Word
          • Exercice Word: insertion d'éléments spéciaux
          • Exercice Word: tableaux
        • 04: Word
          • Exercice Word: références
          • TP01: Word (15%)
        • 05: PowerPoint
          • TP02: PowerPoint (10%)
        • 06: Examen Word (20%)
        • 07: Excel
        • 08: Excel
        • 09: Excel
          • TP03: Excel (15%)
        • 10: Excel
        • 11: Examen Excel (20%)
        • 12: Access
        • 13: Access
        • 14: Access
        • 15: Examen Access
      • Sondage H2023 (dept. info)
      • Vision H2023 (dept. info)
      • P1) exercices interactifs de lecture
      • P2) transition Excel vers Python
        • Atelier 2: un exemple
      • Index
      • Point de vue sur l'IA
    Frontal
    • Tutoriel 4: observer le modèle dans le frontal
      • Vérifier le fichier .json
      • Ajouter des données au fichier .json

    Tutoriel 4: observer le modèle dans le frontal #

    1. Dans frontal.taches ajouter la classe AfficherFileAttente

    2. En VSCode, s’assurer d’avoir l’arborescence suivante

    3. Ouvrir AfficherFileAttente et ajouter le import static suivant:

      • import static ca.ntro.app.tasks.frontend.FrontendTasks.*;
    4. Dans AfficherFileAttente, ajouter un groupe de tâches

      import static ca.ntro.app.tasks.frontend.FrontendTasks.*;
      
          public class AfficherFileAttente {
      
              public static void creerTaches(FrontendTasks tasks) {
      
                  tasks.taskGroup("AfficherFileAttente")
      
                       .waitsFor("afficherVueFileAttente")
      
                       .contains(subTasks -> {
      
      
                           // Prêt à observer le modèle
      
      
                       });
              }
      
      • NOTE:
        • le groupe de tâche au complet attend que la VueFileAttente soit créée, ce qui se fait dans le groupe de tâches Initialisation
        • dans le cas de VuePartie, la vue est plutôt créée dans le groupe de tâche Navigation
    5. Ajouter la tâche afficherFileAttente

      import static ca.ntro.app.tasks.frontend.FrontendTasks.*;
      
          public class AfficherFileAttente {
      
              public static void creerTaches(FrontendTasks tasks) {
      
                  tasks.taskGroup("AfficherFileAttente")
      
                       .waitsFor("afficherVueFileAttente")
      
                       .contains(subTasks -> {
      
                           // ajouter l'appel
                           afficherFileAttente(subTasks);
      
                       });
              }
      
              private static void afficherFileAttente(FrontendTasks subTasks) {
      
                  subTasks.task("afficherFileAttente")
      
      
                          .waitsFor(created(VueFileAttente.class))
      
                          .waitsFor(modified(ModeleFileAttente.class))
      
                          .executes(inputs -> {
      
                               VueFileAttente              vueFileAttente = inputs.get(created(VueFileAttente.class));
                               Modified<ModeleFileAttente> fileAttente    = inputs.get(modified(ModeleFileAttente.class));
      
                               ModeleFileAttente ancienneFile = fileAttente.previousValue();
                               ModeleFileAttente fileCourante = fileAttente.currentValue();
      
                               // Prêt à afficher les rendez-vous!
                               //
                       });
              }
          }
      
      • NOTES:
        • la tâche récupère la vue
        • la tâche observe le modèle
        • cette tâche sera donc appelée à chaque fois que le modèle est modifié
    6. Dans FrontalPong, appeler AfficherFileAttente.creerTaches

      
          public class FrontalPong implements FrontendFx {
      
              // ...
      
              @Override
              public void createTasks(FrontendTasks tasks) {
      
                  // ...
      
                  AfficherFileAttente.creerTaches(tasks);
      
              }
      
    7. Exécuter pong et vérifier le mon graphe de tâches du frontal

       $ sh gradlew pong
      

    Vérifier le fichier .json #

    1. Le fichier .json du modèle est dans _storage/models/ModeleFileAttente.json

    2. Vérifier le contenu de ModeleFileAttente.json

      {
            "_C": "ModeleFileAttente",
            "prochainIdRendezVous": 1,
            "rendezVousDansOrdre": []
          }
      

    Ajouter des données au fichier .json #

    1. Ouvrir le fichier ModeleFileAttente.json

    2. Ajouter à la main des rendez-vous

      {
            "_C": "ModeleFileAttente",
            "prochainIdRendezVous": 3,
            "rendezVousDansOrdre": [
              {
                "_C": "RendezVous",
                "idRendezVous": "1",
                "premierJoueur": {
                  "_C": "Joueur",
                  "id": "ZQ6B",
                  "nom": "Lagrois",
                  "prenom": "Dominic"
                }
              },
              {
                "_C": "RendezVousComplet",
                "idRendezVous": "2",
                "premierJoueur": {
                  "_C": "Joueur",
                  "id": "UWmq",
                  "nom": "Abdenouri",
                  "prenom": "Mehdi"
                },
                "deuxiemeJoueur": {
                  "_C": "Joueur",
                  "id": "NrPs",
                  "nom": "Gonzales",
                  "prenom": "Chaaya"
                }
              }
            ]
          }
      
      • RAPPEL: par héritage, une RendezVousComplet a aussi les attributs d’un RendezVous
    3. Ré-exécuter pong

       $ sh gradlew pong
      
    4. Fermer la fenêtre afin de générer ModeleFileAttente.png

    5. Observer que le modèle pour la file d’attente contient maitenant trois objets:

    Creative Commons License Creative Commons Attribution Creative Commons ShareAlike
    • Tutoriel 4: observer le modèle dans le frontal
      • Vérifier le fichier .json
      • Ajouter des données au fichier .json