IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

SWT/JFace Java Discussion :

colonne "span" dans un tree/treeviewer


Sujet :

SWT/JFace Java

  1. #1
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut colonne "span" dans un tree/treeviewer
    Bonjour,

    je voudrais avoir un item dans un CheckboxTreeViewer qui s'affiche sur toute la largeur, pour simuler une table avec groupement.

    Ca marche bien (pour l'instant j'ai testé que sur Windows) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    Listener paintListener = new Listener() {
    
      public void handleEvent(Event event) {
        TreeItem item = ((TreeItem)event.item);
        Object element = item.getData(); 
        if ( element instanceof BundleHandler ) {
          //event.doit=false;
          switch(event.type) {		 
            case SWT.PaintItem: { 
              String text = ((BundleHandler)element).getLabel();
              if ( text!=null ) {
                Point size = event.gc.stringExtent(text);
                int yOffset = Math.max(0, (event.height - size.y) / 2); 
                event.gc.drawString(text, item.getBounds(0).x + item.getBounds(event.index).x-event.x+2 , event.y + yOffset, true);
              }
              break;
            }
          }
        }
      }
    
    }; 
    treeViewer.getTree().addListener(SWT.PaintItem, paintListener);
    Par contre le +2 que j'ai dû mettre "en dur" me gène : je suppose qu'il s'agit de trims , genre marge, mais je n'arrive pas à trouver un moyen d'en calculer une valeur générique qui s'adapte donc à l'environnement. Je ne vois pas d'où viennent ces 2 pixels de décalage.

    Quelqu'un a une idée de ce à quoi cet offset correspond ?
    Ou voit-il à un moyen de le déterminer de manière à ce que cela fonctionne sur tous les os et avec toutes les tailles de polices ?

  2. #2
    Modérateur
    Avatar de joel.drigo
    Homme Profil pro
    Ingénieur R&D - Développeur Java
    Inscrit en
    Septembre 2009
    Messages
    12 430
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 55
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur R&D - Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2009
    Messages : 12 430
    Points : 29 131
    Points
    29 131
    Billets dans le blog
    2
    Par défaut
    J'ai trouvé la solution à priori (reste à tester sur Macintosh) :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    Listener paintListener = new Listener() {
     
      public void handleEvent(Event event) {
        TreeItem item = ((TreeItem)event.item);
        Object element = item.getData(); 
        if ( element instanceof BundleHandler && event.index>0 ) {
          //event.doit=false;
          switch(event.type) {		 
            case SWT.PaintItem: {  
              String text = item.getText(0);
              if ( text!=null ) {
                Point size = event.gc.stringExtent(text);
                int yOffset = Math.max(0, (event.height - size.y) / 2); 
                event.gc.drawString(text, item.getBounds(event.index).x +  item.getTextBounds(0).x - event.x , event.y + yOffset, true);
              }
              break;
            }
          }
        }
      }
     
    };
    Ca m'a permis en plus de rétablir le fonctionnement standard avec un texte produit par le LabelProvider, ce qui est encore mieux. C'était évident finalement après coup, bien sûr.

+ Répondre à la discussion
Cette discussion est résolue.

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo