Dev控件GridControl实现CheckBox列和ComBox列
1、在sql语句中添加空白行,如select c1,c2 null c3 from xxx;
2、将sql语句查询结果与gdc绑定CmmFrm.BestFitGridViewColumnsWidth(gdc_lines, sql,2);
3、将上述空白列绑定为RepositoryItemCheckEdit控件,并添加事件
RepositoryItemCheckEdit re = new RepositoryItemCheckEdit();
re.QueryCheckStateByValue += new DevExpress.XtraEditors.Controls.QueryCheckStateByValueEventHandler(Re_QueryCheckStateByValue);//定义这个事件是关键,因为就靠它了
gdv_lines.Columns[2].ColumnEdit = re;
4、事件实现:
void Re_QueryCheckStateByValue(object sender, DevExpress.XtraEditors.Controls.QueryCheckStateByValueEventArgs e)
{
string val = "";
if (e.Value != null)
{
val = e.Value.ToString();
}
else
{
val = "";//默认为不选中
}
switch (val)
{
case"True":
e.CheckState = CheckState.Checked;
break;
case"False":
e.CheckState = CheckState.Unchecked;
break;
case"Yes":
goto case"True";
case"No":
goto case"False";
case"1":
goto case"True";
case"0":
goto case"False";
default:
e.CheckState = CheckState.Unchecked; //默认状态,如果默认选择,则改为Checked
break;
}
e.Handled = true;
}
5、整个gdv控件要设为可编辑,但除了chekbox列外,其它列要禁止出现编辑,这要靠gdc控件的ShowingEditor事件实现
private void gdv_lines_ShowingEditor(object sender, CancelEventArgs e)
{
if (gdv_lines.FocusedColumn.AbsoluteIndex != 2)
e.Cancel = true;
}
6、遍历、检索
for (int i = 0; i < gdv_lines.DataRowCount; i++)
{
DataRow dr=gdv_lines.GetDataRow(i);
string ck = dr[2].ToString();
if (ck == "True")
{
...
}
7、程序设置选择状态
bool res = true;
if (gdv_lines.GetDataRow(0)[2].ToString() == "True") res = false;
for (int i = 0; i < gdv_lines.DataRowCount; i++) gdv_lines.GetDataRow(i)[2] = res;
///////////////////////////////////////////////////
另外,添加CombBox的方法,还不完善
// gdvLevel.BeginUpdate(); //开始视图的编辑,防止触发其他事件
// gdvLevel.BeginDataUpdate(); //开始数据的编辑
CmmFrm.BestFitGridViewColumnsWidth(gdcLevel, lvels, 1, false, false);
gdcLevel.DataSource = lvels;
gdvLevel.Columns[0].Visible = false;
RepositoryItemComboBox riCombo = new RepositoryItemComboBox();
riCombo.Items.AddRange(new string[] { "夏", "目视", "目视以下", "(含)以下" });
gdcLevel.RepositoryItems.Add(riCombo);
gdvLevel.Columns["其它"].ColumnEdit = riCombo;
//目前这种添加combbox的方法有缺陷,主要表现在1、不能设置为DorpDownList样式。2、选择后要敲回车,选择才能现在Cell中,否则焦点移走,选择就消失。
//有两篇文章解决这个问题,有时间梳理下
//https://yq.aliyun.com/articles/55052
//https://www.cnblogs.com/lonelyxmas/p/3906496.html
RepositoryItemCheckEdit riCkbox = new RepositoryItemCheckEdit();
riCkbox.ValueChecked = false;
gdcLevel.RepositoryItems.Add(riCkbox);
gdvLevel.Columns["选择"].ColumnEdit = riCkbox;
gdvLevel.EndDataUpdate();//结束数据的编辑
gdvLevel.EndUpdate(); //结束视图的编辑
Dev控件GridControl实现CheckBox列和ComBox列的更多相关文章
- DEV控件GridControl常用属性设置
1. 如何解决单击记录整行选中的问题 View->OptionsBehavior->EditorShowMode 设置为:Click 2. 如何新增一条记录 (1).gridView.Ad ...
- DEV控件GridControl常用属性设置(转)
1. 如何解决单击记录整行选中的问题 View->OptionsBehavior->EditorShowMode 设置为:Click 2. 如何新增一条记录 (1).gridView. ...
- c# dev控件 gridcontrol 数据跟随鼠标滚轮滚动也可以编辑
在绑定书到gridControl后经常发现: 如果你设置了 this.gridView3.OptionsBehavior.Editable = false; 那数据可以跟随滚轮滚动,但如果你要复制某个 ...
- devexpress表格控件gridcontrol图片列,按钮列,时间列等特殊列的实现
1.项目中经常会在表格中插入按钮列,图片列,表格列一些非文本的特殊列.如何在devexpress表格控件gridcontrol中实现呢?以下列举一个实现添加图片列,按钮列,时间列,按钮列,开关列的示例 ...
- DevExpress控件-GridControl根据条件改变单元格/行颜色(Dev GridControl 单元格着色) z
DevExpress控件-数据控件GridControl,有时我们需要根据特定条件改变符合条件的行或者单元格颜色达到突出显示目的,现在动起鼠标跟我一起操作吧,对的,要达到这个目的您甚至都不用动键盘. ...
- DEV控件中GridView中的复选框与CheckBox实现联动的全选功能
最初的界面图如图1-1(全选框ID: cb_checkall DEV控件名称:gcCon ): 要实现的功能如下图(1-2 1-3 1-4)及代码所示: 图1-2 图1-3 图1-4 O(∩_∩ ...
- DevExpress控件-GridControl根据条件改变单元格(Dev GridControl 单元格着色)
DevExpress控件-GridControl根据条件改变单元格颜色,如下图: 解决办法:可以参考:http://www.cnblogs.com/zeroone/p/4311191.html 第一步 ...
- DevExpress ASP.NET 使用经验谈(9)-Dev控件客户端事件 ClientSideEvents
上一节,已经介绍了ASPxGridView的自定义列和基本事件 ,本节接着将介绍Dev控件的客户端事件模型. 在上节示例基础上,我们增加一行菜单,使用Dev的ASPxMenu来实现,如下图所示. 图一 ...
- DevExpress控件-GridControl根据条件改变单元格/行颜色--转载
DevExpress控件-数据控件GridControl,有时我们需要根据特定条件改变符合条件的行或者单元格颜色达到突出显示目的,现在动起鼠标跟我一起操作吧,对的,要达到这个目的您甚至都不用动键盘. ...
随机推荐
- 美化tp5.1跳转提示
<html> <head> <meta http-equiv="Content-Type" content="text/html; char ...
- webdriver 选择
You only need from selenium import webdriver . Execute html= browser.find_element_by_xpath(" ...
- jquery jsonp模版
$.ajax({ dataType: "jsonp", url: "http://www.b.com/b.php", jsonp: "callback ...
- 手动下载 Xcode 文档
下载Xcode文档的方法有两个: 1. 自动下载:到在Xcode的Preserences中Downloads页面的Documentation,点击对应文档的下载. 2. 手动下载:到这个页面:http ...
- hdu 1517 A Multiplication Game(必胜态,必败态)
A Multiplication Game Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Ot ...
- uva 10739 dp
https://vjudge.net/problem/UVA-10739 和昨天的那个回文串几乎一样只是加了条件限制,可以随意增删以及替换. #include<iostream> #inc ...
- MySQL 索引的知识整理
前言: 很多面试者,在面试的时候,都会回答,”索引就相当于一本书的字典,有了他能够很快的找到数据”, 这种答案好像在读书的时候老师告诉这么说的吧.今天来全面的描述一下数据库索引的原理及优化 ...
- 经典SQL语句(转载)
一.基础 1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- ...
- Django pymysql学员管理系统
学员管理系统 项目规划阶段 项目背景 近年来老男孩教育的入学学员数量稳步快速增长,传统的excel统计管理学员信息的方式已经无法满足日渐增长的业务需求.因此公司急需一套方便易用的“学员管理系统”,来提 ...
- mysql 初识数据库
一 数据库管理软件的由来 基于我们之前所学,数据要想永久保存,都是保存于文件中,毫无疑问,一个文件仅仅只能存在于某一台机器上. 如果我们暂且忽略直接基于文件来存取数据的效率问题,并且假设程序所有的组件 ...