1°/ Description de l'application

Dans ce TP vous allez utiliser les composants graphiques vues au 4° cours pour faire une application avec une interface graphique qui affiche les images contenues dans un répertoire donné. La fenêtre comprendra deux onglets créés par une TabPane.

Le premier onglet est divisé en 2 parties avec une SplitPane. La première partie comprend une ListView contenant les noms des images contenues dans le répertoire et la 2ème partie affiche l'image sélectionnée dans la ListView.

Le deuxième onglet contient un conteneur pour afficher une image et les boutons : "first", "previous", "play", "next" et "last" pour afficher d'autres images contenues dans le répertoire. Enfin, le deuxième onglet contient une ProgressBar pour afficher la progression du diaporama.

2°/Implémentation

L'application doit être conforme au paradigme MVC. Donc, elle se composera de :

  1. une classe Model qui contiendra les données : tableau de chaines de caractères contenant les noms des images, indice de l'image affichée pour chaque onglet, nombre des images, état de l'application, ... et les getters pour tous les attributs
  2. une classe View qui sera la vue contenant les 2 onglets pour afficher les images comme décrit ci-dessus
  3. une classe ControlList pour détecter les évènements de sélection des éléments de la ListView et afficher l'image correspondante à la sélection
  4. une classe ControlButton pour gérer les boutons "first" (afficher la première image), "previous" (afficher l'image précédente), "play" (afficher toutes les 2 secondes une image selon leur ordre dans le répertoire), "next" (afficher l'image suivante) et "last" (afficher la dernière image). La ProgressBar doit être mise à jour avec tout changement d'images

3°/Remarques

File folder=new File(imagesPath);

int cpt=0;

for (final File fileEntry : folder.listFiles()) {
    imageNames[cpt]=fileEntry.getName();
    cpt++;
}
ImageView imageView1=new ImageView("file:path_to_image/image_name");
imageView1.setFitWidth(300);
imageView1.setFitHeight(300);

https://cours-info.iut-bm.univ-fcomte.fr/upload/supports/S4/Swing/tp2/Capture_décran_2022-04-30_à_12.19.56.png

Figure 1 : Premier onglet divisé en deux parties avec la SplitPane. La première partie contient une ListView affichant les noms des images et la deuxième partie affiche l'image sélectionnée dans la ListView.

https://cours-info.iut-bm.univ-fcomte.fr/upload/supports/S4/Swing/tp2/Capture_décran_2022-04-30_à_12.24.19.png