使用动态节点填充XtraTreeList

时间:2014-07-16 12:03:56

标签: c# xtratreelist

我有两列的表格:

+-------------+------------+  
| Level       | Desc       |  
+-------------+------------+  
| 1           | a          |  
+-------------+------------+    
| 2           | b          |  
+-------------+------------+ 
| 2           | c          | 
+-------------+------------+    
| 1           | d          |  
+-------------+------------+ 
| 2           | e          | 
+-------------+------------+    
| 2           | f          |  
+-------------+------------+ 
| 3           | g          | 
+-------------+------------+    
| 1           | h          |  
+-------------+------------+ 
| 1           | i          | 
+-------------+------------+ 
| 2           | j          |  
+-------------+------------+ 
| 2           | k          | 
+-------------+------------+ 

我需要根据Level列在XtraTreeview中创建具有两列的数据显示,它应该是:

- 1 a
   -- 2 b
   -- 2 c
 -1 d
   -- 2 e
   -- 2 f
      -- 3 g
 -1 h
 -1 i 
   -- 2 j 
   -- 2 k

因此,级别列表示节点。级别1是主节点,级别2是级别1的子节点,级别3是级别2的子节点,级别4是子节点3 ... 我知道如果有固定数量的节点和子节点,如何填充Xtratreeview,但在这种情况下,不知道如何填充1个节点由3个,4个或更多个子节点组成的位置。

到目前为止我已经做到了这一点:

填充TreeView:

DataTable table = new DataTable();
        table.Columns.Add("Level");
        table.Columns.Add("Data");

        table.Rows.Add(1, "a");
        table.Rows.Add(2, "b");
        table.Rows.Add(2, "c");
        table.Rows.Add(1, "d");
        table.Rows.Add(2, "e");
        table.Rows.Add(2, "f");
        table.Rows.Add(3, "g");
        table.Rows.Add(4, "z");
        table.Rows.Add(5, "x");
        table.Rows.Add(2, "h");
        table.Rows.Add(3, "i");
        table.Rows.Add(1, "j");
        table.Rows.Add(2, "k");

        TreeListNode rootNode = null;

        for (int i = 0; i < table.Rows.Count; i++)
        {
            tl.BeginUnboundLoad();

            TreeListNode parentForRootNodes = null;

            if (table.Rows[i][0].ToString().Equals("1"))
            {
                rootNode = tl.AppendNode(new object[] { (string)table.Rows[i][1] }, parentForRootNodes);
            }


            if (table.Rows[i][0].ToString().Equals("2"))
            {
                tl.AppendNode(new object[] { (string)table.Rows[i][1] }, rootNode);
            }

            tl.EndUnboundLoad();
        }

创建列:

 private void CreateColumns2(TreeList tl)
    {
        tl.BeginUpdate();
        tl.Columns.Add();
        tl.Columns[0].Caption = "Level";
        tl.Columns[0].VisibleIndex = 0;
        tl.Columns.Add();
        tl.Columns[1].Caption = "Desc";
        tl.Columns[1].VisibleIndex = 1;
        tl.Columns.Add();
        tl.EndUpdate();
    }

1 个答案:

答案 0 :(得分:0)

您可能希望阅读的文档位于:https://documentation.devexpress.com/#windowsforms/CustomDocument198

树木至少需要三件事:

  • 编号
  • 的ParentId
  • 文本

因此,您描述的结构需要更改以允许查找项目的父级。

一旦你有了这个,概念是这样的:

  • 为树中所需的每个节点创建一个项目,我为此创建了我自己的类,其中包含我想要的属性(Id,ParentId,Text ...)
  • 然后设置树控件的数据源

示例:

var data = new List<TreeItem>
{
    new TreeItem { Id = "L1_1", ParentId = "", Text = "ONE" },
    new TreeItem { Id = "L1_2", ParentId = "", Text = "TWO" },
    new TreeItem { Id = "L1_3", ParentId = "", Text = "THREE" },
    new TreeItem { Id = "L2_1", ParentId = "L1_1", Text = "A" },
    new TreeItem { Id = "L2_2", ParentId = "L1_1", Text = "B" },
    new TreeItem { Id = "L2_3", ParentId = "L1_2", Text = "C" },
    new TreeItem { Id = "L2_4", ParentId = "L1_2", Text = "D" },
    new TreeItem { Id = "L2_5", ParentId = "L1_2", Text = "E" }
};

tree.Properties.DataSource = data;

}

class TreeItem
{
    public string Id { get; set; }
    public string ParentId { get; set; }
    public string Text { get; set; }
}

数据源中项目的顺序无关紧要,重要的是每个id的唯一性。

以上示例生成如下树:

- ONE
-- A
-- B
- TWO
- THREE
-- C
-- D
-- E

我在没有安装DevExpress且没有编译器的情况下这样做,所以请原谅任何错误。但是这个概念仍然是一样的。