C1FlexGrid:在单元格范围内排序

有些实际案例中需要实现针对单元格范围而不是整个 C1FlexGrid 排序。C1FlexGrid 本身不具备该功能。在这篇文章中我们将讨论如何通过代码实现针对单元格范围的排序。

发布于 2013/02/22 00:00

ComponentOne Enterprise

有些实际案例中需要实现针对单元格范围而不是整个 C1FlexGrid 排序。C1FlexGrid 本身不具备该功能。在这篇文章中我们将讨论如何通过代码实现针对单元格范围的排序。

 背景:首先通过鼠标或代码选择单元格范围,在通过代码排序。‘

 我们在窗体中添加 button,添加点击事件,用于调用排序方法。

代码如下:

1.       获取当前选择单元格范围:

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 的排序结果存储进选中的单元格范围内。

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;

}


关于葡萄城

葡萄城是专业的软件开发技术和低代码平台提供商,以“赋能开发者”为使命,致力于通过表格控件、低代码和BI等各类软件开发工具和服务,一站式满足开发者需求,帮助企业提升开发效率并创新开发模式。葡萄城开发技术始于1980年,40余年来始终聚焦软件开发技术,有深厚的技术积累和丰富的产品线。是业界能够同时赋能软件开发和低代码开发的企业。凭借过硬的产品能力、活跃的用户社区和丰富的伙伴生态,与超过3000家合作伙伴紧密合作,产品广泛应用于信息和软件服务、制造、交通运输、建筑、金融、能源、教育、公共管理等支柱产业。

相关产品
推荐相关案例
关注微信
葡萄城社区二维码

关注“葡萄城社区”

加微信获取技术资讯

加微信获取技术资讯

想了解更多信息,请联系我们, 随时掌握技术资源和产品动态