Devexpress GridControl中 repositoryItemCheckEdit作为选择列以及作为显示列的使用方法

一、在gridcontrol列表控件中使用单选框作为选择列,这里有两种方式。

方式一:选择gridcontrol控件的Run Designer按钮,添加一列,设置该列的ColumnEdit为checkedit。如下图:

代码如下:

private void Form1_Load(object sender, EventArgs e)
        {
            try
            {
                List<Student> studentList = new List<Student> { new Student() { Selected="N",Name="张三",Age=22 },
                new Student() { Selected="N",Name="李四",Age=20 }, new Student() { Selected="N",Name="王五",Age=24}};
                repositoryItemCheckEdit1.ValueUnchecked = "N";
                //定义选中状态值
                repositoryItemCheckEdit1.ValueChecked = "Y";
                //绑定数据
                gridControl1.DataSource = studentList;
                //gridControl2.DataSource = studentList;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }

        /// <summary>
        /// 得到选中项
        /// </summary>
        private void simpleButton1_Click(object sender, EventArgs e)
        {
            try
            {
                if (gridView1.FocusedRowHandle >= 0)
                {
                    string str = string.Empty;
                    for (int i = 0; i < gridView1.RowCount; i++)
                    {
                        if (gridView1.GetRowCellValue(i, "Selected").ToString().Equals("Y"))
                        {
                            if(string.IsNullOrEmpty(str))
                            {
                                str = gridView1.GetRowCellValue(i, "Name").ToString();
                            }
                            else
                            {
                                str+="\n"+ gridView1.GetRowCellValue(i, "Name").ToString();
                            }
                        }
                    }
                    MessageBox.Show(str);
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
 public class Student
    {
        public string Selected { get; set; }
        public string Name { get; set; }
        public int Age { get; set;}
    }

效果图:

方式二:选择gridcontrol控件的Run Designer按钮,选中gridview,设置gridview的MultiSelect和MultiSelectMode属性。如下图:

代码如下:

private void Form1_Load(object sender, EventArgs e)
        {
            try
            {
                List<Student> studentList = new List<Student> { new Student() { Selected="N",Name="张三",Age=22 },
                new Student() { Selected="N",Name="李四",Age=20 }, new Student() { Selected="N",Name="王五",Age=24}};
                //repositoryItemCheckEdit1.ValueUnchecked = "N";
                //定义选中状态值
                //repositoryItemCheckEdit1.ValueChecked = "Y";
                //绑定数据
                //gridControl1.DataSource = studentList;
                gridControl2.DataSource = studentList;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }
         /// <summary>
        /// 得到选中项
        /// </summary>
  private void simpleButton2_Click(object sender, EventArgs e)
        {
            try
            {
               int[] rowIndex=gridView2.GetSelectedRows();
                string str = string.Empty;
                foreach (int index in rowIndex)
                {
                    if (string.IsNullOrEmpty(str))
                    {
                        str = gridView1.GetRowCellValue(index, "Name").ToString();
                    }
                    else
                    {
                        str += "\n" + gridView1.GetRowCellValue(index, "Name").ToString();
                    }
                }
                MessageBox.Show(str);
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }

效果图如下:

二、在gridcontrol列表控件中使用单选框作为显示列

选择gridcontrol控件的Run Designer按钮,添加一列,设置该列的ColumnEdit为checkedit,设置gridview的optionscolumn的AllowEdit为false(设置改列不可编辑)。如下图

代码如下:

private void Form1_Load(object sender, EventArgs e)
        {
            try
            {
                 List<Student> studentList = new List<Student> { new Student() { Selected="N",Name="张三",Age=22,IsStudent=true },
                new Student() { Selected="N",Name="李四",Age=20,IsStudent=true }, new Student() { Selected="N",Name="王五",Age=24,IsStudent=false}};
                repositoryItemCheckEdit3.CheckStyle = DevExpress.XtraEditors.Controls.CheckStyles.Standard;
                //复选框加载的状态     实心   空心   空心打勾
                repositoryItemCheckEdit3.NullStyle = DevExpress.XtraEditors.Controls.StyleIndeterminate.Unchecked;
                //绑定数据
                gridControl1.DataSource = studentList;
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message);
            }
        }    

    public class Student
    {
        public string Selected { get; set; }
        public string Name { get; set; }
        public int Age { get; set; }

        public bool IsStudent { get; set; }
    }

效果图如下:

示例代码:http://download.csdn.net/detail/u012026245/9917399

原文地址:https://www.cnblogs.com/dinggf/p/11966826.html

时间: 2024-10-19 13:59:38

Devexpress GridControl中 repositoryItemCheckEdit作为选择列以及作为显示列的使用方法的相关文章

在DevExpress GridControl中添加进度条控件 z

首先可以使用 DevExpress GridControl 自带的进度条控件. 但是我要用一个方法来设置所有的单元格进度,而不是每个单元格都要设置一遍,同时我想要根据进度值不同,进度条显示不同的颜色. 那么就要自己手动的编写代码来完成了. 1 .绘制一个单元格进度条形状,当进度小于50%时显示为红色. public void DrawProgressBar(DevExpress.XtraGrid.Views.Base.RowCellCustomDrawEventArgs e) { string

在DevExpress GridControl的一列中显示图片

最近做项目的时候用到了将GridControl中一列设置为PictureEdit类型,然后通过这一列来显示图片.经过尝试发现有以下两种方式可行. 方法一.知道图片的路径与名称 比如:在数据库中存储了图片的路径(包括:本地路径.服务器路径),那么在可以通过非绑定列的方式来实现. 1.创建了一个非绑定列并设置其相应的属性,属性设置如下: FieldName设为 Photo(该字段名必须是唯一的) UnboundType设为 UnboundColumnType.Object ColumnEdit设为R

[DevExpress]GridControl 同步列头checkbox与列中checkbox状态

关键代码: /// <summary> /// 同步列头checkbox与列中checkbox状态 /// </summary> /// <param name="view">GridView</param> /// <param name="fieldeName">需要绘制Checkbox的列名</param> /// <param name="e">Mouse

在DevExpress程序中使用GridView直接录入数据的时候,增加列表选择的功能

在我上篇随笔<在DevExpress程序中使用Winform分页控件直接录入数据并保存>中介绍了在GridView以及在其封装的分页控件上做数据的直接录入的处理,介绍情况下数据的保存和校验等操作,不过还没有涉及到数据列表选择的这种方式,而这种在项目应用也是比较广泛的一种输入方式.本篇随笔继续探讨在GridView上直接录入数据,并增加字典选择列表的功能. 1.GridView直接录入数据回顾 在之前整合的数据录入案例里面,我们可以看到可以在列表里面直接录入速度的便捷性,如下所示. 1)直接在G

[DevExpress]GridControl 列头绘制Checkbox

关键代码: /// <summary> /// 为列头绘制CheckBox /// </summary> /// <param name="view">GridView</param> /// <param name="checkItem">RepositoryItemCheckEdit</param> /// <param name="fieldName">需要

关于DevExpress GridControl控件中新增复选按钮一事

关于DevExpress GridControl新增复选按钮的事情,查了一下网上的文档,发现都是在查询的数据集[table]中新增一列供checkbox绑定使用.偶尔的一瞬间,我在DevExpress 的Demo上发现有使用CheckBox的例子,找了半天Demo的代码,还是没找到.然后就找到了设置的属性. 晚上的时候,想了想,感觉能试出来简直是运气.如下配置即可: 设置GridView中的[OptionsSelection]->[MultiSelectMode]设置为CheckBoxRowSe

DevExpress GridControl 按扭列的操作

为Winform 中的DevExpress GridControl某列添加按扭列,定义全局变量 RepositoryItemButtonEdit m_OperateFoodBtn = new RepositoryItemButtonEdit(); RepositoryItemButtonEdit m_OperateClothBtn = new RepositoryItemButtonEdit(); 设置相关属性方法 private void SetEditBtn(RepositoryItemBu

[WinForm][DevExpress]自定义GridControl中按钮文字内容

最近项目开发中,使用到了GridControl的FindPanel,这样可以很好的对数据进行筛选,可是所展现的按钮文字是英文,如图: 那怎么定义两个按钮问题,以符合项目需求了?经过一番搜索发现利用GridLocalizer可以很好实现: 核心代码: public class BuilderGridLocalizer : GridLocalizer { Dictionary<GridStringId, string> CusLocalizedKeyValue = null; /// <su

[Devexpress]GridControl 绑定DataSource时GridView列不变化

Devexpress  GridControl 绑定DataSource时GridView列不变化 1.使用VS自带的DataGridView替代 2.数据绑定以后调用 gridView.PopulateColumns()  函数 重新创建列 gcSummary.DataSource = _dtData; gvSummary.PopulateColumns();