zoukankan      html  css  js  c++  java
  • 如何为WPF数据网格创建自定义筛选器编辑器对话框?

    下载DevExpress v20.2完整版

    DevExpress技术交流群3:700924826      欢迎一起进群讨论

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

    问题:

    从v19.1开始,网格控件使用新的FilterEditorControl。UseLegacyFilterEditor设置为True,从而可以触发FilterEditorCreated事件。 如果要自定义新的FilterEditorControl,是否还有另一个事件可以使用?

    希望能够创建由DxGrid控件使用的自定义FilterEditorControl对话框表单,使用更新的FilterEditorControl时,如何完成利用网格引发的事件来拦截创建的旧版FilterControl并将其注入自定义形式?

    解决方案:

    要完成此任务,可以使用TableView的FilterEditorDialogServiceTemplate属性,该属性将允许您重新定义FilterEditorContol的默认对话框服务。 此代码段演示了默认实现:

    XAML

    <dxg:TableView.FilterEditorDialogServiceTemplate>
    <DataTemplate xmlns:dx="http://schemas.devexpress.com/winfx/2008/xaml/core"
    xmlns:dxfuit="http://schemas.devexpress.com/winfx/2008/xaml/core/filteringui/themekeys"
    xmlns:dxn="http://schemas.devexpress.com/winfx/2008/xaml/core/internal">
    <ContentControl>
    <dx:DialogService DialogWindowStartupLocation="CenterOwner"
    ViewTemplate="{DynamicResource {dxfuit:FilterEditorThemeKey ResourceKey=FilterEditorDialogServiceViewTemplate}}">
    <dx:DialogService.DialogStyle>
    <Style TargetType="{x:Type dx:ThemedWindow}">
    <Setter Property="dxn:ThemedWindowOptions.ShowOverPopups" Value="True" />
    <Setter Property="ShowInTaskbar" Value="False" />
    <Setter Property="WindowStyle" Value="ToolWindow" />
    <Setter Property="ShowIcon" Value="False" />
    <Setter Property="UseLayoutRounding" Value="True" />
    <Setter Property="Width" Value="500" />
    <Setter Property="Height" Value="350" />
    <Setter Property="MinWidth" Value="500" />
    <Setter Property="MinHeight" Value="350" />
    </Style>
    </dx:DialogService.DialogStyle>
    </dx:DialogService>
    </ContentControl>
    </DataTemplate>
    </dxg:TableView.FilterEditorDialogServiceTemplate>

    要显示自己的对话框按钮,您将需要启用ThemedWindowOptions.UseCustomDialogFooter属性:

    XAML

    <dx:DialogService.DialogStyle>
    <Style TargetType="{x:Type dx:ThemedWindow}">
    <Setter Property="dxn:ThemedWindowOptions.UseCustomDialogFooter" Value="True"/>
    <.../>

    之后,您可以覆盖FilterEditorTemplate属性并定义自定义按钮。

    XAML

    <dxg:TableView.FilterEditorTemplate>
    <DataTemplate xmlns:dxfui="http://schemas.devexpress.com/winfx/2008/xaml/core/filteringui">
    <Grid>
    <Grid.RowDefinitions>
    <RowDefinition/>
    <RowDefinition Height="Auto"/>
    </Grid.RowDefinitions>
    <dxfui:FilterEditorControl x:Name="filterControl" />
    <dx:ThemedWindowDialogButtonsControl Grid.Row="1">
    <dx:ThemedWindowDialogButton Margin="6 0 0 0"
    Content="Cancel"
    DialogResult="Cancel"
    IsCancel="True" />
    <dx:ThemedWindowDialogButton Margin="6 0 0 0"
    Content="Test"
    DialogResult="OK"
    Command="{DXCommand Execute='@e(filterControl).ApplyFilter()'}"
    IsDefault="True" />
    </dx:ThemedWindowDialogButtonsControl>
    </Grid>
    </DataTemplate>
    </dxg:TableView.FilterEditorTemplate>

    上DevExpress中文网,获取第一手最新产品资讯!

  • 相关阅读:
    【Mongodb教程 第九课 】MongoDB 删除文档
    【Mongodb教程 第八课 】MongoDB 更新文档
    【Mongodb教程 第七课 】MongoDB 查询文档
    【Mongodb教程 第六课 】MongoDB 插入文档
    【Mongodb教程 第五课 】MongoDB 删除集合
    【Mongodb教程 第四课 】MongoDB 创建集合
    【Mongodb教程 第三课 】MongoDB 删除数据库
    【Mongodb教程 第二课 】 MongoDB 创建数据库 use 命令
    题解 P2821 【变幻数】
    题解 P6249 【神帖】
  • 原文地址:https://www.cnblogs.com/AABBbaby/p/14754013.html
Copyright © 2011-2022 走看看