如何在遍历Treeview时设置位置

时间:2014-05-23 11:37:16

标签: c#

我想穿越树视图&将value属性设置为它在树中的位置,如下所示

     A[val:1]->A1[val:11]
        l l--->A2[val:12]
        l----->A3[val:13]

     B[val:2]->B1[val:21]
        l l--->B2[val:22]

     C[val:3]->C1[val:31]
        l l--->C2[val:32]

我编写了一个递归函数,它返回了所有节点,但我无法为其节点分配所需的位置。

  private void TraverseTreeNode(TreeNodeCollection nodes)
    {
        foreach (TreeNode node in nodes)
        {
            TraverseTreeNode(node.ChildNodes);
        }
    }

2 个答案:

答案 0 :(得分:2)

考虑到TreeNode.Value的类型为string,这将从level = 1开始:

    private static void TraverseTreeNode(TreeNodeCollection nodes, int parentNumber)
    {
        var childNumber = 1;
        foreach (TreeNode node in nodes)
        {
            node.Value = string.Format("{0}{1}", parentNumber, childNumber ).Substring(0,node.Depth+1);
            TraverseTreeNode(node.ChildNodes, parentNumber);
            childNumber++;
            if (node.Depth == 0) { parentNumber++; }
        }
    }

仅适用于两个级别,但可以通过向TraverseTreeNode添加其他参数轻松扩展。

<强>更新

以下内容适用于层次结构中的任何深度:

    private static void TraverseTreeNode(TreeNodeCollection nodes, int parentNumber)
    {
        var childNumber = 1;
        foreach (TreeNode node in nodes)
        {
            node.Value = node.Parent != null && node.Parent.Value != null
                ? string.Format("{0}{1}", node.Parent.Value, childNumber)
                : string.Format("{0}{1}", parentNumber, childNumber).Substring(0, node.Depth + 1);

            TraverseTreeNode(node.ChildNodes, parentNumber);
            childNumber++;
            if (node.Depth == 0) { parentNumber++; }
        }
    }

答案 1 :(得分:1)

因为你需要递归方法,试试这个

     private void Caller()
    {
        TraverseTreeNode(treeView1.Nodes);
    }

    private void TraverseTreeNode(TreeNodeCollection nodes)
    {
        int index = 1;
        foreach (TreeNode node in nodes)
        {
            node.Text = (node.Parent != null ? node.Parent.Text : string.Empty) + index++;
            TraverseTreeNode(node.Nodes);
        }
    }