1

我有一个jtree。我已经编写了代码以在单击搜索按钮时搜索树中的给定节点,现在我必须通过再次单击该按钮来搜索下一个出现是否存在?你能帮我吗?搜索按钮的代码是

 m_searchButton.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent e) {
    DefaultMutableTreeNode node = searchNode(m_searchText.getText());
    if (node != null) {
      TreeNode[] nodes = m_model.getPathToRoot(node);
      TreePath path = new TreePath(nodes);
      m_tree.scrollPathToVisible(path);
      m_tree.setSelectionPath(path);
    } else {
      System.out.println("Node with string " + m_searchText.getText() + " not found");
    }
}

});

搜索方法的代码是

public DefaultMutableTreeNode searchNode(String nodeStr) {
DefaultMutableTreeNode node = null;
Enumeration e = m_rootNode.breadthFirstEnumeration();
while (e.hasMoreElements()) {
  node = (DefaultMutableTreeNode) e.nextElement();
  if (nodeStr.equals(node.getUserObject().toString())) {
    return node;
  }
}
return null;

}

4

1 回答 1

2

不是只返回一个节点,而是返回一个找到的节点列表。

public List<DefaultMutableTreeNode> searchNode(String nodeStr) {
DefaultMutableTreeNode node = null;
Enumeration e = m_rootNode.breadthFirstEnumeration();
List<DefaultMutableTreeNode> list = new ArrayList<DefaultMutableTreeNode>();
while (e.hasMoreElements()) {
  node = (DefaultMutableTreeNode) e.nextElement();
  if (nodeStr.equals(node.getUserObject().toString())) {
    list.add(node);
  }
}
return list;
}

自己做按钮的逻辑ActionListener,这并不难。

添加节点列表作为您的类成员,当您单击按钮时检查它是否为空,如果是,则检索列表,获取第一个节点;用它做任何你想做的事情并将其从列表中删除。当您到达最后一个元素时,将列表再次设置为空。

于 2012-09-17T11:51:44.813 回答