如何用界面组件DevExpress WPF创建Excel式的过滤功能?

DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。

DevExpress WPF在v19.2版本中添加了新的excel样式下拉过滤器,旨在简化使用,并为最终用户提供各种数据分析增强功能,这个下拉过滤器还被设计为为开发人员扩展定制功能。

DevExpress WPF v22.1正式版下载

在v19.2及之后的版本中,这个下拉过滤器默认在以下几个控件中使用:

  • Data Grid
  • TreeList
  • Pivot Grid
如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第1张图片

接下来我们将详细介绍Excel样式下拉过滤器的功能。

记录计数显示

在应用筛选器时,您可能希望知道有多少条记录与给定筛选器值匹配,Excel-Style Drop-Down Filter在过滤器值旁边显示一个记录计数。

日期时间间隔

Excel-Style Drop-Down Filter允许您在其中组合不同的日期间隔。

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第2张图片

数据分析过滤器

您可以在xcel-Style Drop-Down Filter中应用以下数字过滤器:

  • Top / Bottom N
  • Above / Below Average
  • Unique / Duplicate

这些筛选器允许分析数据网格中的信息,而无需构造复杂的筛选条件。

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第3张图片

条件格式过滤器

Data Grid和TreeList允许您指定条件格式规则并给予这些规则应用过滤器。

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第4张图片

分组过滤器

在Data Grid和TreeList中,可以对来自两个或多个列的筛选值进行分组,并将结果显示为一个分层检查列表,这个功能允许用户根据多个列筛选数据。

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第5张图片

要合并此功能,请将ColumnBase.FilterPopupGroupFields属性设置为针对筛选器值进行分组的字段的名称,名称之间用逗号、分号或空格隔开,字段名的顺序决定了组内的层次结构。







...

预定义的过滤器

Excel-style Drop-Down Filter允许您附带预定义的过滤器,预定义过滤器显示在Filter Rules选项卡中。

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第6张图片

Data Grid和TreeList允许您使用ColumnBase.PredefinedFilters 属性指定这样的过滤器。










自定义

使用 ColumnBase.CustomColumnFilterPopupTemplate 属性来指定一个自定义数据模板,在这个模板中,定义一个筛选器元素并指定其设置。

自定义过滤器弹出内容

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第7张图片



...







...

自定义运算符列表

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第8张图片







void OnExcelStyleFilterQueryOperators(object sender,
ExcelStyleFilterElementQueryOperatorsEventArgs e) {

if(e.FieldName == "OrderDate") {
e.Operators.Clear();
e.Operators.Add(new ExcelStyleFilterElementOperatorItem(
ExcelStyleFilterElementOperatorType.Equal));
e.Operators.Add(new ExcelStyleFilterElementOperatorItem(
ExcelStyleFilterElementOperatorType.NotEqual));
}
}

创建自定义运算符

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第9张图片







const string CustomFunctionName = "LastYears";
var currentYear = DateTime.Now.Year;

ICustomFunctionOperatorBrowsable customFunction = CustomFunctionFactory.Create(
CustomFunctionName, (DateTime date, int threshold) => {
return currentYear >= date.Year && currentYear - date.Year <= threshold;
}
);

void OnExcelStyleFilterQueryOperators(object sender,
ExcelStyleFilterElementQueryOperatorsEventArgs e) {

if(e.FieldName == "OrderDate") {
// ...
var customFunctionEditSettings = new BaseEditSettings[] {
new TextEditSettings { MaskType = MaskType.Numeric, Mask = "D",
MaskUseAsDisplayFormat = true }
};
e.Operators.Add(new ExcelStyleFilterElementOperatorItem(CustomFunctionName,
customFunctionEditSettings) { Caption = "Last Years" });
}
}

自定义操作数模板

如何用界面组件DevExpress WPF创建Excel式的过滤功能?_第10张图片

UserControl.Resources>















...








void OnExcelStyleFilterQueryOperators(object sender,
ExcelStyleFilterElementQueryOperatorsEventArgs e) {

if(e.FieldName == "Quantity") {
var template = (DataTemplate)FindResource("ternaryTemplate");
e.Operators[ExcelStyleFilterElementOperatorType.Between].OperandTemplate =
template;
e.Operators[ExcelStyleFilterElementOperatorType.NotBetween].OperandTemplate =
template;
}
}

你可能感兴趣的:(UI开发,devexpress,c#,wpf,excel)