c#treeview路径

时间:2011-11-10 12:40:10

标签: c# treeview

我有TreeNode节点。

something = treeview.Nodes[1].Nodes[4].Nodes[0]; 

TreeNode myNode = something;

并希望了解它拥有多少父母,以及我需要使用哪些索引来查找此节点的完整路径。

我的意思是从 myNode

获取“treeview.Nodes [1] .Nodes [4] .Nodes [0]”

2 个答案:

答案 0 :(得分:1)

这样的事情应该有效:

public IList<int> GetNodePathIndexes(TreeNode node)
{
    List<int> indexes = new List<int>();
    TreeNode currentNode = node;
    while (currentNode != null)
    {
        TreeNode parentNode = currentNode.Parent;
        if (parentNode != null)
            indexes.Add(parentNode.Nodes.IndexOf(currentNode));
        else
            indexes.Add(currentNode.TreeView.Nodes.IndexOf(currentNode));

        currentNode = parentNode;
    }
    indexes.Reverse();
    return indexes;
}

然后,您可以查看此结果以获取索引和计数,以获取父母的数量。

IList<int> path = GetNodePathIndexes(myNode);

StringBuilder fullPath = new StringBuilder("treeview");
foreach (int index in path)
{
    fullPath.AppendFormat(".Nodes[{0}]", index);
}

然后fullPath.ToString()应该返回treeview.Nodes[1].Nodes[4].Nodes[0]

答案 1 :(得分:0)

//...
string path = GetPath(treeView1.Nodes[0].Nodes[0].Nodes[1].Nodes[0]);
// now path is "treeView.Nodes[0].Nodes[0].Nodes[1].Nodes[0]"
//...
string GetPath(TreeNode node) {
    int index;
    Stack<string> stack = new Stack<string>();
    while(node != null) {
        if(node.Parent != null) {
            index = node.Parent.Nodes.IndexOf(node);
            stack.Push(string.Format("Nodes[{0}]", index));
        }
        else {
            index = node.TreeView.Nodes.IndexOf(node);
            stack.Push(string.Format("treeView.Nodes[{0}]", index));
        }
        node = node.Parent;
    }
    return string.Join(".", stack.ToArray());
}