扩展 DataGridView 的功能(二)

二、加入可以输入文字的 DataGridViewComboBoxCell

DataGridView 的功能确实很强大,要实现在 grid 中加入 ComboBox , 只需要将grid列的类型改为 DataGridViewComboBoxColumn 即可

DataGridViewComboBoxColumn 也是从 DataGridViewColumn 中继承过来的

public class DataGridViewComboBoxColumn : DataGridViewColumn

在 Combobox  中加入选项值也是很简单的,不在赘述。

但系统自带的 DataGridViewComboBoxColumn 有个致命的缺点,就是它的 DropDownStyle 默认是 ComboBoxStyle.DropDownList,也就是

说下拉列表只能选择,不能输入文字,这样就极其不爽了,所以我们现在就要来扩展这个功能

定义新的 columns类, 当然要继承自DataGridViewComboBoxColumn 

     ///   <summary>
    
///  可修改 DropDownStyle 的 DataGridViewComboBoxColumn
    
///   </summary>

    public class DataGridViewComboBoxColumnEx : DataGridViewComboBoxColumn 

这个类只需要添加了一个属性

ContractedBlock.gif ExpandedBlockStart.gif DropDownStyle 属性
        /// <summary>
        
/// 控制组合框的外观和功能
        
/// </summary>
        [Description("控制组合框的外观和功能"), DefaultValue(ComboBoxStyle.DropDownList)]
        
public ComboBoxStyle DropDownStyle
        {
            
get { return dropDownStyle; }
            
set { dropDownStyle = value; }

 

因为主要的功能都是在 DataGridViewEx 中实现的, 呵呵

回到 DataGridViewEx 中, 重写 OnEditingControlShowing 方法,看字面意思就知道,这个方法是在 grid 的任何“编辑控件”显示时调用

看到这个我想大家都明白了, 我们只要在 ComboBox 控件显示出来时修改它的样式即可

         protected   override   void  OnEditingControlShowing(DataGridViewEditingControlShowingEventArgs e)
        {
            
if  (CurrentCell  !=   null   &&  CurrentCell.OwningColumn  is  DataGridViewComboBoxColumnEx)
            {
                DataGridViewComboBoxColumnEx col 
=  CurrentCell.OwningColumn  as  DataGridViewComboBoxColumnEx;
                
// 修改组合框的样式
                 if  (col.DropDownStyle  !=  ComboBoxStyle.DropDownList)
                {
                    ComboBox combo 
=  e.Control  as  ComboBox;
                    combo.DropDownStyle 
=  col.DropDownStyle;
                    combo.Leave 
+=   new  EventHandler(combo_Leave);
                }
            }
            
base .OnEditingControlShowing(e);

        }

上面可以看到, 修改了样式后,还需要为 ComboBox 控件绑定一个事件,这是为了能在 ComboBox 失去焦点时更新 Cell 的值

         ///   <summary>
        
///  当焦点离开时,需要将新输入的值加入到组合框的 Items 列表中
        
///   </summary>
        
///   <param name="sender"></param>
        
///   <param name="e"></param>
         void  combo_Leave( object  sender, EventArgs e)
        {
            ComboBox combo 
=  sender  as  ComboBox;
            combo.Leave 
-=   new  EventHandler(combo_Leave);
            
if  (CurrentCell  !=   null   &&  CurrentCell.OwningColumn  is  DataGridViewComboBoxColumnEx)
            {
                DataGridViewComboBoxColumnEx col 
=  CurrentCell.OwningColumn  as  DataGridViewComboBoxColumnEx;
                
// 一定要将新输入的值加入到组合框的值列表中
                
// 否则下一步给单元格赋值的时候会报错(因为值不在组合框的值列表中)
                col.Items.Add(combo.Text);
                CurrentCell.Value 
=  combo.Text;
            }

        }

OK了, 很简单, 所有的工作都完成了, 只需要创建一个 DataGridViewComboBoxColumnEx 列,并将 DropDownStyle 属性设置为 DropDown,

就可以在 ComboBox 中输入文字了

效果图


 代码下载

 

转载于:https://www.cnblogs.com/michaelhuwei/archive/2008/09/28/1301290.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
开发环境为vs2012 C#源码及完全样例 此版本为2012.2.24日更新版本,更新内容为 * 最后修改时间:2012.2.24 增加了汇总信息的自定义控制属性,参见功能描述12 * 2012.2.23 修改了过多列时父标题不显示的问题,重新写了算法,修改了标题头重叠及不能换行的问题,参见说明11. 总功能列举如下: /**************************************************************************************************** * Copyright (C) 2012 明振居士 版权没有,任意拷贝及使用,但对使用造成的任何后果不负任何责任,互相开源影响,共同进步 * 文 件 名:DataGridViewEx.cs * 创 建 人:明振居士 * Email:nzj.163@163.com qq:342155124 * 创建时间:2010-06-01 * 最后修改时间:2012.2.24 增加了汇总信息的自定义控制属性,参见功能描述12 * 2012.2.23 修改了过多列时父标题不显示的问题,重新写了算法,修改了标题头重叠及不能换行的问题,参见说明11. * 2012-1-19 增加第10条所示的功能;修改了列头超过26列的错误,导出excel为数组方式,速度更快,导出的单元格设置为文本格式。 * 标 题:用户自定义的DataGridView控件 * 功能描述:扩展DataGridView控件功能 * 扩展功能: * 1、搜索Search(); 有两个同明方法,参数不同 F3为快捷键继续向下搜索 * 2、用TreeView HeadSource 来设置复杂的标题样式,如果某个节点对应的显示列隐藏,请将该节点Tag设置为hide,隐藏列的排列位置与绑定数据元列位置对应,树叶节点的顺序需要与结果集的列顺序一致 * 3、通过反射导出Excel,无需引用com组件,方法ExportExcel() ,不受列数的限制,表头同样可以导出,AutoFit属性设置导出excel后是否自动调整单元格宽度 * 导出内容支持自定义的:Title List Header List Footer,支持在设计时值的设定,窗口关闭时Excel资源自动彻底释放 * 4、可以自己任意设定那些列显示及不显示,通过调用方法SetColumnVisible()实现。 * 5、设置列标题SetHeader(),设置列永远可见AlwaysShowCols(),设置列暂时不可见HideCols() * 注意,当使用了TreeView作为复杂Header时,不要使用本方法,Header显示的内容根据treeview内容而显示 * 6、列宽度及顺序的保存SaveGridView(),加载LoadGridView() * 7、支持所见即所得的打印功能,举例如下 * private void button5_Click(object sender, EventArgs e) { DGVPrinter printer = new DGVPrinter(); printer.PrintPreviewDataGridView(DataGridViewEx1); } * 8、自定义合并行与列,行合并用 MergeRowColumn 属性,列合并用MergeColumnNames属性,都可以定义多个列 * 9、行标号的设置 bool ShowRowNumber; * 10、增加最后一行的汇总行,支持列的聚合函数,参见http://msdn.microsoft.com/zh-cn/library/system.data.datacolumn.[removed]v=VS.100).aspx * 假设对id列显示“合计”字符,avgPrice进行平均值,total列显示合计,则对ComputeColumns属性增加三行内容:id,合计:;avgPrice,Avg(avgPrice);total,Sum(total) * 如果需要对值进行格式控制,请实现beforeShow事件 * 增加了导出和打印对应的支持,所见即所得的对齐方应用于式导出及打印。 * 11、列标题头自动换行,默认设置为每个列标题头行高为22,如果设置的字体更大,将自动进行计算。如果需要多行显示,请根据需要调节ColumnHeaderHeight属性值, * 其估算方法为预计的标题头层数乘以22,或层数乘以设置的字体高度。 * 12、针对第10条功能,增加汇总信息的自定义控制属性,汇总字体SummaryFont,汇总字体颜色SummaryFontColor,汇总背景色SummaryBGColor,边框与整个表格边框一致 ****************************************************************************************************/
*调整导出及打印的格式与显示一致;合计行,详细参见第10条修正功能,全部源码及示例。 * 文 件 名:DataGridViewEx.cs * 创 建 人:明振居士 * Email:nzj.163@163.com qq:342155124 * 创建时间:2010-06-01 * 最后修改时间:2012-1-19 增加第10条所示的功能;修改了列头超过26列的错误,导出excel为数组方式,速度更快,导出的单元格设置为文本格式。 * 标 题:用户自定义的DataGridView控件 * 功能描述:扩展DataGridView控件功能 * 扩展功能: * 1、搜索Search(); 有两个同明方法,参数不同 F3为快捷键继续向下搜索 * 2、用TreeView HeadSource 来设置复杂的标题样式,如果某个节点对应的显示列隐藏,请将该节点Tag设置为hide,隐藏列的排列位置与绑定数据元列位置对应,树叶节点的顺序需要与结果集的列顺序一致 * 3、通过反射导出Excel,无需引用com组件,方法ExportExcel() ,不受列数的限制,表头同样可以导出,AutoFit属性设置导出excel后是否自动调整单元格宽度 * 导出内容支持自定义的:Title List Header List Footer,支持在设计时值的设定,窗口关闭时Excel资源自动彻底释放 * 4、可以自己任意设定那些列显示及不显示,通过调用方法SetColumnVisible()实现。 * 5、设置列标题SetHeader(),设置列永远可见AlwaysShowCols(),设置列暂时不可见HideCols() * 注意,当使用了TreeView作为复杂Header时,不要使用本方法,Header显示的内容根据treeview内容而显示 * 6、列宽度及顺序的保存SaveGridView(),加载LoadGridView() * 7、支持所见即所得的打印功能,举例如下 * private void button5_Click(object sender, EventArgs e) { DGVPrinter printer = new DGVPrinter(); printer.PrintPreviewDataGridView(DataGridViewEx1); } * 8、自定义合并行与列,行合并用 MergeRowColumn 属性,列合并用MergeColumnNames属性,都可以定义多个列 * 9、行标号的设置 bool ShowRowNumber; * 10、增加最后一行的汇总行,支持列的聚合函数,参见http://msdn.microsoft.com/zh-cn/library/system.data.datacolumn.[removed]v=VS.100).aspx * 假设对id列显示“合计”字符,avgPrice进行平均值,total列显示合计,则对ComputeColumns增加三行内容:id,合计:;avgPrice,Avg(avgPrice);total,Sum(total) * 如果需要对值进行格式控制,请实现beforeShow事件 * 增加了导出和打印对应的支持,所见即所得的对齐方应用于式导出及打印。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值