begin process at 2008 08 20 14:06:39
1 228 858 membres
224 nouveaux aujourd'hui
14 257 membres club

Vous ne trouvez pas de réponse à votre problème ? Alors posez la question dans le forum.
Souvenez-vous qu'il n'y a jamais de question bête, mais rester dans l'ignorance parce que l'on n'ose pas poser une question, ça c'est une erreur !

VERTICALLAYOUT, ENFIN UN LAYOUT POUR PLACER DES ÉLÉMENTS EN VERTICAL


Information sur la source

Catégorie :Swing Classé sous : layoutmanager, verticallayout, container, insets Niveau : Débutant Date de création : 18/01/2003 Date de mise à jour : 18/01/2003 15:54:26 Vu : 4 710

Note :
9,17 / 10 - par 6 personnes
9,17 / 10

  • 1

  • 2

  • 3

  • 4

  • 5

  • 6

  • 7

  • 8

  • 9

  • 10

Commentaire sur cette source (2)
Ajouter un commentaire et/ou une note

Description

Ce layout permet de placer  des composants les uns sous les autres (Un FlowLayout en vertical en somme)
Le code vous montre également comment on crée un layout.
Un exemple d'utilisation :
JPanel panneau=new JPanel(new VerticalLayout());
panneau.add(bouton1);
panneau.add(composant2);
....

Je trouvais que celà manquait.
JHelp

Source

  • import java.awt.LayoutManager;
  • import java.awt.Component;
  • import java.awt.Dimension;
  • import java.awt.Container;
  • import java.awt.Insets;
  • /**
  • * @author Gérard Bourriaud dit JHelp
  • * @version 1.0
  • */
  • /**
  • * Layout pour placer les élémnts en vertical
  • */
  • public class VerticalLayout implements LayoutManager
  • {
  • //Nombre de pixels de vide entre le composant et le bord du conteneur en horizontal
  • private int espaceHorizontal=1;
  • //Nombre de pixels de vide entre le composant et le bord du conteneur en vertical
  • private int espaceVertical=1;
  • /**
  • * Layout vertical par défaut
  • */
  • public VerticalLayout()
  • {
  • }
  • /**
  • * LayoutVertical en présisant les écart avec le bord
  • */
  • public VerticalLayout(int espaceHorizontal,int espaceVertical)
  • {
  • this.espaceHorizontal=espaceHorizontal;
  • this.espaceVertical=espaceVertical;
  • }
  • /**
  • * Ajoute un composant avec une contrainte particuliére, inutile ici, mias laissé pour implémenté l'interface LayoutManager
  • */
  • public void addLayoutComponent(String name, Component comp)
  • {
  • }
  • /**
  • * Retire un composant du rendu, inutile ici, mias laissé pour implémenté l'interface LayoutManager
  • */
  • public void removeLayoutComponent(Component comp)
  • {
  • }
  • /**
  • * Calcul la dimension préférée du conteneur en paramètre
  • */
  • public Dimension preferredLayoutSize(Container parent)
  • {
  • //On récupère le nombre de composant contenus
  • int nb=parent.getComponentCount();
  • //On initialise la réponse
  • Dimension reponse=new Dimension(0,0);
  • //Pour chaque composant dans le conteneur
  • for(int i=0;i<nb;i++)
  • {
  • //Si le composant actuel est affiché
  • if(parent.getComponent(i).isVisible())
  • {
  • //On récupère les dimensions préférées du composant actuel
  • Dimension actuel=parent.getComponent(i).getPreferredSize();
  • //La largeur totale est le maximum des largeurs
  • if(reponse.width<actuel.width)
  • reponse.width=actuel.width;
  • //On ajoute la hauteur du composant actuel
  • reponse.height += actuel.height;
  • }
  • }
  • //On tiens en compte des divers décalages
  • Insets insets=parent.getInsets();
  • reponse.width += insets.right+insets.left+espaceHorizontal*2;
  • reponse.height += insets.top+insets.bottom+espaceVertical*2;
  • //On renvoie la réponse
  • return reponse;
  • }
  • /**
  • * Calcul la dimension minimale du conteneur en paramètre
  • */
  • public Dimension minimumLayoutSize(Container parent)
  • {
  • //On récupère le nombre de composant contenus
  • int nb=parent.getComponentCount();
  • //On initialise la réponse
  • Dimension reponse=new Dimension(0,0);
  • //Pour chaque composant dans le conteneur
  • for(int i=0;i<nb;i++)
  • {
  • //Si le composant actuel est affiché
  • if(parent.getComponent(i).isVisible())
  • {
  • //On récupère les dimensions minimales du composant actuel
  • Dimension actuel=parent.getComponent(i).getMinimumSize();
  • //La largeur totale est le maximum des largeurs
  • if(reponse.width<actuel.width)
  • reponse.width=actuel.width;
  • //On ajoute la hauteur du composant actuel
  • reponse.height += actuel.height+espaceVertical;
  • }
  • }
  • //On tiens en compte des divers décalages
  • Insets insets=parent.getInsets();
  • reponse.width += insets.right+insets.left+espaceHorizontal*2;
  • reponse.height += insets.top+insets.bottom+espaceVertical*2;
  • //On renvoie la réponse
  • return reponse;
  • }
  • /**
  • * Place les composants dans le conteneur
  • */
  • public void layoutContainer(Container parent)
  • {
  • //On se synchronize sur le conteneur pour éviter des défauts d'affichage
  • synchronized(parent.getTreeLock())
  • {
  • //On récupère le décalage du conteneur
  • Insets insets=parent.getInsets();
  • //On récupère le nombre de composants contenus dans le conteneur
  • int nb=parent.getComponentCount();
  • //On initialise les coordonées de placement
  • int x=espaceVertical+insets.left;
  • int y=espaceHorizontal+insets.top;
  • //Pour chaque composant du conteneur
  • for(int i=0;i<nb;i++)
  • {
  • //Si le composant actuel est visible
  • if(parent.getComponent(i).isVisible())
  • {
  • //On récupére la taille préferée du composant
  • Dimension d=parent.getComponent(i).getPreferredSize();
  • //On donne au composant sa taille préférée
  • parent.getComponent(i).setSize(d);
  • //On place le composant
  • parent.getComponent(i).setLocation(x,y);
  • //On décale les ordonées pour le prochain composant
  • y += d.height+espaceVertical;
  • }
  • }
  • }
  • }
  • }
import java.awt.LayoutManager;
import java.awt.Component;
import java.awt.Dimension;
import java.awt.Container;
import java.awt.Insets;

/**
 * @author Gérard Bourriaud dit JHelp
 * @version 1.0
 */

/**
 * Layout pour placer les élémnts en vertical
 */
public class VerticalLayout implements LayoutManager
{
  //Nombre de pixels de vide entre le composant et le bord du conteneur en horizontal
  private int espaceHorizontal=1;
  //Nombre de pixels de vide entre le composant et le bord du conteneur en vertical
  private int espaceVertical=1;

  /**
   * Layout vertical par défaut
   */
  public VerticalLayout()
  {
  }

  /**
   * LayoutVertical en présisant les écart avec le bord
   */
  public VerticalLayout(int espaceHorizontal,int espaceVertical)
  {
    this.espaceHorizontal=espaceHorizontal;
    this.espaceVertical=espaceVertical;
  }

  /**
   * Ajoute un composant avec une contrainte particuliére, inutile ici, mias laissé pour implémenté l'interface LayoutManager
   */
  public void addLayoutComponent(String name, Component comp)
  {
  }

  /**
   * Retire un composant du rendu, inutile ici, mias laissé pour implémenté l'interface LayoutManager
   */
  public void removeLayoutComponent(Component comp)
  {
  }

  /**
   * Calcul la dimension préférée du conteneur en paramètre
   */
  public Dimension preferredLayoutSize(Container parent)
  {
    //On récupère le nombre de composant contenus
    int nb=parent.getComponentCount();
    //On initialise la réponse
    Dimension reponse=new Dimension(0,0);
    //Pour chaque composant dans le conteneur
    for(int i=0;i<nb;i++)
    {
      //Si le composant actuel est affiché
      if(parent.getComponent(i).isVisible())
      {
        //On récupère les dimensions préférées du composant actuel
        Dimension actuel=parent.getComponent(i).getPreferredSize();
        //La largeur totale est le maximum des largeurs
        if(reponse.width<actuel.width)
          reponse.width=actuel.width;
        //On ajoute la hauteur du composant actuel
        reponse.height += actuel.height;
      }
    }
    //On tiens en compte des divers décalages
    Insets insets=parent.getInsets();
    reponse.width += insets.right+insets.left+espaceHorizontal*2;
    reponse.height += insets.top+insets.bottom+espaceVertical*2;
    //On renvoie la réponse
    return reponse;
  }

  /**
   * Calcul la dimension minimale du conteneur en paramètre
   */
  public Dimension minimumLayoutSize(Container parent)
  {
    //On récupère le nombre de composant contenus
    int nb=parent.getComponentCount();
    //On initialise la réponse
    Dimension reponse=new Dimension(0,0);
    //Pour chaque composant dans le conteneur
    for(int i=0;i<nb;i++)
    {
      //Si le composant actuel est affiché
      if(parent.getComponent(i).isVisible())
      {
      //On récupère les dimensions minimales du composant actuel
        Dimension actuel=parent.getComponent(i).getMinimumSize();
        //La largeur totale est le maximum des largeurs
        if(reponse.width<actuel.width)
          reponse.width=actuel.width;
        //On ajoute la hauteur du composant actuel
        reponse.height += actuel.height+espaceVertical;
      }
    }
    //On tiens en compte des divers décalages
    Insets insets=parent.getInsets();
    reponse.width += insets.right+insets.left+espaceHorizontal*2;
    reponse.height += insets.top+insets.bottom+espaceVertical*2;
    //On renvoie la réponse
    return reponse;
  }

  /**
   * Place les composants dans le conteneur
   */
  public void layoutContainer(Container parent)
  {
    //On se synchronize sur le conteneur pour éviter des défauts d'affichage
    synchronized(parent.getTreeLock())
    {
      //On récupère le décalage du conteneur
      Insets insets=parent.getInsets();
      //On récupère le nombre de composants contenus dans le conteneur
      int nb=parent.getComponentCount();
      //On initialise les coordonées de placement
      int x=espaceVertical+insets.left;
      int y=espaceHorizontal+insets.top;
      //Pour chaque composant du conteneur
      for(int i=0;i<nb;i++)
      {
        //Si le composant actuel est visible
        if(parent.getComponent(i).isVisible())
        {
          //On récupére la taille préferée du composant
          Dimension d=parent.getComponent(i).getPreferredSize();
          //On donne au composant sa taille préférée
          parent.getComponent(i).setSize(d);
          //On place le composant
          parent.getComponent(i).setLocation(x,y);
          //On décale les ordonées pour le prochain composant
          y += d.height+espaceVertical;
        }
      }
    }
  }
}

Conclusion

Si vous désirez un composant que vous ne trouvé pas dans l'API swing, je peux le faire et le publier ici.

JHelp
  • signaler à un administrateur
    Commentaire de benohite le 29/04/2003 11:12:21

    alors la je dis chapeau
    tu m enleve une epine du pied car j etais en train de me resigner a le faire pour mon projet et je tombe sur le tiens (ouf! :-) )
    un grand merci a toi car je pense qu il va me servir plus d une fois

  • signaler à un administrateur
    Commentaire de Icarius44 le 09/05/2008 12:39:22 8/10

    Pareil que benohite : "tu m'enlève une épine du pied"

    Deux petit truc par contre :
    Tout d'abord j'ai ajouter vite fait une ligne pour pouvoir centrer :
    if (this.alignement == VerticalLayout.LEFT) {
    parent.getComponent(i).setLocation(x, y);
    } else {
    parent.getComponent(i).setLocation(((int) (dP.getWidth() - 2*x - d.getWidth()) / 2), y);
    }

    Deuxième petit truc : j'ai utilisé la source dans un JPanel  lui même dans un JScrollPane et le défilement me fait des trainés de couleur, comme si le repaint ou autre ne se faisait pas.

Ajouter un commentaire

Pub



Appels d'offres

CalendriCode

Août 2008
LMMJVSD
    123
45678910
11121314151617
18192021222324
25262728293031

VS Express FR Gratuit !

VS Express en français et 100% gratuit !

Boutique

Boutique de goodies CodeS-SourceS