2011-09-07 11 views
5

私はJtreeと2つのボタンを持っていて、すべてのノードを選択したり選択解除したりできます。JTree:すべてのノードをプログラムで選択する

selectAll = new JButton("Select all"); 
selectAll.addActionListener(new ActionListener(){ 
     @Override 
     public void actionPerformed(ActionEvent e) { 
       int row = 0; 
       while (row < curvesTree.getRowCount()) 
       { 
        curvesTree.expandRow(row); 
        row++; 
       } 
      int entradasTree = curvesTree.getRowCount(); 
      for(int i=0; i<entradasTree; i++){ 
       TreePath path = curvesTree.getPathForRow(i); 
       curvesTree.setSelectionPath(path); 
      } 
     } 
    }); 

     unselectAll = new JButton("Unselect all"); 
     unselectAll.addActionListener(new ActionListener(){ 
      @Override 
      public void actionPerformed(ActionEvent e) { 
       curvesTree.clearSelection(); 
      } 
     }); 

非選択ボタンが動作しているようだが、選択はすべてのみJTreeのを展開し、最後のノードを選択します。私はこのような試みをしました。私はノードが計画的に選択されるたびに、私は前者を選択解除していると思う。例えば、

curvesTree = new JTree(rootNode); 
curvesTree.setExpandsSelectedPaths(true); 
curvesTree.getSelectionModel().setSelectionMode(TreeSelectionModel. 
        DISCONTIGUOUS_TREE_SELECTION); 

答えて

6

非選択が起こります。拡大後のループでは、代わりにAPIを読ん

​​3210

EDIT

は年;-)だけがツリーにすべての作業を残し多くのsimper方法を、見つけた後も、常に有益ですか:

tree.setSelectionInterval(0, tree.getRowCount()); 
+1

優秀キャッチ、あなたをどうやったのか... 1人の – mKorbel

+0

おかげで、私は半分の朝その方法を探している:) –

0

はい、その可能です::

JTreeのは、このように構成された新しい選択パスを設定する代わりに、追加しているので、

import java.awt.Dimension; 
import javax.swing.*; 
import javax.swing.event.*; 
import javax.swing.tree.*; 

public class TreeWithMultiDiscontiguousSelections { 

    public static void main(String[] argv) { 
     JTree tree = new JTree(); 
     tree.getSelectionModel().setSelectionMode(TreeSelectionModel.DISCONTIGUOUS_TREE_SELECTION); 
     int treeSelectedRows[] = {3, 1}; 
     tree.setSelectionRows(treeSelectedRows); 
     TreeSelectionListener treeSelectionListener = new TreeSelectionListener() { 

      @Override 
      public void valueChanged(TreeSelectionEvent treeSelectionEvent) { 
       JTree treeSource = (JTree) treeSelectionEvent.getSource(); 
       System.out.println("Min: " + treeSource.getMinSelectionRow()); 
       System.out.println("Max: " + treeSource.getMaxSelectionRow()); 
       System.out.println("Lead: " + treeSource.getLeadSelectionRow()); 
       System.out.println("Row: " + treeSource.getSelectionRows()[0]); 
      } 
     }; 
     tree.addTreeSelectionListener(treeSelectionListener); 
     JFrame frame = new JFrame("JTree With Multi-Discontiguous selection"); 
     frame.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
     frame.add(new JScrollPane(tree)); 
     frame.setPreferredSize(new Dimension(380, 320)); 
     frame.setLocation(150, 150); 
     frame.pack(); 
     frame.setVisible(true); 
    } 

    private TreeWithMultiDiscontiguousSelections() { 
    } 
} 
+0

ランダムコードスニペット再び;-) – kleopatra

0

私はkleopatraの答えに自分自身の成長の痛みに基づいて追加したいと思います。

特に私の問題では、ノードポップアップメニューJTreeに「Select All Children」メニュー項目を追加する必要がありました。したがって、このソリューションは、選択したノードのすべての子ノードに適用されます。

TreeNode selectedNode = tree.getSelectionPath().getLastPathComponent(); 
// Expand tree from selected node... 
List<TreePath> paths = new ArrayList<TreePath>(); 
determineTreePaths(selectedNode, paths); // Recursive method call... 

TreePath[] treePaths = new TreePath[paths.size()]; 
Iterator<TreePath> iter = paths.iterator(); 

for (int i = 0; iter.hasNext(); ++i) 
{ 
    treePaths[i] = iter.next(); 
} 

if (paths.size() > 0) 
{ 
    TreePath firstElement = paths.get(0); 
    setSelectionPath(firstElement); 
    scrollPathToVisible(firstElement); 
}  

determineTreePaths(selectedNode, paths)再帰呼び出しは、すべての方法ダウンリーフノードに選択したノードからツリーを走査するために必要とされます。このソリューションは、深さに関係なく機能します(私の知る限り)。私が言うことができないのは、それが最も効率的な解決策であるということです。より良いソリューションをお持ちの方は、別のソリューションを投稿していただくか、この1つを編集してください。次のように

メソッドの実装は次のとおりです。

private void determineTreePaths(TreeNode currentNode, List<TreePath> paths) 
{ 
    paths.add(new TreePath(((DefaultTreeModel) getDefaultTreeModel()).getPathToRoot(currentNode)); 

    // Get all of my Children 
    Enumeration<?> children = currentNode.children(); 

    // iterate over my children 
    while (children.hasMoreElements()) 
    { 
     TreeNode child = (TreeNode) children.nextElement(); 
     determineTreePaths(child, paths); 
    } 
} 
関連する問題