0

我有两列的表:

+-------------+------------+  
| 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 个或更多子节点的位置。

到目前为止,我已经这样做了:

填充树视图:

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();
    }
4

1 回答 1

0

您可能想阅读的文档在这里:https ://documentation.devexpress.com/#windowsforms/CustomDocument198

一棵树至少需要三样东西:

  • ID
  • 父 ID
  • 文本

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

一旦你有了它,这个概念就变成了这样:

  • 为树中所需的每个节点创建一个项目,我为此创建了自己的类,并使用了我想要的属性(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 且没有编译器的情况下执行此操作,因此请原谅任何错误。但是这个概念保持不变。

于 2014-07-16T12:20:15.567 回答