2016-12-06 3 views
0

TreeViewを扱うときに問題が発生します。ノードごとに表示されるテキストがより具体的です。TreeViewノードの名前が曖昧になる

private void defineEmpityTree(){    
    cbt.setModel(new DefaultTreeModel(
     new DefaultMutableTreeNode("Relat\u00F3rios Individuais") { 
      { 
      } 
     } 
    )); 
} 

と私はツリーを初期化し追加します:私はテキストを持つ単一のノードを期待ツリー、の初期化子を皮切り

、それはユーザーのためのプログラムより直感的になるかもしれない

"Relatórios Individuais" aren't shown, Tree Ok, another bug

cbt = new JCheckBoxTree(); 
    defineEmpityTree(); 
    scrollPane.setViewportView(cbt); 
が、私はこの問題を無視して、ノードの実際の充填を続け、ユーザーは自分の検索やプレスを指定し、「OK」 、ツリーがいっぱいになったとき、それは2番目のイメージです。

しかし、もう一度 "ok"を押すと、奇妙な3番目の画像が表示されることがあります。

ノードが作成されたケードの部分を強調します。ファイルの配列の場合、ノードは各タイプのレポートと各レポートのロットごとに作成されますが、実際はそれほど重要ではありません。

private void defineNewTree(ArrayList<File> files){ 
    DefaultMutableTreeNode dmtRoot = new DefaultMutableTreeNode("Relat\u00F3rios Individuais"); 
    DefaultMutableTreeNode dmtSubFolder = null; 
    DefaultMutableTreeNode dmtLotFolder = null; 
    int childsRoot = 0; 
    int childsSub = 0; 

    for(File f : files){ 
     String subFolder = f.getName().substring(17,f.getName().length()-4); 
     String name = f.getName(); 
     String lot = f.getName().substring(0, 3); 
     childsRoot = dmtRoot.getChildCount(); 
     boolean subFoldExists = false; 
     boolean foldLotExists = false; 
     //creatingo folder reports: 
     for(int i = 0;i<childsRoot;i++){ 
      if(dmtRoot.getChildAt(i).toString().equals(subFolder)){ 
       dmtSubFolder = (DefaultMutableTreeNode) dmtRoot.getChildAt(i);   
       subFoldExists = true; 
       i=childsRoot; 
      } 
     } 
     if(!subFoldExists){ 
      dmtSubFolder = new DefaultMutableTreeNode(subFolder); 
      dmtRoot.add(dmtSubFolder); 
     } 
     for(int j = 0;j<childsSub;j++){ 
      if(dmtSubFolder.getChildAt(j).toString().equals(lot)){ 
       dmtLotFolder = (DefaultMutableTreeNode) dmtSubFolder.getChildAt(j); 
       foldLotExists = true; 
       j=childsSub; 
      } 
     } 
     if(!foldLotExists){ 
      dmtLotFolder = new DefaultMutableTreeNode("lote "+lot); 
      dmtSubFolder.add(dmtLotFolder); 
     } 
     dmtLotFolder.add(new DefaultMutableTreeNode(name)); 

    } 
    DefaultTreeModel myTree = new DefaultTreeModel(dmtRoot); 

    cbt.setModel(myTree); 
} 

私は、本当の問題があることだと思う:

cbt.setModel(myTree); 

ツリーの内容を定義するための正しい方法は何ですか?

編集: ボタンOK:

... 
JButton btnOk = new JButton("OK"); 
btnOk.setBounds(161, 37, 49, 23); 
btnOk.setActionCommand("ok"); 
btnOk.addActionListener(buttonListener); 
panel.add(btnOk); 
... 

class ButtonListener implements ActionListener{ 
    @Override 
    public void actionPerformed(ActionEvent a) { 
     switch(a.getActionCommand()){ 
      case "ok":     
       search(); 
       self.requestFocusInWindow(); 
       break; 
      case "cancel": 
       dispose(); 
       break; 
      case "print": 
       TreePath[] tp = cbt.getCheckedPaths(); 
       for(TreePath t : tp){ 
        System.out.println(t.getLastPathComponent().toString()); 
       } 
       self.requestFocusInWindow(); 
       break; 
      default: 
       break; 
     } 
    } 
} 

private void search(){ 
    FileSeeker fs = new FileSeeker(textField.getText()); 
    ArrayList<File> files = fs.getFiles(); 

    defineNewTree(files); 
} 

編集: CheckBoxCellRenderer:

private class CheckBoxCellRenderer extends JPanel implements TreeCellRenderer {  
    private static final long serialVersionUID = -7341833835878991719L;  
    JCheckBox checkBox;  
    public CheckBoxCellRenderer() { 
     super(); 
     this.setLayout(new BorderLayout()); 
     checkBox = new JCheckBox(); 
     add(checkBox, BorderLayout.CENTER); 
     setOpaque(false); 
    } 

    @Override 
    public Component getTreeCellRendererComponent(JTree tree, Object value, 
      boolean selected, boolean expanded, boolean leaf, int row, 
      boolean hasFocus) { 
     DefaultMutableTreeNode node = (DefaultMutableTreeNode)value; 
     Object obj = node.getUserObject();   
     TreePath tp = new TreePath(node.getPath()); 
     CheckedNode cn = nodesCheckingState.get(tp); 
     if (cn == null) { 
      return this; 
     } 
     checkBox.setSelected(cn.isSelected); 
     checkBox.setText(obj.toString()); 
     checkBox.setOpaque(cn.isSelected && cn.hasChildren && ! cn.allChildrenSelected); 
     return this; 
    }  
} 
+0

ここにOKボタンのコードを表示しましたか?私はそれを見ることができません。 – Michael

+0

私はそれが問題ではないと思ったので私はそれを見せなかった、私は今追加します:D –

+0

私はあなたのツリーセルレンダラに問題があると思う。この疑惑はヌルレイアウトを使用することでさらに増します。各JCheckBoxのサイズを明示的に設定している場合は、表示されている動作が説明されます。ツリーのセルレンダラーを設定するコードを含めてください。 – VGR

答えて

0

だから、最初の問題のための解決策は次のとおりです。

private void defineEmpityTree(){    
    DefaultMutableTreeNode dmtn = new DefaultMutableTreeNode("Relat\u00F3rios Individuais"); 
    cbt.setModel(new DefaultTreeModel(dmtn)); 
    ((DefaultTreeModel) cbt.getModel()).nodeChanged(dmtn); 
} 

私は単純にノードが変更されたことを通知する必要がありました。切り捨ての問題については

cbt.setLargeModel(true); 

はトリックをしました。