参考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. sharepoint 版本信息查看

    #检查版本:# PowerShell script to display SharePoint products from the registry. Param( # decide on wheth ...

  2. 【cocos2d-x 环境配置-Mac配置篇】

    目前我配置的环境需求如下: JDK 1.6 XCode Version 4.6 (4H127) Cocos2d-x 2.2.0  Android Developer  一,下载安装 要配置环境一次性下 ...

  3. Android intent 传值不更新的原因和解决办法

    当 Activity 的启动模式是 singleTask 或者 singleInstance 的时候.如果使用了 intent 传值,则可能出现 intent 的值无法更新的问题.也就是说每次 int ...

  4. mysql 批量更新的四种方法

    批量更新的方法: 1 ) 逐条更新 代码如下: UPDATE mytable SET myfield = 'value' WHERE other_field = 'other_value'; 如果更新 ...

  5. 1083 矩阵取数问题(DP)

    1083 矩阵取数问题 基准时间限制:1 秒 空间限制:131072 KB 分值: 5 难度:1级算法题  收藏  关注 一个N*N矩阵中有不同的正整数,经过这个格子,就能获得相应价值的奖励,从左上走 ...

  6. Git 教程 -- 基于自己学习记录

    Git 教程 -- 基于自己学习记录 1. 引言 由于学校布置了一项熟悉 git 和 svn 操作的实验,所以自己重新温习了下 git,记录过程在这. 2. 注册登录 GitHub. 3. 选择一个仓 ...

  7. NOIP2018滚粗祭(周记更新至11.25)

      还好吧, 好像回归之后 还是有时间去机房转一转的 一个特别生动的例子就是 体育会考就去机房呆了一上午. 这里又要吐槽一下信息技术会考 stm我拿到的第一道题就是 https://www.luogu ...

  8. AcDbTable表格实体的简单例子

    例子是创建一个含有表格实体的块定义 效果如下(手动插入的块) 源代码如下,简单示意,采用了我不是很熟悉的智能指针创建实体对象,代码仅供参考 AcDbObjectPointer<AcDbTable ...

  9. Service由浅到深——AIDL的使用方式

    前言 最近有很多朋友问我这个AIDL怎么用,也许由于是工作性质的原因,很多人都没有使用过aidl,所以和他们讲解完以后,感觉对方也是半懂不懂的,所以今天我就从浅到深的分析一下这个aidl具体是怎么用的 ...

  10. delphi 10.2 ----简单的叠乘例子

    unit Unit11; interface uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, Syste ...