【转】关于DevExpress的XtraTreeList使用方法总结

【转】原文地址http://www.cnblogs.com/zfanlong1314/archive/2012/06/26/2564118.html

  1 树形控件是使用频率很高的一种控件。对于属性控件往往需要下面两个功能
  2
  3 1.TreeList带有CheckBox,并且节点要有三种状态(所有的子节点都选中,所有的子节点都没选择,一部分子节点选中)。使用DevXpress的TreeList控件很容易实现这一功能。
  4
  5 设置TreeList.OptionsView.ShowCheckBoxes = true            //是否显示CheckBox
  6
  7 设置TreeList.OptionsBehavior.AllowIndeterminateCheckState = true;         //设置节点是否有中间状态,即一部分子节点选中,一部分子节点没有选中
  8
  9 设置这两个属性之后就实现了TreeList带有CheckBox,并且节点有三种状态。
 10
 11
 12
 13 2.选中父节点或者子节点相互影响的功能,如选择父节点选择所有子节点。绑定TreeList的两个事件AfterCheckNode和BeforeCheckNode
 14
 15 实现功能的代码如下:
 16
 17
 18
 19         private void treeList1_AfterCheckNode(object sender, DevExpress.XtraTreeList.NodeEventArgs e)
 20         {
 21             SetCheckedChildNodes(e.Node, e.Node.CheckState);
 22             SetCheckedParentNodes(e.Node, e.Node.CheckState);
 23
 24         }
 25
 26         private void treeList1_BeforeCheckNode(object sender, DevExpress.XtraTreeList.CheckNodeEventArgs e)
 27         {
 28             e.State = (e.PrevState == CheckState.Checked ? CheckState.Unchecked : CheckState.Checked);
 29         }
 30
 31         /// <summary>
 32         /// 设置子节点的状态
 33         /// </summary>
 34         /// <param name="node"></param>
 35         /// <param name="check"></param>
 36         private void SetCheckedChildNodes(TreeListNode node, CheckState check)
 37         {
 38             for (int i = 0; i < node.Nodes.Count; i++)
 39             {
 40                 node.Nodes[i].CheckState = check;
 41                 SetCheckedChildNodes(node.Nodes[i], check);
 42             }
 43         }
 44
 45         /// <summary>
 46         /// 设置父节点的状态
 47         /// </summary>
 48         /// <param name="node"></param>
 49         /// <param name="check"></param>
 50         private void SetCheckedParentNodes(TreeListNode node, CheckState check)
 51         {
 52             if (node.ParentNode != null)
 53             {
 54                 bool b = false;
 55                 CheckState state;
 56                 for (int i = 0; i < node.ParentNode.Nodes.Count; i++)
 57                 {
 58                     state = (CheckState)node.ParentNode.Nodes[i].CheckState;
 59                     if (!check.Equals(state))
 60                     {
 61                         b = !b;
 62                         break;
 63                     }
 64                 }
 65                 node.ParentNode.CheckState = b ? CheckState.Indeterminate : check;
 66                 SetCheckedParentNodes(node.ParentNode, check);
 67             }
 68         }
 69
 70 1.TreeList.NodeCellStyle事件
 71
 72 Node的显示(包括窗口的切换导致Node的显示)和状态的改变都会触发该事件。该事件主要用来改变Node的显示样式。
 73
 74  private void treeList1_NodeCellStyle(object sender, DevExpress.XtraTreeList.GetCustomNodeCellStyleEventArgs e)
 75         {
 76             if (e.Node.CheckState == CheckState.Unchecked)
 77             {
 78                 e.Appearance.Font = new Font(DevExpress.Utils.AppearanceObject.DefaultFont, FontStyle.Strikeout);
 79                 e.Appearance.ForeColor = Color.Gray;
 80             }
 81         }
 82
 83 上面的代码是实现的效果是 : CheckState为Unchecked的节点的字带有中划线且背景灰色。
 84
 85
 86
 87 2.TreeList.DoubleClick事件
 88
 89 双击Node时触发,但要注意的是要在TreeList.OptionsBehavior.Editable = false的情况下,双击Node才能触发该事件。
 90
 91         private void treeList1_DoubleClick(object sender, EventArgs e)
 92         {
 93             TreeListNode clickedNode = this.treeList1.FocusedNode;
 94             string disPlayText = clickedNode.GetDisplayText("test");
 95             MessageBox.Show("You clicked " + disPlayText);
 96         }
 97
 98
 99
100 3.TreeList的命中测试特性
101
102  private void treeList1_MouseMove(object sender, MouseEventArgs e)
103         {
104             Point point = treeList1.PointToClient(Cursor.Position);
105             TreeListHitInfo hitInfo = treeList1.CalcHitInfo(point);
106             switch (hitInfo.HitInfoType)
107             {
108                 case HitInfoType.Cell:
109                     this.Cursor = Cursors.Hand;
110                     break;
111                 case HitInfoType.NodeCheckBox:
112                     this.Cursor = Cursors.PanEast;
113                     break;
114                 default :
115                     this.Cursor = Cursors.Default;
116                     break;
117             }
118         }
时间: 2024-12-16 09:51:57

【转】关于DevExpress的XtraTreeList使用方法总结的相关文章

DevExpress的XtraTreeList使用方法

树形控件是使用频率很高的一种控件.对于属性控件往往需要下面两个功能 1.TreeList带有CheckBox,并且节点要有三种状态(所有的子节点都选中,所有的子节点都没选择,一部分子节点选中).使用DevXpress的TreeList控件很容易实现这一功能. 设置TreeList.OptionsView.ShowCheckBoxes = true //是否显示CheckBox 设置TreeList.OptionsBehavior.AllowIndeterminateCheckState = tr

关于DevExpress VCL汉化方法

用法1:在工程中加入控件cxLocalizer; 在程序中加入如下语句: Localizer.LoadFromFile('DevLocal.ini'); Localizer.Language := '中文(简体,中国)'; Localizer.Active := true; 用法2:用DevExpress提供的工具cxLocalizerEditor打开这个ini文件,然后File->Build Resource File...; 在工程中加入控件cxLocalizer; 在程序中加入如下语句:

DevExpress的TcxDBLookupComboBox使用方法及问题

使用TcxDBLookupComboBox需要设置以下属性: 1.DataBinding.DataSource:数据感知控件的数据源. 2.DataBinding.DataField:数据感知控件的连接字段. 3.properties.ListSource:TcxDBLookupComboBox下拉列表数据源. 4.Properties.KeyFieldNames:下拉列表的关键字段(即cxDBLookupComboBox1.EditValue的值). 5.Properties.ListColu

DEV 皮肤的使用

一.皮肤的使用 拖入defaultLookAndFeel 组件到窗体中 拖入ribbonControl 控件到窗体中 将窗体继承为 DevExpress.XtraBars.Ribbon.RibbonForm 将窗体的AllowFormGlass属性改为 False 引用DevExpress.BonusSkins 引用DevExpress.OfficeSkins 在Main方法中加入代码DevExpress.UserSkins.BonusSkins.Register(); 7.DevExpress

DevExpress.XtraTreeList

1. DevExpress.XtraTreeList控件         将其简称为tree,tree其实就是一个树表控件,他像树一样包含具有父子关系的若干节点,同时每个节点又是一个带有多个字段的记录.其用法非常简单方便,只需要为其配置带有父子关系的数据源,其就可以按照树的形式进行显示. 1.1 DevExpress.XtraTreeList配置数据源    数据源一般是一个二维表,可以是数据库中的表,该表中要包含表示父子关系的两个字段,即主键和父亲的主键.下面的代码是手动创建的数据源DataT

DevExpress XtraTreeList TreeList复选框选择

权限管理涉及复选框多勾选. 1.控件属性设置 TreeList.OperationView.ShowCheckBoxes=true;用于显示CheckBox: TreeList.OperationBehavior.AllowIndeterminateCheckState=true;  设置CheckBox允许第三种状态. 2.控件事件绑定 要实现选择父级节点选择.子级节点全部选中.父级节点未选择.反之.子级节点部分选中.父级节点为第三种状态. private void treeList1_Aft

DevExpress 控件汉化代码和使用方法

DevExpress.XtraEditors.Controls  此控件包中包含的控件最多,包括文本框,下拉列表,按钮,等等       DevExpress.XtraGrid 网格       DevExpress.XtraBars 菜单栏 和 工具栏       DevExpress.XtraNavBar 导航条       DevExpress.XtraPrinting 报表打印相关       DevExpress.XtraReports 报表     DevExpress.XtraTr

DevExpress的Web控件汉化方法

原文:DevExpress的Web控件汉化方法 项目中用到devexpress的web控件,机器没有安装devexpress控件,直接在项目中引用的dev的dll,项目运行时发现都是英文界面,所以解决汉化问题. 项目中用的是v10.2版本,以此版本为例,其他版本方法应该类似. 步骤如下:   1.从官网下载对应的汉化包,地址:http://www.devexpresscn.com/news/DevExpress-news-94.html,找到对应的版本下载. 2.在下载的汉化文件里找到\Web\

DevExpress实现根据行,列索引来获取RepositoryItem的方法

/// <summary> /// 根据行,列索引来获取RepositoryItem /// </summary> /// <param name="view">GridView</param> /// <param name="rowIndex">行索引</param> /// <param name="columnIndex">列索引</param>