参考DEV官网代码做了一个增加checkbox列效果:

#region 方法:设置GridView数据绑定
        public void GridDataBind()
        {
            dt = dbHelper.Fill(cmdStr);                     // 填充DataTable
            dt.Columns.Add("Check", typeof(bool));  // 增加个CheckBox列
            dt.Columns["Check"].SetOrdinal(0);       // 设置选择列的位置
            for (int i = 0; i < dt.Rows.Count; i++)
            {
                dt.Rows[i]["Check"] = false;
            }
            gridControl1.DataSource = dt;
            gridView1.Columns["Check"].Width = 22;
            gridView1.Columns["Check"].OptionsColumn.ShowCaption = false;
            gridView1.Columns["Check"].OptionsColumn.AllowSort = DevExpress.Utils.DefaultBoolean.False;
        }
  #endregion

===================================================================================

#region GridView增加CheckBox列相关代码

protected void DrawCheckBox(Graphics g, Rectangle r, bool Checked)

{

DevExpress.XtraEditors.ViewInfo.CheckEditViewInfo info;

DevExpress.XtraEditors.Drawing.CheckEditPainter painter;

DevExpress.XtraEditors.Drawing.ControlGraphicsInfoArgs args;

info = chkEdit.CreateViewInfo() as DevExpress.XtraEditors.ViewInfo.CheckEditViewInfo;

painter = chkEdit.CreatePainter() as DevExpress.XtraEditors.Drawing.CheckEditPainter;

info.EditValue = Checked;

info.Bounds = r;

info.PaintAppearance.ForeColor = Color.Black;

info.CalcViewInfo(g);

args = new DevExpress.XtraEditors.Drawing.ControlGraphicsInfoArgs(info, new DevExpress.Utils.Drawing.GraphicsCache(g), r);

painter.Draw(args);

args.Cache.Dispose();

}

private void gridView_CustomDrawRowIndicator(object sender, RowIndicatorCustomDrawEventArgs e)
        {
            e.Appearance.TextOptions.HAlignment = HorzAlignment.Far;
            if (e.Info.IsRowIndicator)
            {
                if (e.RowHandle >= 0)
                {
                    e.Info.DisplayText = (e.RowHandle + 1).ToString(CultureInfo.InvariantCulture);
                }
                else if (e.RowHandle < 0 && e.RowHandle > -1000)
                {
                    e.Info.Appearance.BackColor = Color.AntiqueWhite;
                    e.Info.DisplayText = "G" + e.RowHandle;
                }
            }
        }

private void gridView_CustomDrawColumnHeader(object sender, ColumnHeaderCustomDrawEventArgs e)

{

if (e.Column == (sender as GridView).Columns["Check"])

{

e.Info.InnerElements.Clear();

e.Info.Appearance.ForeColor = Color.Blue;

e.Painter.DrawObject(e.Info);

DrawCheckBox(e.Graphics, e.Bounds, GetCheckedCount() == gridView1.DataRowCount);

//DrawCheckBox(e.Graphics, e.Bounds, false);

e.Handled = true;

}

}

private void gridView_MouseUp(object sender, MouseEventArgs e)

{

if (e.Clicks == 1 && e.Button == MouseButtons.Left)

{

GridHitInfo gridHitInfo;

Point point = gridView1.GridControl.PointToClient(Control.MousePosition);

gridHitInfo = gridView1.CalcHitInfo(point);

if (gridHitInfo.InColumn && gridHitInfo.Column.FieldName == "Check")

{

if (GetCheckedCount() == gridView1.DataRowCount)

{

UnCheckAll();

}

else

{

CheckAll();

}

}

if (gridHitInfo.InRow && gridHitInfo.InRowCell == true)

{

if (Convert.ToBoolean(gridView1.GetFocusedRowCellValue("Check")) == false)

{

CheckSingle();

}

else

{

UnCheckSingle();

}

}

}

}

private int GetCheckedCount() // 获取到已选择的数量

{

int count = 0;

for (int i = 0; i < gridView1.DataRowCount; i++)

{

if ((bool)gridView1.GetRowCellValue(i, gridView1.Columns["Check"]) == true)

{

count++;

}

}

return count;

}

private void CheckAll() // 选择全部

{

for (int i = 0; i < gridView1.DataRowCount; i++)

{

gridView1.SetRowCellValue(i, gridView1.Columns["Check"], true);

}

}

private void UnCheckAll() // 反选全部

{

for (int i = 0; i < gridView1.DataRowCount; i++)

{

gridView1.SetRowCellValue(i, gridView1.Columns["Check"], false);

}

}

private void CheckSingle() // 选择一个

{

gridView1.SetRowCellValue(gridView1.FocusedRowHandle, gridView1.Columns["Check"], true);

}

private void UnCheckSingle() // 反选一个

{

gridView1.SetRowCellValue(gridView1.FocusedRowHandle, gridView1.Columns["Check"], false);

}

#endregion

======================================================================

在窗体加载事件里的代码:

private void MainForm_Load(object sender, EventArgs e)

{

#region 从本地数据库中获取数据 并展示到gridView控件上

GridDataBind();

#endregion

#region 设置gridview列只读(不能编辑)

for (int i = 1; i < gridView1.Columns.Count; i++)

{

gridView1.Columns[i].OptionsColumn.ReadOnly = true;

}

#endregion

}

Devexpress GridView增加CheckBox列的更多相关文章

  1. 在DBGrid增加一列CheckBox(而非DBCheckBox)

    自:http://rabbitfox.blog.sohu.com/33264033.html http://community.csdn.net/Expert/topic/5342/5342920.x ...

  2. DevExpress GridView属性说明

    转自http://www.cnblogs.com/-ShiL/archive/2012/06/08/ShiL201206081335.html (一)双击展开,收缩字表 1 Private Sub E ...

  3. DevExpress Grid使用checkBox选中的方法

    到官网得到消息自13.2版本后的Dev Grid中均内置了CheckBox列多选功能.在寻找答案的过程的成果进行记录. 一.13.2版本以后用法 启用多选列 对Gird中的View进行以下属性设置: ...

  4. DevExpress GridView 整理(转)

    DevExpress GridView 那些事儿 1:去除 GridView 头上的 "Drag a column header here to group by that column&q ...

  5. DevExpress GridView 那些事儿

    1:去除 GridView 头上的 "Drag a column header here to group by that column" -->  点击 Run Desig ...

  6. DevExpress GridView 整理

    1:去除 GridView 头上的 "Drag a column header here to group by that column" -->  点击 Run Desig ...

  7. gridview动态添加列的问题

    相信大家也和我一样遇到过这种问题,gridview在生成列的时候当列不确定怎么办?下面分享一下自己的解决方法. 举个列子说明一下. 普通列的添加比较简单. BoundField bf = new Bo ...

  8. DevExpress gridview下拉框的再次研究

    原文:DevExpress gridview下拉框的再次研究 前几天写了一篇关于研究DevExpress gridview下拉框的随笔(DevExpress gridview下拉框repository ...

  9. DEVEXPRESS GRIDVIEW 代码添加按钮(转)

    https://www.cnblogs.com/qq-xiao/p/6122573.html 1.1 创建一个RepositoryItemButtonEdit方法 1 private Reposito ...

随机推荐

  1. WCF快速上手(二)

    服务端是CS程序,客户端(调用者)是BS程序 一.代码结构: 二.服务接口Contract和实体类Domain INoticeService: using Domain; using System; ...

  2. form 认证 读取

    class Program { public static CookieContainer cc { get; set; } static void Main(string[] args) { str ...

  3. 【ocp-12c】最新Oracle OCP-071考试题库(42题)

    42.(9-1)choose the best answer: Which statement is true about the Oracle SQL, DELETE and TRUNCATE st ...

  4. SpringMVC 的映射

    27.1.1 @RequestMapping使用 之前,我们是把@RequestMapping注解放在方法之上,用来给方法绑定一个请求映射.除此以外,@RequestMapping注解还可以放在类的上 ...

  5. Linux下查找命令

    在CentOs下查找某个目录下的某个文件,使用如下指令: find /目录 -name 文件名 eg:查找当前目录下关于hadoop的文件 find / -name hadoop

  6. [转] LVM分区在线扩容

    [转] LVM分区在线扩容 在线扩容的这台服务器,LV分区格式为xfs,原大小1.2TB.增加了一块硬盘,大小为1.8TB. fdisk /dev/cciss/c0d1 # 创建分区,并指定分区类型为 ...

  7. 孩子们各显神通对付 iOS 12「屏幕使用时间」的限制

    简评:2018 年秋季,苹果公司推出了 iOS 12,其中备受好评的一项改变是:增加了屏幕使用时间限制,以减轻沉迷手机的状况.三个月过去后,这项功能似乎并没有对孩子造成太多困扰,道高一尺魔高一丈,孩子 ...

  8. null、 is_null() 、empty() 、isset() PHP 判断变量是否为空

    PHP中,在判断变量是否为空的时候,总会纠结应该选用哪个函数,下面列取常用的多种情况,其中1/3经过我的验证,其它来自网络,验证后使用... 使用 PHP 函数对变量 $x 进行比较 表达式 gett ...

  9. Oracle中ROWNUM的使用技巧

    ROWNUM是一种伪列,它会根据返回记录生成一个序列化的数字.利用ROWNUM,我们可以生产一些原先难以实现的结果输出,但因为它是伪列的这个特殊性,我们在使用时也需要注意一些事项,不要掉入“陷阱”.下 ...

  10. luogu_1379 八数码难题

    八数码-->BFS+set #include<iostream> #include<cstdlib> #include<cstdio> #include< ...