首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用动态节点填充XtraTreeList

用动态节点填充XtraTreeList
EN

Stack Overflow用户
提问于 2014-07-16 12:03:56
回答 1查看 1.1K关注 0票数 0

我的桌子有两栏:

代码语言:javascript
复制
+-------------+------------+  
| Level       | Desc       |  
+-------------+------------+  
| 1           | a          |  
+-------------+------------+    
| 2           | b          |  
+-------------+------------+ 
| 2           | c          | 
+-------------+------------+    
| 1           | d          |  
+-------------+------------+ 
| 2           | e          | 
+-------------+------------+    
| 2           | f          |  
+-------------+------------+ 
| 3           | g          | 
+-------------+------------+    
| 1           | h          |  
+-------------+------------+ 
| 1           | i          | 
+-------------+------------+ 
| 2           | j          |  
+-------------+------------+ 
| 2           | k          | 
+-------------+------------+ 

我需要在XtraTreeview中根据级别列用两列创建这些数据的显示,应该如下所示:

代码语言:javascript
复制
- 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,但在这种情况下,不知道如何填充一个节点包含3个、4个或更多子节点的位置。

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

填充TreeView:

代码语言:javascript
复制
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();
        }

创建列:

代码语言:javascript
复制
 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();
    }
EN

回答 1

Stack Overflow用户

发布于 2014-07-16 12:20:15

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

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

  • Id
  • ParentId
  • 文本

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

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

  • 为树中的每个节点创建一个项,我用我想要的属性(Id、ParentId、Text.)创建了自己的类。
  • 然后设置树控件的数据源。

示例:

代码语言:javascript
复制
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的唯一性。

上面的示例生成这样的树:

代码语言:javascript
复制
- ONE
-- A
-- B
- TWO
- THREE
-- C
-- D
-- E

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

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/24780337

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档