世界俱乐部杯赛

DevExpress WinForms中文教程:Grouping(分组)- 如何自定义分组算法?

翻译|使用教程|编辑:龚雪|2025-07-21 10:37:46.390|阅读 1 次

概述:本教程主要为大家介绍如何使用DevExpress WinForms控件实现自定义分组算法,欢迎下载最新版组件体验!

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

相关链接:

DevExpress WinForms拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!

DevExpress WinForms中文使用教程图集

 默认情况下,通过在每个组中放入相同的值来形成数据组。尽管DevExpress WinForms网格提供了一些其他内置算法,但有时您需要实现自己的逻辑,这是使用GridViewCustomColumnGroup事件完成的。在本文中您将了解如何处理此事件,以便更改数字列的数据分组逻辑,分组包含从0到99.99,然后从100到199.99等开始的值范围。

获取DevExpress WinForms v25.1正式版下载

DevExpress技术交流群11:749942875      欢迎一起进群讨论

默认操作

 当您根据Order Sum列对网格数据进行分组时,默认情况下,分组是基于该列中的唯一值形成的。

DevExpress WinForms中文使用教程图集
实现自定义分组逻辑

切换到设计时,首先,通过将属性设置为来启用该列的自定义排序模式。

DevExpress WinForms中文使用教程图集

 之后,选择网格视图并处理它的事件,要处理的列由事件的参数指定,事件处理程序将两行与和参数指定的值进行比较。由于要将值组合成与百相对应的组,因此将值除以100并比较结果。为了将大于1000的所有值放入同一组,处理程序假设如果结果都大于10,则结果相等。在这种情况下,参数被设置为0,其他值进行标准比较。

事件的参数被设置为true,以防止在事件执行后调用默认的比较机制。

C#

private void gridView_CustomColumnGroup(object sender, DevExpress.XtraGrid.Views.Base.CustomColumnSortEventArgs e) {
if (e.Column.FieldName == "Order Sum") {
e.Handled = true;
double val1 = Math.Floor(Convert.ToDouble(e.Value1) / 100);
double val2 = Math.Floor(Convert.ToDouble(e.Value2) / 100);
if (val1 >= 10 && val2 >= 10)
e.Result = 0;
else e.Result = System.Collections.Comparer.Default.Compare(val1, val2);
}
}

 为了更好地说明这段代码是如何工作的,即使在对数据进行分组时,分组列值也应该是可见的。要启用此操作,展开并将选项设置为true。

DevExpress WinForms中文使用教程图集

 现在运行应用程序并按Order Sum列对网格数据进行分组,因此将行组合到指定的间隔中。但是组行在相应的组中显示第一个值,从而误导最终用户,这也是可以修复的。

DevExpress WinForms中文使用教程图集
为组行提供自定义显示文本

 返回到设计时并订阅事件,检查事件的和参数。第一个参数指定当前正在处理的列,而第二个参数指示是否调用事件来自定义组行显示文本,参数 返回当前处理的组行。要更改组行的显示文本,使用事件的参数。

C#

using DevExpress.XtraGrid.Views.Grid;
//...
private void gridView_CustomColumnDisplayText(object sender, DevExpress.XtraGrid.Views.Base.CustomColumnDisplayTextEventArgs e) {
GridView view = sender as GridView;
if (view == null) return;
if (e.Column.FieldName == "Order Sum" && e.IsForGroupRow) {
double rowValue = Convert.ToDouble(view.GetGroupRowValue(e.GroupRowHandle, colOrderSum));
double val = Math.Floor(rowValue / 100);
if (val >= 10)
e.DisplayText = string.Format(">= {0:c} ", val * 100);
else e.DisplayText = string.Format("{0:c} - {1:c} ", val * 100, (val + 1) * 100 - 0.01);
}
}

 运行应用程序并再次按Order Sum列对数据进行分组,组行现在将显示正确标识间隔的自定义文本。

DevExpress WinForms中文使用教程图集

关于慧都科技

慧都是⼀家⾏业数字化解决⽅案公司,专注于软件、⽯油与⼯业领域,以深⼊的业务理解和⾏业经验,帮助企业实现智能化转型与持续竞争优势。

 慧都科技是DevExpress的中国区的合作伙伴,DevExpress作为用户界面领域的优秀产品,帮助企业高效构建权限管理、数据可视化(如网格/图表/仪表盘)、跨平台系统(WinForms/ASP.NET/.NET MAUI)及行业定制解决方案,加速开发并强化交互体验。


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@defefr.cn

文章转载自:慧都网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP