FAQ Java GUIConsultez toutes les FAQ

Nombre d'auteurs : 51, nombre de questions : 152, dernière mise à jour : 29 juin 2013 

 
OuvrirSommaireAWT et SwingJFileChooser

Ces boîtes de dialogue ne suivent pas la locale de votre système. En fait chaque texte affiché dans ces boîtes de dialogue correspond à une ressource du UIManager. Il va donc falloir changer ces ressources.

Par exemple pour le JFileChooser vous pouvez dans votre code faire :

 
Sélectionnez
UIManager.put("FileChooser.saveButtonText","Enregistrer");
UIManager.put("FileChooser.openButtonText","Ouvrir");
UIManager.put("FileChooser.cancelButtonText","Annuler");
UIManager.put("FileChooser.updateButtonText","Actualiser");
UIManager.put("FileChooser.helpButtonText","Aide");
UIManager.put("FileChooser.saveButtonToolTipText","Enregistre le fichier");
Créé le 24 mars 2002  par L'équipe Java

La classe FileSystemView, du package javax.swing.filechooser, permet de récupérer notamment le home directory et le répertoire par défaut. Sous windows, ces deux répertoires correspondent au bureau et à "Mes documents". Vous pouvez donc facilement positionner le JFileChooser. Par exemple :

 
Sélectionnez

FileSystemView vueSysteme = FileSystemView.getFileSystemView(); 
//récupération des répertoires
File defaut = vueSysteme.getDefaultDirectory(); 
File home = vueSysteme.getHomeDirectory(); 
//création et affichage des JFileChooser
JFileChooser defautChooser = new JFileChooser(defaut);
defautChooser.showOpenDialog(null);
JFileChooser homeChooser = new JFileChooser(home);
homeChooser.showOpenDialog(null);

Par contre, il n'existe pas de méthode toute faite pour se positionner de manière à voir tous les disques. Vous devrez faire comme ceci :

 
Sélectionnez

 
JFileChooser chooser = new JFileChooser();
chooser.setCurrentDirectory(new File("/"));
chooser.changeToParentDirectory();
chooser.showOpenDialog(null);
Créé le 12 août 2004  par bulbo

Pour filtrer les fichiers affichés par un JFileChooser vous devez utiliser un FileFilter (package javax.swing.filechooser). Cette classe abstraite définit deux méthodes :

  • accept(File) : Cette méthode retourne un booléen indiquant si le fichier passé en paramètre est acceptable.
  • getDescription() : Cette méthode retourne un String décrivant le filtre. C'est cette description qui sera affichée dans le JFileChooser.

Voici un exemple simple d'implémentation.

 
Sélectionnez

public class FiltreSimple extends FileFilter{
   //Description et extension acceptée par le filtre
   private String description;
   private String extension;
   //Constructeur à partir de la description et de l'extension acceptée
   public FiltreSimple(String description, String extension){
      if(description == null || extension ==null){
         throw new NullPointerException("La description (ou extension) ne peut être null.");
      }
      this.description = description;
      this.extension = extension;
   }
   //Implémentation de FileFilter
   public boolean accept(File file){
      if(file.isDirectory()) { 
         return true; 
      } 
      String nomFichier = file.getName().toLowerCase(); 
 
      return nomFichier.endsWith(extension);
   }
      public String getDescription(){
      return description;
   }
}

L'utilisation se fait comme ceci :

 
Sélectionnez

FileFilter java = new FiltreSimple("Fichiers Java",".java");
FileFilter classes = new FiltreSimple("Fichiers Class",".class");
FileFilter jar = new FiltreSimple("Fichiers JAR",".jar");
 
JFileChooser chooser = new JFileChooser(".");
chooser.addChoosableFileFilter(java);
chooser.addChoosableFileFilter(classes);
chooser.addChoosableFileFilter(jar);
chooser.showOpenDialog(null);

Vous pouvez télécharger cet exemple ci-dessous.

Ce filtre simple ne prend en compte qu'une seule extension. Vous pouvez regarder les liens ci-dessous pour un exemple de filtre "extensible" (capable de prendre en compte plusieurs extensions de fichiers).

Une dernière remarque : le filtrage ne se fait pas nécessairement sur une extension de fichier. Pour l'exemple on a choisi cette possibilité car c'est ce qui est le plus couramment rencontré. Vous pouvez tout à fait faire des filtres sur les tailles des fichiers, leurs dates de dernière modification, etc.

Mis à jour le 3 avril 2005  par Ioan Calapodescu

Téléchargement : FiltreSimple.java

Voici un exemple d'implémentation de FileFilter (package javax.swing.filechooser) qui prend en compte plusieurs extensions. Quelques méthodes supplémentaires sont définies pour des facilités d'utilisation.

 
Sélectionnez
public class FiltreExtensible extends FileFilter{
   //Description et extensions acceptées par le filtre
   private String description;
   private List<String> extensions;
   //Constructeur à partir de la description
   public FiltreExtensible(String description){
      if(description == null){
         throw new NullPointerException("La description ne peut être null.");
      }
      this.description = description;
      this.extensions = new ArrayList<String>();
   }
   //Implémentation de FileFilter
   public boolean accept(File file){
      if(file.isDirectory() || extensions.size()==0) { 
         return true; 
      } 
      String nomFichier = file.getName().toLowerCase(); 
      for(String extension : extensions){
         if(nomFichier.endsWith(extension)){
            return true;
         }
      }
      return false;
   }
   public String getDescription(){
      StringBuffer buffer = new StringBuffer(description);
      buffer.append(" (");
      for(String extension : extensions){
         buffer.append(extension).append(" ");
      }
      return buffer.append(")").toString();
   }
   //Quelques méthodes utilitaires
   public void setDescription(String description){
      if(description == null){
         throw new NullPointerException("La description ne peut être null.");
      }
      this.description = description;
   }
   public void addExtension(String extension){
      if(extension == null){
         throw new NullPointerException("Une extension ne peut être null.");
      }
      extensions.add(extension);
   }
   public void removeExtension(String extension){
      extensions.remove(extension);
   }
   public void clearExtensions(){
      extensions.clear();
   }
   public List<String> getExtensions(){
      return extensions;
   }
}

Ce filtre peut s'utiliser comme ceci :

 
Sélectionnez

FiltreExtensible filtre = new FiltreExtensible("Fichiers Java");
filtre.addExtension(".java");
 
JFileChooser chooser = new JFileChooser(".");
chooser.addChoosableFileFilter(filtre);
chooser.showOpenDialog(null);
 
filtre.addExtension(".class");
chooser.showOpenDialog(null);
 
filtre.setDescription("Fichiers class");
filtre.removeExtension(".java");
chooser.showOpenDialog(null);
 
filtre.setDescription("Tous les fichiers");
filtre.clearExtensions();
chooser.showOpenDialog(null);

Vous pouvez télécharger cet exemple ci-dessous.


A noter que depuis Java 6.0, vous pouvez faire ceci de manière standard en utilisant la classe FileNameExtensionFilter, qui permet de faire un filtre avec plusieurs extensions. Elle se crée de la manière suivante :

 
Sélectionnez

FileFilter imagesFilter = new FileNameExtensionFilter("Images", "bmp", "gif", "jpg", "jpeg", "png", ...);


Ensuite, vous pouvez l'utiliser comme n'importe quel FileFilter.

Mis à jour le 26 mai 2005  par Ioan Calapodescu, Pill_S

Téléchargement : FiltreExtensible.java

La classe JFileChooser permet au développeur de définir, avec la méthode setAccessory(Component) un composant accessoire. Ce composant peut se mettre à l'écoute des événements relatifs au JFileChooser grâce à un PropertyChangeListener.

Vous pouvez donc utiliser cet accessoire pour par exemple prévisualiser des images ou simplement pour avoir des informations détaillées sur le fichier sélectionné. Voici un exemple de rendu (vous pouvez télécharger l'implémentation ci-dessous) :

Image non disponible
Créé le 1er février 2005  par Ioan Calapodescu

Téléchargement : FilePreview.java

Les codes sources présentés sur cette page sont libres de droits et vous pouvez les utiliser à votre convenance. Pour le reste, ce document constitue une oeuvre intellectuelle protégée par les droits d'auteurs. Ce document issu de http://www.developpez.com est soumis à deux licences, en fonction des contributeurs : - Les contributions de Clément Cunin et Johann Heymes sont soumises aux termes de la la licence GNU FDL traduite en français ici. Permission vous est donnée de distribuer, modifier des copies des contributions de Clément Cunin et Johann Heymes tant que cette note apparaît clairement : "Ce document issu de http://www.developpez.com est soumis à la licence GNU FDL traduite en français ici. Permission vous est donnée de distribuer, modifier des copies de cette page tant que cette note apparaît clairement". - Pour ce qui est des autres contributions : Copyright © 2004 - 2009 Developpez LLC : Tous droits réservés Developpez LLC. Aucune reproduction ne peut en être faite sans l'autorisation expresse de Developpez LLC. Sinon vous encourez selon la loi jusqu'à 3 ans de prison et jusqu'à 300 000 E de dommages et intérêts. Cette page est déposée à la SACD.