dev 中的GridControl中的行实现选择的功能实现
1、项目有实现不GridControl中的数据导出Excel的功能,导出的时候是把所有的数据全部导出,现在要实现可供选择的灵活的导出功能。除了全选可全不选,还可以对每一行实现选择的功能。实现起来比较简单,界面也很简单,先贴一下实现的界面。
2、实现思路:先要在传给GridControl的DataTable中增加新的字段,字段名称可以自己选择,显示出方框的形状以供选择。默认全部选择,所以调用函数时,传入的isSelected为false。实现代码:
public void AddChooseColumn(DataTable dt, bool isSelected)
{
if (dt == null || dt.Rows.Count == ) { return; }
if (dt.Columns.Contains("CHOOSE")) { return; }
dt.Columns.Add("CHOOSE", typeof(Boolean));
dt.Columns["CHOOSE"].DefaultValue = false;
foreach (DataRow row in dt.Rows)
row["CHOOSE"] = isSelected;
dt.AcceptChanges();
}
3、实现全选和全部不选的功能,由第二步知道当新增字段“CHOOSE”为false时是,全不选,那么当用户单击CheckEdit时(窗体上的全选选择框name为chkSelectAll)时,把字段“CHOOSE”设置成true即可实现全选功能。全选选择框的实现代码如下:
Action<bool> allOrNotAll = flag =>
{
foreach (DataRow row in dt.Rows)
{
foreach (DataColumn column in dt.Columns)
{
string name = column.ColumnName;
if (name.Equals(DataTableField.CHOOSE.ToString()))
{
row[name] = flag;
}
}
}
};
//全选
this.chkSelectAll.CheckStateChanged += (x, y) => allOrNotAll(this.chkSelectAll.Checked);
原本的代码是这样的:this.chkSelectAll.CheckStateChanged += delegate{ allOrNotAll(this.chkSelectAll.Checked);};因为有大括号,所以delegate之后的大括号在代码中单独占了一行,而大括号中的代码却只有一行,所以为了看起来更加清晰,改为了: this.chkSelectAll.CheckStateChanged += (x, y) => allOrNotAll(this.chkSelectAll.Checked); 参数想x,y是,object,EventArgs,在代码中没有用到,所以简单命名成想x,y.
4、现在实现单选一行就可以了,思路是:当用户单击时,根据单击的坐标,对应的DataRow,如果对应的ColumnName=“CHOOSE”,那么就可以断定是要选择这一行。所以把数据中的row["CHOOSE"]设置为true,显示选中状态即可。代码如下所示。
private static void SelectTicket(MouseEventArgs e, ColumnView gridView, string columnFieldName)
{
GridHitInfo hint = (GridHitInfo)gridView.CalcHitInfo(e.X, e.Y);
if ((gridView.RowCount <= ) || (!hint.InRowCell) || (hint.Column != gridView.Columns[columnFieldName]))
return;
DataRow hintRow = gridView.GetDataRow(hint.RowHandle);
if (hintRow == null)
return;
if (hintRow[columnFieldName] == null)
return;
hintRow["CHOOSE"] = !(bool)hintRow["CHOOSE"];
}
调用此函数的代码是:
this.gridOperatorTask.Click += (obj, e) => SelectTicket((MouseEventArgs)e, this.advBandedGridView1, "CHOOSE");
到此功能已经实现了。
感想:最近要过年了,一直都心思没写博客,看到别人写的很好的博客,从其中学到了好多知识,心里非常感激。今天把自己解决的问题写出来,万一有人遇到了可以参考一下。知识在于分享,以后要像其他优秀的人那样,不仅在停学习新的知识,而且把心得、总结写成博客分享出来,有很多的文章都使我受益匪浅。
dev 中的GridControl中的行实现选择的功能实现的更多相关文章
- 关于 Dev中的GridControl 中 GridView 的 PopulateColumns() 方法
最近使用Dev控件,Gridview绑定数据源后不能显示数据,于是在网上查询,说是使用PopulateColumns()方法,可以显示数据.试了一下,管用. 于是在所有更新数据源数据后,都用上了这句话 ...
- WPF datagrid/gridcontrol 中选中多行,复制粘贴到excel或其他文本编辑器中
wpf中 data grid 开启自带的选中,然后复制,可以到excel中直接粘贴,在某些业务场景中很实用,方便.开启也很简单: SelectionMode="Row" 加上这个, ...
- VMware10中的CentOS6.5命令行安装VMwaretools工具启用windows与虚拟机中Linux系统的共享目录
VMware10中的CentOS6.5命令行安装VMwaretools工具启用windows与虚拟机中Linux系统的共享目录 一.描述 系统描述:win7旗舰版64位系统+VMware Workst ...
- Developer Express控件gridcontrol中gridView的某一个单元格是否可以自由输入
场景:在Developer Express控件gridcontrol中的gridView中,当医生开的临时医嘱的医嘱类型为"中草药","计价总量"单元格不可以自 ...
- WPF界面开发:DevExpress WPF在GridControl中固定行时处理时刻
DevExpress广泛应用于ECM企业内容管理. 成本管控.进程监督.生产调度,在企业/政务信息化管理中占据一席重要之地.通过DevExpress WPF Controls,您能创建有着强大互动功能 ...
- DevExpress中的gridControl选择问题
在Dev控件中,gridControl是最常用的一个了. //直接通过gridView获取当前行 dr=this.gridView1.GetDataRow(this.gridView1.Focused ...
- MFC 编辑框中字体大小改变,行高不能改变,只能显示一半的问题,已解决。
CKagulaCEdit是CEdit的一个继承类,m_edit的CKagulaCEdit类型的一个变量 调用的时候,是这样的: 编辑框中字体大小改变,行高不能改变,只能显示一半的问题,问题如下: 这时 ...
- 在命令行中运行eclipse中创建的java项目
在命令行中运行eclipse中创建的java项目 博客分类: java相关 javaeclipse命令行 由于项目要求,需要对eclipse中的项目进行打包,似的可以在客户机上不装eclipse的情 ...
- Devexpress GridControl中combobox级联显示 z
http://minmin86121.blog.163.com/blog/static/4968115720143163533356/ 在 使用GridControl时,可能会有需求要求某2列显示co ...
随机推荐
- KoaHub平台基于Node.js开发的Koa的连接MongoDB插件代码详情
koa-mongo MongoDB middleware for koa, support connection pool. koa-mongo koa-mongo is a mongodb midd ...
- Instant App 即将到来,Android 集权或将加速分裂
在境外,Android 的体验将越来越好,在中国,Android 的更新可能将止步于6.0! 话题讨论:Instant App 在中国将何去何从? 以下为谷歌原创文章 2017-03-03 Googl ...
- java内部发送http请求并取得返回结果,修改response的cookie
public Object userLogin(HttpServletRequest request, HttpServletResponse response, String email, Stri ...
- RabbitMQ-从基础到实战(4)— 消息的交换(下)
0.目录 RabbitMQ-从基础到实战(1)- Hello RabbitMQ RabbitMQ-从基础到实战(2)- 防止消息丢失 RabbitMQ-从基础到实战(3)- 消息的交换(上) 1.简介 ...
- SQL SERVER 执行大于80M的SQL 脚本
在CMD控制器窗口 使用SqlCmd命令来执行 具体请看 SqlCmd /? 或者MSDN
- windows修改Host后未生效。
打开CMD命令,输入ipconfig /flushdns即可
- 功能总结之MongDB初探
题外话 工作3年,了解的技术颇多,但都是一知半解,了解不是很透澈.用过的技术,就像猴子搬过的包谷,搬一个丢一个.几年风雨,真有点一缕清风过,片叶不沾身的味道. 为强化知识点,提升文档及学习能力,我把以 ...
- 打印时鼠标键盘移动的div创建
function createDiv(id, label, offset_left, offset_top) { $("body").append($("<div& ...
- iOS开发之应用沙盒
1.应用沙盒概述 每个iOS应用都有自己的应用沙盒(应用沙盒就是文件系统目录),与其他文件系统隔离.应用必须待在自己的沙盒里,其他应用不能访问该沙盒. 应用沙盒的文件系统目录,如下图所示(假设应用的名 ...
- 如何修改vsftpd的默认根目录/var/ftp/pub到另一个目录?
修改ftp的根目录只要修改/etc/vsftpd/vsftpd.conf文件即可: 加入如下几行: local_root=/var/www/html chroot_local_user=YES ano ...