对C1FlexGrid for WinForms中指定区域的数据进行排序

发布时间:2012/11/16 00:11 发布者:葡萄城产品团队

返回博客中心

在某些特殊情况下,用户需要对C1FlexGrid for WinForms中的数据进行一些特殊的排序操作,比如:只对指定区域的单元格数据进行排序,C1FlexGrid虽然没有内置这样的功能,不过我们可以通过自定义排序来实现该需求。

首先,在Form中添加一个按钮和C1FlexGrid控件,并为按钮添加Click事件,添加以下逻辑:
1、得到C1Flexgrid中选中的单元格区域
 
C1.Win.C1FlexGrid.CellRange cr = this.c1FlexGrid1.Selection;
复制代码
2、创建一个临时的C1Flexgrid对象
 
var fg = new C1.Win.C1FlexGrid.C1FlexGrid();
复制代码
3、根据选中单元格的范围,为临时的C1Flexgrid指定行列数
 
fg.Cols.Count = cr.c2 - cr.c1 + 1;
    fg.Cols.Fixed = 0;
    fg.Rows.Count = cr.r2 - cr.r1 + 1;
    fg.Rows.Fixed = 0;
复制代码
4、给临时C1Flexgrid单元格赋值
 
for (int i = cr.r1; i <= cr.r2; i++)
    {
        for (int j = cr.c1; j <= cr.c2; j++)
        {
            fg[_row, _col] = this.c1FlexGrid1[i, j];
            _col += 1;
        }
        _row += 1;
        _col = 0;
    }
复制代码
5、对临时C1Flexgrid进行排序
 
fg.Sort(C1.Win.C1FlexGrid.SortFlags.Ascending, 0);
复制代码
6、将临时C1Flexgrid中的值设置给原始的C1Flexgrid
 
for (int i = cr.r1; i <= cr.r2; i++)
    {
        for (int j = cr.c1; j <= cr.c2; j++)
        {
            this.c1FlexGrid1[i, j] = fg[_row, _col];
            _col += 1;
        }
        _row += 1;
        _col = 0;
    }
复制代码
运行效果截图:

源码下载:VS2010 + ComponentOne Studio for Windows Forms 2012V2
Sort_CellRange.zip (64.38 K, 下载次数:10)

关于葡萄城

赋能开发者!葡萄城是专业的集开发工具、商业智能解决方案、低代码开发平台于一身的软件和服务提供商,为超过 75% 的全球财富 500 强企业提供服务。葡萄城专注控件软件领域30年,希望通过模块化的开发控件、灵活的低代码应用开发平台等一系列开发工具、解决方案和服务,帮助开发者快速响应复杂多变的业务需求,最大程度地发挥开发者的才智和潜能,让开发者的 IT 人生更从容更美好。

了解详情,请访问葡萄城官网