timiil
无才可去补单车
随笔 - 4,  文章 - 0,  评论 - 28,  阅读 - 18151
     个人而言,一直觉得XtraGrid是个非常不错的窗格控件,也基于它做了若干个微型的应用,最终用户们也比较能接受。当然,现在商业的Grid很多,同质化也很严重,好像Infragstics的UltraGrid,ComponentOne的,DataDynamic的SharpGrid,还有Janus的GridEx。。。反正什么列锁定,拖放,排序,过滤,单元格合并,导出。。。都成了Basic Feature了:)
    最近有朋友问过,如何在XtraGrid上显示出象会计凭证一样的录入方式,其实之前几个客户也向我提过,不过一直都很忙,总没有空尝试做这个东西。这两天因为准备仔细的研究DevExpress的源码,就用这个题目进行了一次热身了,这里也不揣简陋,让各位高人晒笑一下:)
    首先我想到的实现方法,是从RepositoryItem中继承出一个新的文本编辑器,里边进行数位间隔,但由于不能直接从Winform.TextBox里边继承,想了想重绘的种种恐怖,我就放弃了。
    第2条路是做一个UserControl,在里边动态生成若干个文本诓(你要多少位有效数字,就生成多少个),一个埃一个的排列,UserControl作为容器。我想这是最懒惰的方法了,几乎没有什么高难度的地方。。。只是,亲爱的XtraGrid不支持在单元格中直接挂接UserControl!!!(PopupContainer可以,不过是弹出一个小窗口,在这里没用),所以这个方法也行不通。(BTW,Janus的GridEX可以这样做,你在单元格里边挂接任意的控件都无任欢迎,所以GridEx是我的Second Choice。。。)
    现在采取的办法,其实最笨,就是直接动态生成数位列,为了好看,再重绘一下ColumnHeader,具体代码这里不拜弄了,各位可以自由欣赏。运行效果如下:
    


        现在基本上可以使用,包括录入和显示都正常,不足之处还有很多: 
        1,不支持列拖放(因为我找不到"捕捉列拖放完成"的事件)
        2,可以排序,但升序和降序的Indicator不能显示(不知到在那里重绘)
        3,不支持分组和过滤(不过想来没有人会在凭证列干这两件事吧)
       
        测试窗体的代码:
        定义一个私有对象
private GridCurrencyEdit gce;

public Form1()
        
{
            InitializeComponent();

            
// 加载数据

            
this.gce = new GridCurrencyEdit(this.colSinglePrice, this.dsTest.dtOrderMaster, 42, Color.Beige);
        }


private void UpdateData()
        
{
            
this.gce.PreUpdate();
            
//执行了上述函数再更新数据
        }


     具体源代码一并奉上,对应DevExpress版本2.0.0到最新的6.1.4都可以; 代码基于.net 2.0,如果要“回迁”到1.1的,就把那几个匿名事件改一下就可以了. 希望各位高手提出宝贵意见和整改代码,或者是对其进一步优雅的封装,都非常期待:)
        /Files/timiil/GridCurrencyHelper.rar
posted on   timiil  阅读(9687)  评论(6编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 【自荐】一款简洁、开源的在线白板工具 Drawnix

< 2006年5月 >
30 1 2 3 4 5 6
7 8 9 10 11 12 13
14 15 16 17 18 19 20
21 22 23 24 25 26 27
28 29 30 31 1 2 3
4 5 6 7 8 9 10
点击右上角即可分享
微信分享提示