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 : 5 199

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
 

Commentaires et avis

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

Discussions en rapport avec ce code source dans le forum

Probleme d'affichage d'une applet [ par juanpipo ] Voila le message d'erreur qui s'affiche:java.awt.AWTError: BoxLayout can't be shared at javax.swing.BoxLayout.checkContainer(BoxLayout.java:342) at ja pb de changement de panel [ par Serik ] Voilà j'ai une "pile" de Panel, et dans un je veux aller dans l'autre...etc mais un bug se produit : il faut faire un resize de la fenêtre pour que ça JBuilder getCOntentPane() [ par fredspv ] Jbuilder ne comprend pas getContentPane() lorsque je fais:container container.... getContentPane()Pourquoi? problème de transmission de variable entre classe [ par kelu28 ] voila je suis en train de développer un petit logiciel qui gère des cartes d'acquisution. mon truc marchais sans interface graphique et j'ai voullu ra [Swing] redimensionnement [ par ApoKlypse ] 'lu !Je suis en train de construire un formulaire et j'ai un petit souci: voilà j'ai un GridBagLayout dans lequel est disposé pour la plupart des JTex problème avec JPanel et LayoutManager AU SECOURS [ par seb78 ] Bonjour,J'ai un JPanel properties dans lequel j'insère deux JPanel property l'un en dessous de l'autre._________| ______ || | | || |__1 _| || Container Component [ par anzize ] Bonjour tout le monde !J'ai un le probl&#232;me suivant :JPanel panel=new JPanel();JButton buton1=new JButton("1");JButton buton2=new JButton("2");pan swing [ par saispasq ] je veu s&#233;rialiser et swinger ce code , mais j'ai des problem avec le: JComponent m = target.getComponent(i);&nbsp;&nbsp; // erreur: incompatble t getContentPane() et Container [ par toonytoun ] Bonjour tous le monde, j'ai une petite question qui me serra d'une grande utilit&#233;: je dois cr&#233;er des applets pour int&#233;grer dans un site affichage d'un container dans un autre en fct du menu [ par bmikl59 ] Bonjour,j'ai des probleme avec les layout de mes container...je m'expliqueJ'ai crée une classe qui dessine une fentre principale :public</f


Nos sponsors

Sondage...

CalendriCode

Décembre 2008
LMMJVSD
1234567
891011121314
15161718192021
22232425262728
293031    

Consulter la suite du CalendriCode



Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel BAÏSE, Merci à Vincent pour ses précieux conseils
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés
Temps d'éxécution de la page : 0,343 sec

Google Coop CodeS-SourceS Google Coop CodeS-SourceS


Certaines images présentes sur le site (notament certains avatars) sont issues des collections IconShock, donc si vous souhaitez utiliser ces icons vous devez les acheter, ne les copiez pas et ne utilisez pas dans vos sites et applications sans les avoir commandé.