有些实际案例中需要实现针对单元格范围而不是整个 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;
}
ComponentOne Enterprise | 下载试用
ComponentOne 是一套专注于企业 .NET开发、支持 .NET Core 平台,并完美集成于 Visual Studio 的第三方控件集,包含 300 多种 .NET开发控件,提供表格数据管理、数据可视化、报表和文档、日程安排、输入和编辑、导航和布局、系统提升工具等七大功能,被誉为“.NET开发的‘瑞士军刀’”。
ComponentOne 为您提供专业的产品咨询服务,并由技术支持工程师为您1对1解答。>> 发帖提问
葡萄城热门产品
活字格
打通现有软件,快速定制面向未来的个性化应用

SpreadJS
可嵌入您系统的在线Excel的纯前端表格控件

Wyn商业智能
可与企业自有系统深度集成,增强数据分析的 BI 工具
