8.自定义分组信息
在上一篇文章我们已经介绍了分组:
本文就在这个基础上介绍如何自定义分组信息。
默认情况下,C1DataGrid总是根据匹配的条件分组,有时候需要覆盖并且提供自己的逻辑。
这个时候,可以使用GroupConverter属性从IValueConverter继承。这个grouping converter将应用到每个数据项,允许控制分组和每组的项目。
为了自定义分组有如下连个步骤:
1.创建converter.
将值放到需求的分组,设置GroupConverter属性给需求的列。比如,创建日期分组。
c1DataGrid1.Columns["Received"].GroupConverter = new MyDateGroupConverter(); public class MyDateGroupConverter : IValueConverter { public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { DateTime date = (DateTime)value; if(date.DayOfYear == DateTime.Now.DayOfYear) { return "Date: Today"; } else if (date.DayOfYear == DateTime.Now.DayOfYear - 1) { return "Date: Yesterday"; } else { return "Date: Older"; } } public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { return value; } }
2.创建给分组行的UI的Converter。
对于文字,通过GroupContentConverter属性来设置。比如下面代码参考:
c1DataGrid1.Columns["Received"].GroupContentConverter = new MyDateGroupContentConverter(); public class MyDateGroupContentConverter : IValueConverter { public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { // just simple string, no conversion needed return value; } public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture) { return value; } }
3.对于特定列的分组
通过CanUserGroup属性,和在运行时设置GroupBy方法。
代码参考:
// group by a column c1DataGrid1.GroupBy(c1DataGrid1.Columns["Received"], DataGridSortDirection.Descending);
有关本文讲解的分组,可以参考如下Demo:
DataGrid_CustomGrouping.zip (13.84 kb)
C1DataGrid的在线英文产品文档地址:
http://helpcentral.componentone.com/nethelp/C1datagridWPF/
如果你对C1DataGrid感兴趣,请到我们的官网下载最新版本:/download/?pid=6
如果你有疑问,可以到GCDN论坛获得技术支持:http://gcdn.grapecity.com.cn/showforum-138.html