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

AWT/Swing Java Discussion :

Un arbre "interactif"


Sujet :

AWT/Swing Java

  1. #1
    Membre régulier Avatar de ForgetTheNorm
    Homme Profil pro
    Docteur en informatique
    Inscrit en
    Novembre 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Docteur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2006
    Messages : 133
    Points : 76
    Points
    76
    Par défaut Un arbre "interactif"
    Bonjour

    Je souhaiterai pouvoir afficher un arbre (via JTree) "interactivement", c'est à dire de ne pas le charger complètement à sa création (c'est impossible, il est infini), mais de charger branche par branche lorsque l'utilisateur le demande.

    J'ai donc trouvé différents listeners, par exemple TreeWillExpandListener, qui est appelé lorsqu'une branche se développe, et où je pourrais donc demander (juste avant son développement) l'ajout du sous-arbre juste à cet endroit.

    Mon problème est que par défaut, un élément de JTree qui ne possède pas de fils est considéré comme "une feuille", et donc non extensible, et donc ne pouvant pas appeler ce listener.

    Existe-t-il un moyen de "forcer" un élément à autoriser cette extension, même si au moment du clic il ne possède pas de fils ?

    Merci

    Pierre

  2. #2
    Membre émérite
    Avatar de gifffftane
    Profil pro
    Inscrit en
    Février 2007
    Messages
    2 354
    Détails du profil
    Informations personnelles :
    Localisation : France, Loire (Rhône Alpes)

    Informations forums :
    Inscription : Février 2007
    Messages : 2 354
    Points : 2 582
    Points
    2 582
    Par défaut
    Lorsque tu as un noeud, qui est visible, même s'il est replié, même si tu n'as pas encore chargé ses enfants, il faut au moins que tu détermines s'il en a ou pas, de façon à placer le isLeaf de ton modèle correctement.

    Après, tu chargeras les valeurs (nombre d'enfants, enfants eux mêmes) au fur et à mesure qu'elles te sont demandées (c'est à dire lorsque l'utilisateur dépliera ton noeud).
    Mieux que Google, utilisez Sur Java spécialisé sur la plate-forme java !
    Pour réaliser vos applications Java dans le cadre de prestations, forfait, conseil, contactez-moi en message privé.

  3. #3
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Par défaut
    En plus de isLeaf(), voir ausi dans javax.swing.tree.DefaultTreeModel :

    asksAllowsChildren
    protected boolean asksAllowsChildren
    Determines how the isLeaf method figures out if a node is a leaf node. If true, a node is a leaf node if it does not allow children. (If it allows children, it is not a leaf node, even if no children are present.) That lets you distinguish between folder nodes and file nodes in a file system, for example.
    If this value is false, then any node which has no children is a leaf node, and any node may acquire children.


    See Also:
    TreeNode.getAllowsChildren(), TreeModel.isLeaf(java.lang.Object), setAsksAllowsChildren(boolean)


    setAsksAllowsChildren
    public void setAsksAllowsChildren(boolean newValue)
    Sets whether or not to test leafness by asking getAllowsChildren() or isLeaf() to the TreeNodes. If newvalue is true, getAllowsChildren() is messaged, otherwise isLeaf() is messaged.

    asksAllowsChildren
    public boolean asksAllowsChildren()
    Tells how leaf nodes are determined.

    Returns:
    true if only nodes which do not allow children are leaf nodes, false if nodes which have no children (even if allowed) are leaf nodes
    See Also:
    asksAllowsChildren

    isLeaf
    public boolean isLeaf(Object node)
    Returns whether the specified node is a leaf node. The way the test is performed depends on the askAllowsChildren setting.

    Specified by:
    isLeaf in interface TreeModel
    Parameters:
    node - the node to check
    Returns:
    true if the node is a leaf node
    See Also:
    asksAllowsChildren, TreeModel.isLeaf(java.lang.Object)
    ainsi que dans javax.swing.tree.TreeNode :

    getAllowsChildren
    boolean getAllowsChildren()
    Returns true if the receiver allows children.
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  4. #4
    Membre régulier Avatar de ForgetTheNorm
    Homme Profil pro
    Docteur en informatique
    Inscrit en
    Novembre 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Docteur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2006
    Messages : 133
    Points : 76
    Points
    76
    Par défaut
    Merci pour vos réponses, mais je pense m'être mal exprimé.

    Ce que vous me présentez permet de savoir si un noeud est une feuille, ou d'allouer / désallouer la possibilité de placer des fils.

    Je cherche en fait à "simuler" des sous-arbres à chaque noeud, afin d'avoir l'expansion possible. Car si le noeud est une feuille, alors ce noeud ne possède pas la "manette" pour l'ouvrir et accéder aux sous-arbres.

    J'ai trouvé une solution pas très propre, en ajoutant un fils DefaultMutableNode à chaque noeud, que le supprime pour le remplacer par ses vrais fils lors de son "WillExpand".

  5. #5
    Rédacteur/Modérateur

    Avatar de bouye
    Homme Profil pro
    Information Technologies Specialist (Scientific Computing)
    Inscrit en
    Août 2005
    Messages
    6 840
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : Nouvelle-Calédonie

    Informations professionnelles :
    Activité : Information Technologies Specialist (Scientific Computing)
    Secteur : Agroalimentaire - Agriculture

    Informations forums :
    Inscription : Août 2005
    Messages : 6 840
    Points : 22 854
    Points
    22 854
    Billets dans le blog
    51
    Par défaut
    Hum, hum... si on configure le modele de maniere a ce que la methode isLeaf() de chaque TreeNode soit appellee, alors on peut retourner false si le noeud en question contiens/est un repertoire au lieu d'un fichier et true dans le cas contraire (attention aux fichiers speciaux sous Windows cependant). De meme getChildCount() peut renvoyer le nombre de fichiers et sous-repertoires contenus dans le dossier.
    Merci de penser au tag quand une réponse a été apportée à votre question. Aucune réponse ne sera donnée à des messages privés portant sur des questions d'ordre technique. Les forums sont là pour que vous y postiez publiquement vos problèmes.

    suivez mon blog sur Développez.

    Programming today is a race between software engineers striving to build bigger and better idiot-proof programs, and the universe trying to produce bigger and better idiots. So far, the universe is winning. ~ Rich Cook

  6. #6
    Expert éminent sénior
    Avatar de sinok
    Profil pro
    Inscrit en
    Août 2004
    Messages
    8 765
    Détails du profil
    Informations personnelles :
    Âge : 43
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Août 2004
    Messages : 8 765
    Points : 12 977
    Points
    12 977
    Par défaut
    Pour voire un exemple d'implémentation de JTree avec LazyLoading c'est par là:

    http://www.jroller.com/Thierry/entry...y_loading_in_a

    http://www.jroller.com/Thierry/entry...ading_in_jtree
    Hey, this is mine. That's mine. All this is mine. I'm claiming all this as mine. Except that bit. I don't want that bit. But all the rest of this is mine. Hey, this has been a really good day. I've eaten five times, I've slept six times, and I've made a lot of things mine. Tomorrow, I'm gonna see if I can't have sex with something.

  7. #7
    Membre régulier Avatar de ForgetTheNorm
    Homme Profil pro
    Docteur en informatique
    Inscrit en
    Novembre 2006
    Messages
    133
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Docteur en informatique
    Secteur : Enseignement

    Informations forums :
    Inscription : Novembre 2006
    Messages : 133
    Points : 76
    Points
    76
    Par défaut
    Citation Envoyé par sinok Voir le message
    Pour voire un exemple d'implémentation de JTree avec LazyLoading c'est par là:

    http://www.jroller.com/Thierry/entry...y_loading_in_a

    http://www.jroller.com/Thierry/entry...ading_in_jtree
    Ah, merci beaucoup c'est exactement ça que je voulais faire...
    Mais je viens seulement de lire ton message, et je m'aperçois que la façon dont j'ai codé mon arbre reprend les mêmes principes que ceux que tu me proposes : insérer un noeud "bidon", puis lors de l'ouverture, le supprimer pour le remplacer par les vrais fils.

    Merci

+ 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