DevExpress WPF中文教程:Data Grid - 如何使用虚拟源?(四)

DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过DevExpress WPF控件来实现。

本文将为大家一步一步演示如何在一个MVVM应用程序中使用虚拟源。

注意 :本教程使用Issues Service作为示例数据源,使用InfiniteAsyncSource作为虚拟数据源。

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

Step 4:显示摘要

您可以显示关于行组或单个数据列的摘要信息,完成以下步骤:

  1. 在虚拟源中处理摘要。

  2. 在GridControl中显示摘要。

摘要类型

Issues Service允许您获得:

  • 行的总数。
  • 最后创建的DateTime对象。

C#

cs 复制代码
public class IssuesSummaries {
public int Count { get; private set; }
public DateTime? LastCreated { get; private set; }
}
实现细节

在虚拟源中处理摘要

  1. 创建一个使用IssuesService.GetSummariesAsync方法从数据源获取摘要的任务。

  2. 使用Summaries属性获取GridControl摘要项。

  3. 创建GetTotalSummaries命令。

  4. 获取与GridControl摘要项对应的数据源摘要列表,并将该列表分配给Result属性。

  5. 将GetTotalSummaries命令绑定到InfiniteAsyncSource.GetTotalSummariesCommand

C#

cs 复制代码
[Command]
public void GetTotalSummaries(GetSummariesAsyncArgs args) {
args.Result = GetTotalSummariesAsync(args);
}
static async Task<object[]> GetTotalSummariesAsync(GetSummariesAsyncArgs args) {
var summaryValues = await IssuesService.GetSummariesAsync((IssueFilter)args.Filter);
return args.Summaries.Select(x => {
if(x.SummaryType == SummaryType.Count)
return (object)summaryValues.Count;
if(x.SummaryType == SummaryType.Max && x.PropertyName == "Created")
return summaryValues.LastCreated;
throw new InvalidOperationException();
}).ToArray();
}

xml

XML 复制代码
<dxg:GridControl.ItemsSource>
<dx:InfiniteAsyncSource ElementType="{x:Type local:IssueData}"
FetchRowsCommand="{Binding FetchIssuesCommand}"
GetUniqueValuesCommand="{Binding GetUniqueValuesCommand}"
GetTotalSummariesCommand="{Binding GetTotalSummariesCommand}"/>
</dxg:GridControl.ItemsSource>

显示固定摘要面板

启用DataViewBase.ShowFixedTotalSummary属性来显示固定摘要面板:

xml

XML 复制代码
<dxg:GridControl.View>
<dxg:TableView ShowFixedTotalSummary="True"/>
</dxg:GridControl.View>

显示总摘要

指定GridControl.TotalSummary属性在GridControl中显示总的摘要:

xml

XML 复制代码
<dxg:GridControl.TotalSummary>
<dxg:GridSummaryItem SummaryType="Count" Alignment="Right"/>
<dxg:GridSummaryItem SummaryType="Max" FieldName="Created"
DisplayFormat="{}Last created: {0}"
Alignment="Right"/>
</dxg:GridControl.TotalSummary>
显示自定义摘要

Issues Service可以计算Median和StdDev值:

C#

cs 复制代码
public class IssuesSummaries {
// ...
public double VotesMedian { get; private set; }
public double VotesStdDev { get; private set; }
}
  1. 在虚拟源中的过程摘要:

C#

cs 复制代码
[Command]
public void GetTotalSummaries(GetSummariesAsyncArgs args) {
args.Result = GetTotalSummariesAsync(args);
}
static async Task<object[]> GetTotalSummariesAsync(GetSummariesAsyncArgs args) {
var summaryValues = await IssuesService.GetSummariesAsync((IssueFilter)args.Filter);
return args.Summaries.Select(x => {
if (x.SummaryType == SummaryType.Count)
return (object)summaryValues.Count;
if (x.SummaryType == SummaryType.Max && x.PropertyName == "Created")
return summaryValues.LastCreated;

// Custom Summaries
if (x.SummaryType == SummaryType.Custom && x.PropertyName == "Votes") {
var tag = x.Tag as string;
if (tag == "Median")
return summaryValues.VotesMedian;
if (tag == "StdDev")
return summaryValues.VotesStdDev;
}
throw new InvalidOperationException();
}).ToArray();
}
  1. 在GridControl中显示摘要:

xml

XML 复制代码
<dxg:GridControl.TotalSummary>
<dxg:GridSummaryItem SummaryType="Count" Alignment="Right"/>
<dxg:GridSummaryItem SummaryType="Max" FieldName="Created"
DisplayFormat="{}Last created: {0}" Alignment="Right"/>
<!-- Custom Summaries -->
<dxg:GridSummaryItem SummaryType="Custom" Tag="StdDev" FieldName="Votes"
DisplayFormat="{}Votes StdDev={0}" Alignment="Right"/>
<dxg:GridSummaryItem SummaryType="Custom" Tag="Median" FieldName="Votes"
DisplayFormat="{}Votes Median={0}" Alignment="Right"/>
</dxg:GridControl.TotalSummary>
相关推荐
Psycho_MrZhang1 小时前
REST/gRPC/队列通信模式对比
wpf
我是唐青枫13 小时前
深入理解 C#.NET Interlocked.Increment:原子操作的核心
c#·.net
墨白曦煜15 小时前
Seata AT 模式:应用层回滚 vs 引擎层回滚
wpf
我是唐青枫18 小时前
深入理解 C#.NET Parallel:并行编程的正确打开方式
开发语言·c#·.net
TypingLearn18 小时前
Perigon.CLI 10.0 重磅发布【AspNetCore开发模板和辅助工具】
c#·.net·aspnetcore
博主花神20 小时前
【React】UI库Antd和Redux状态管理
react.js·ui·arcgis
mudtools1 天前
如何设计易维护、低学习成本的飞书.NET SDK组件
学习·.net·飞书
繁星流动 >_<1 天前
axure点击图标放大展示
ui·axure
航Hang*1 天前
Photoshop 图形与图像处理技术——第7章:滤镜的应用
图像处理·笔记·ui·photoshop
flysh051 天前
C#和.NET简介
开发语言·c#·.net