当前位置: 首页 > 编程笔记 >

Devexpress treelist 简介

安星汉
2023-03-14
本文向大家介绍Devexpress treelist 简介,包括了Devexpress treelist 简介的使用技巧和注意事项,需要的朋友参考一下

节点折叠 this.treeList1.CollapseAll();

  一、简介

二、属性列表

1、OptionsSelection:

  EnableAppearanceForcusedCell:选中的Cell的Appearance设置是否可用。默认为True;

  EnableAppearanceForcusedRow:选中的Node的Appearance设置是否可用。默认为True

  InvertSelection:设置选中风格是只应用于选中的Cell,还是应用于除选中的Cell之外的所有Cell。默认为False,即后者; 

  MultiSelect:是否可以选择多个Node。默认为False。

2、OptionsView:

   AutoCalcPreviewLineCount:是否自动计算预览节段的高度。默认为True;

   AutoWidth:是否允许列自动调整宽度;默认为True;

   EnableAppearanceEvenRow:生成偶数Node时,是采用由

  TreeListAppearanceCollection.EvenRow属性提供的Appearance

    设置,还是采用由TreeListAppearanceCollection.Row提供的

   Appearance设置。默认为False,即后者;

   EnableAppearanceOddRow:生成奇数Node时,是采用由

  TreeListAppearanceCollection.OddRow属性提供的Appearance

    设置,还是采用由TreeListAppearanceCollection.Row提供的

   Appearance设置。默认为False,即后者;

   ShowButtons:是否显示展开与收缩按钮。默认为True;

   ShowCloumns:是否显示列标题。默认为True;

   ShowFocusedFrame:在获得焦点的Cell上,是否显示焦点框架。默认为True;

   ShowHorzLines:是否显示水平线。默认为True;

   ShowIndentAsRowStyle:是否用相应Node的Appearance设置来生成Tree的缩进。默认为False

   ShowIndicator:是否显示Node的指示符面板。默认为True;

  ShowPreview:是否显示预览节段。默认为False;

  ShowRoot:是否在根Node间显示连接线。默认为True;

   ShowRowFooterSummary:是否显示分组脚注。默认为False;

  ShowSummaryFooter:是否显示摘要脚注。默认为False;

  ShowVertLines:是否显示垂直线。默认为True;

3、SelectImageList:选中Node时,显示图片的列表;

4、StateImageList:指明Node状态的图片的列表;

三、事件

四、使用

1、 如何隐藏TreeList的列头

   设置TreeListr的OptionsView的ShowColumns属性为:False

2、 如何默认展开所有的节点ExpandAll()

   tlvWells.ExpandAll();

    以及TreeNode.Expand   =   false   ; 

    或者你可以控制展开的层数 reeView1.ExpandLevel=10; 展开10层

  this.treeList.Nodes[0].ExpandAll();// 第一层下的所有接点展开

3、 如何让TreeList的每个结点高亮显示?

代码如下:

private void treeList1_CustomDrawNodeCell(object sender, DevExpress.XtraTreeList.CustomDrawNodeCellEventArgs e)
    {
      TreeList node = sender as TreeList;
      if (e.Node == node.FocusedNode)
      {
        e.Graphics.FillRectangle(SystemBrushes.Window, e.Bounds);
        Rectangle r = new Rectangle(e.EditViewInfo.ContentRect.Left, e.EditViewInfo.ContentRect.Top,
        Convert.ToInt32(e.Graphics.MeasureString(e.CellText,  treeList1.Font).Width + 1), Convert.ToInt32(e.Graphics.MeasureString(e.CellText,treeList1.Font).Height));
        e.Graphics.FillRectangle(SystemBrushes.Highlight, r);
        e.Graphics.DrawString(e.CellText, treeList1.Font, SystemBrushes.HighlightText, r);
        e.Handled = true;
      }
    }

4、 数据绑定最基本的两个属性:KeyFieldName和ParentFieldName。

(这两个属性一设置就基本上可以实现分级了)可以通过代码的编写实现,也可以直接在属性里面直接实现。这种数据库设计是比较常见的,一般数据满足树形关系就可以这样设计。绑定数据时,只需指定DataSource为对应 的DataTable,指定KeyFieldName为表主键字段,ParentFieldName为表指向主键的外键字段名。

 private void BindData()
      {
      this.tlOffice.DataSource = dtOffice;
      tlOffice.KeyFieldName = "OfficeID";
      //tlOffice.DataMember = "OfficeName";
      tlOffice.Columns["OfficeName"].Caption = "局名称";
      tlOffice.ParentFieldName = "ParentOfficeID";
    }

5、 选择某一节点时,该节点的子节点全部选择  取消某一节点时,该节点的子节点全部取消选择

      哪个节点引起行为的?节点是选中还是取消选中?由此确定方法的两个参数:TreeListNode和CheckState。遍历该节点及其子孙,并将其选中状态设置为该节点的状态即可。

    /// 选择某一节点时,该节点的子节点全部选择 取消某一节点时,该节点的子节点全部取消选择
    /// <param name="node"></param>
    /// <param name="state"></param>
    private void SetCheckedChildNodes(TreeListNode node, CheckState check)
    {
      for (int i = 0; i < node.Nodes.Count; i++)
      {
        node.Nodes[i].CheckState = check;
        SetCheckedChildNodes(node.Nodes[i], check);
      }
  } 

上两步写好了,别忘了上面的两个方法在TreeList_AfterCheckNode里面触发:

private void tlOffice_AfterCheckNode(object sender, DevExpress.XtraTreeList.NodeEventArgs e) 
{ 
  SetCheckedChildNodes(e.Node, e.Node.CheckState); 
  SetCheckedParentNodes(e.Node, e.Node.CheckState); 
}

6、 某节点的子节点全部选择时,该节点选择;某节点的子节点未全部选择时,该节点不选择     

 /// 某节点的子节点全部选择时,该节点选择  某节点的子节点未全部选择时,该节点不选择
    /// <param name="node"></param>
    /// <param name="check"></param>
    private void SetCheckedParentNodes(TreeListNode node, CheckState check)
    {
      if (node.ParentNode != null)
      {
        CheckState parentCheckState = node.ParentNode.CheckState;
        CheckState nodeCheckState;
        for (int i = 0; i < node.ParentNode.Nodes.Count; i++)
        {
          nodeCheckState = (CheckState)node.ParentNode.Nodes[i].CheckState;
          if (!check.Equals(nodeCheckState))//只要任意一个与其选中状态不一样即父节点状态不全选
          {
            parentCheckState = CheckState.Unchecked;
            break;
          }
          parentCheckState = check;//否则(该节点的兄弟节点选中状态都相同),则父节点选中状态为该节点的选中状态
        }
        node.ParentNode.CheckState = parentCheckState;
        SetCheckedParentNodes(node.ParentNode, check);//遍历上级节点
      }
    }

 上两步写好了,别忘了上面的两个方法在TreeList_AfterCheckNode里面触发: 

private void tlOffice_AfterCheckNode(object sender, DevExpress.XtraTreeList.NodeEventArgs e)
    {
      SetCheckedChildNodes(e.Node, e.Node.CheckState);
      SetCheckedParentNodes(e.Node, e.Node.CheckState);
    }

7、 获取选中的复选框数据列表

 private List<int> lstCheckedOfficeID = new List<int>();//选择局ID集合
    /// 获取选择状态的数据主键ID集合
    /// <param name="parentNode">父级节点</param>
    private void GetCheckedOfficeID(TreeListNode parentNode)
    {
      if (parentNode.Nodes.Count == 0)
      {
        return;//递归终止
      }
      foreach (TreeListNode node in parentNode.Nodes)
      {
        if (node.CheckState == CheckState.Checked)
        {
          DataRowView drv = tlOffice.GetDataRecordByNode(node) as DataRowView;//关键代码,就是不知道是这样获取数据而纠结了很久(鬼知道可以转换为DataRowView啊)
          if (drv != null)
          {
            int OfficeID = (int)drv["OfficeID"];
            lstCheckedOfficeID.Add(OfficeID);
          } 
        }
        GetCheckedOfficeID(node);
      }
    }

  下面测试获取主键列表:

 private void btnCheck_Click(object sender, EventArgs e)
    {
      this.lstCheckedOfficeID.Clear();
      if (tlOffice.Nodes.Count > 0)
      {
        foreach (TreeListNode root in tlOffice.Nodes)
        {
          GetCheckedOfficeID(root);
        }
      }
      string idStr = string.Empty;
      foreach (int id in lstCheckedOfficeID)
      {
        idStr += id + " ";
      }
      MessageBox.Show(idStr);
    }

五、注意事项

1、从数据库中读取数据

方法一:直接点击控件

 这种方法连接后系统会自动生成一行代码:

 this. 数据库表名TableAdapter.Fill(this.dataDataSet4.数据库表名);

 这种方法生成后不会像写代码那样连接后就会把第一行默认为根节点。而且一旦你要把可执行文件拿走就不可用了。因为你在选择数据库的时候选的是绝对路径。所以最好用下面的方法。

方法二:

用代码连接数据库(写的代码方法很多)       

 String connectionString = "Provider=Microsoft.Jet.OleDb.4.0;Data Source=";
      connectionString += @"D:\Data.mdb";//这用的是绝对路径

应该用相对路径。

(String connectionString = @"Provider=Microsoft.Jet.OleDb.4.0;Data Source=";
      connectionString += Application.StartupPath + @"\Data.mdb";
 )
      System.Data.OleDb.OleDbConnection con = new System.Data.OleDb.OleDbConnection(connectionString);
      con.Open();
      System.Data.OleDb.OleDbCommand cmd = new System.Data.OleDb.OleDbCommand("SELECT * FROM FS_STAFF", con);
      System.Data.OleDb.OleDbDataReader reader = cmd.ExecuteReader();
      DataTable table = new DataTable();
      table.Load(reader);
      gridControl2.DataSource = table;

好了,以上内容是小编给大家简单介绍的Devexpress treelist 知识,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

 类似资料:
  • 译序 不懂数据库的全栈工程师不是好架构师 —— Vonng ​ 现今,尤其是在互联网领域,大多数应用都属于数据密集型应用。本书从底层数据结构到顶层架构设计,将数据系统设计中的精髓娓娓道来。其中的宝贵经验无论是对架构师,DBA、还是后端工程师、甚至产品经理都会有帮助。 ​ 这是一本理论结合实践的书,书中很多问题,译者在实际场景中都曾遇到过,读来让人击节扼腕。如果能早点读到这本书,该少走多少弯路啊!

  • 模块(也被称为 “task plugins” 或 “library plugins”)是在 Ansible 中实际在执行的.它们就 是在每个 playbook 任务中被执行的.你也可以仅仅通过 ‘ansible’ 命令来运行它们. 让我们回顾一下我们是如何通过命令行来执行三个不同的模块: ansible webservers -m service -a "name=httpd state=star

  • 译者的话 这是一本很经典的Python入门教材,也是一本很适合初学者的编程入门书籍。网上有过一些翻译,不过我觉得都还是自己动手来尝试一下,这样更有利于深入了解和体验,所以就再造轮子了。 作者的话 这是Think Python这本书的第二版,本次使用的是Python3,与Python2有很多不同,这些不同之处会有标注。如果你用Python2的话,还是建议你去阅读上一个版本。 读者可以到亚马逊购买本书

  • 不同于传统 Shell 书籍,本书并未花大篇幅去介绍 Shell 语法,而是以面向“对象” 的方式引入大量的实例介绍 Shell 日常操作,“对象” 涵盖数值、逻辑值、字符串、文件、进程、文件系统等。这样有助于学以致用,并在用的过程中提高兴趣。也可以作为 Shell 编程索引,在需要的时候随时检索。 介绍 项目首页:http://www.tinylab.org/open-shell-book 代码

  • MongoDB 是一个开源的文档类型数据库,它具有高性能,高可用,可自动收缩的特性。MongoDB能够避免传统的ORM映射从而有助于开发。 文档 在MongoDB中,一行纪录就是一个文档,它是一个由键值对构成的数据结构,MongoDB文档与JSON对象类似。键的值可以包含其他的文档,数组,文档数组。 { "_id" : ObjectId("54c955492b7c8eb21818bd09")

  • 为什幺写这个框架? 利用协程特性以同步方式来编写异步代码,增强可读性。 将swoole的异步特性与传统框架的MVC相结合。 可以用作api也可以用作http server,rpc server. 目前实现了以Zookeeper、Redis、Mysql为注册中心的服务化治理. 如何使用,与传统框架的区别? 框架基本使用与传统框架基本一致,路由,控制器,服务层,数据层。 在异步调用的地方需要以yiel

  • 在过去三年半的时间里,AngularJS已经成为世界上数十万程序员的领先开源JavaScript应用程序框架。 AngularJS的“1.x”版本已被广泛使用,并且变得非常受欢迎的复杂应用程序。 新的“Angular 2”也宣布了其最终版本。 如果您认为这种材料有用,您还应该考虑注册一个Rangle的培训课程,这有助于实践学习,非常适合需要将他们的技术转换到Angular 2的公司,或者想要提高技

  • Numeric,即 NumPy 的前身,是由 Jim Hugunin 开发的。 也开发了另一个包 Numarray ,它拥有一些额外的功能。 2005年,Travis Oliphant 通过将 Numarray 的功能集成到 Numeric 包中来创建 NumPy 包。 这个开源项目有很多贡献者。 数组的算数和逻辑运算。 与线性代数有关的操作。 NumPy 拥有线性代数和随机数生成的内置函数。 N