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列的更多相关文章

  1. DEV控件GridControl常用属性设置

    1. 如何解决单击记录整行选中的问题 View->OptionsBehavior->EditorShowMode 设置为:Click 2. 如何新增一条记录 (1).gridView.Ad ...

  2. DEV控件GridControl常用属性设置(转)

      1. 如何解决单击记录整行选中的问题 View->OptionsBehavior->EditorShowMode 设置为:Click 2. 如何新增一条记录 (1).gridView. ...

  3. c# dev控件 gridcontrol 数据跟随鼠标滚轮滚动也可以编辑

    在绑定书到gridControl后经常发现: 如果你设置了 this.gridView3.OptionsBehavior.Editable = false; 那数据可以跟随滚轮滚动,但如果你要复制某个 ...

  4. devexpress表格控件gridcontrol图片列,按钮列,时间列等特殊列的实现

    1.项目中经常会在表格中插入按钮列,图片列,表格列一些非文本的特殊列.如何在devexpress表格控件gridcontrol中实现呢?以下列举一个实现添加图片列,按钮列,时间列,按钮列,开关列的示例 ...

  5. DevExpress控件-GridControl根据条件改变单元格/行颜色(Dev GridControl 单元格着色) z

    DevExpress控件-数据控件GridControl,有时我们需要根据特定条件改变符合条件的行或者单元格颜色达到突出显示目的,现在动起鼠标跟我一起操作吧,对的,要达到这个目的您甚至都不用动键盘. ...

  6. DEV控件中GridView中的复选框与CheckBox实现联动的全选功能

    最初的界面图如图1-1(全选框ID: cb_checkall  DEV控件名称:gcCon ): 要实现的功能如下图(1-2  1-3  1-4)及代码所示: 图1-2 图1-3 图1-4 O(∩_∩ ...

  7. DevExpress控件-GridControl根据条件改变单元格(Dev GridControl 单元格着色)

    DevExpress控件-GridControl根据条件改变单元格颜色,如下图: 解决办法:可以参考:http://www.cnblogs.com/zeroone/p/4311191.html 第一步 ...

  8. DevExpress ASP.NET 使用经验谈(9)-Dev控件客户端事件 ClientSideEvents

    上一节,已经介绍了ASPxGridView的自定义列和基本事件 ,本节接着将介绍Dev控件的客户端事件模型. 在上节示例基础上,我们增加一行菜单,使用Dev的ASPxMenu来实现,如下图所示. 图一 ...

  9. DevExpress控件-GridControl根据条件改变单元格/行颜色--转载

    DevExpress控件-数据控件GridControl,有时我们需要根据特定条件改变符合条件的行或者单元格颜色达到突出显示目的,现在动起鼠标跟我一起操作吧,对的,要达到这个目的您甚至都不用动键盘. ...

随机推荐

  1. 【bzoj2151】种树(堆/优先队列+双向链表)

    题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2151 这道题因为优先队列不怎么会用,而且手写堆的代码也不长,也想复习一下手写堆的写法…… ...

  2. HBase协处理器的使用(添加Solr二级索引)

    给HBase添加一二级索引,HBase协处理器结合solr 代码如下 package com.hbase.coprocessor; import java.io.IOException; import ...

  3. Excel 如何复制粘贴一整行

    在某些时候,我们需要重复性的录入一些信息,而且表头都是一样的,一直拉列宽是相当令人烦躁的事情. 所以,就想可以直接复制黏贴出一整行,包括行的各个列宽. 具体操作如图: ——>首先,一整行复制, ...

  4. lua 写逻辑打印log时,打印到一半后停止不再打印,程序停止

    问题描述:ubuntu下用lua开发游戏电子邮件模块,自己测试时向用户推送100封,而用户最多只能有50封.这是调用sysdelete删除一些邮件.当打印log时,打印到一半后程序中途停止.将打印lo ...

  5. Spring Boot入门——多文件上传大小超限问题解决

    多文件上传中遇到上传文件大小的问题 org.apache.tomcat.util.http.fileupload.FileUploadBase$FileSizeLimitExceededExcepti ...

  6. 解决没有referenced Libraries的方法

  7. wpf多程序集之间共享资源字典--CLR名称空间未定义云云

    wpf多程序集之间共享资源字典--CLR名称空间未定义云云 分类: WPF 2012-10-28 10:57 1162人阅读 评论(0) 收藏 举报 以下介绍如何创建可用于在多个程序集之间共享的资源字 ...

  8. QBXT Day 4 数学,数论

    今天讲一讲数论吧(虽然清明讲过了) 进制转换 我们来看10这个数怎么转换成k进制 因为10=2^3+2^1,所以10就是1010 三进制也同理10=3^2+3^0,所以就是101 我们对于一个10进制 ...

  9. MySQL 分区知识点(三)

    前言: MySQL 分区后每个分区成了独立的文件,虽然从逻辑上还是一张表其实已经分成了多张独立的表, 从 information_schema.INNODB_SYS_TABLES 系统表可以看到每个分 ...

  10. Sublime2 + SASS + Koala 测试

    Sublime SASS语法高亮插件下载地址:https://github.com/kuroir/SCSS.tmbundle/zipball/SublimeText2 koala_2.0.4_setu ...