Skip to content

PendingBox zh CN

末城via edited this page Jun 21, 2023 · 3 revisions

PendingBox 等待框

返回目录

适用于:   v1.1.12 或更新的版本

概述

类名:    PendingBox
命名空间:    Panuon.WPF.UI
位于:    SharedResources/Panuon.WPF.UI/Helpers/PendingBox.cs
静态类

提供一系列属性和方法, 用于显示等待框。
PendingBox 等待框 不依赖任何 Panuon.WPF.UI 中的资源字典,即使不引用 Control.xaml ,也可使用 PendingBox 等待框 或自定义它的样式。

滚动至示例


备注

自定义样式提示

CreateOnNewThread 属性为 True 时(它的默认值为 True), 你无法在等待框的内部样式中使用 Panuon.WPF.UI 中提供的任何资源(例如 Style),因为它们无法跨越线程。因此,PendingBox 等待框 是基于自定义或原生控件样式制作的。
除非将 CreateOnNewThread 属性显式设置为 False ,否则你也应当使用原生控件来完成样式设计。

注意

PendingBox 等待框 不会阻塞当前的进程。
默认情况下,等待框会在一个新的线程上启动。这意味着,即使你在打开等待框后执行一个UI线程上的耗时操作,等待框的UI线程也不会被干扰(即不会出现假死状态)。但如果你在调用 Show 方法后立即执行UI线程耗时操作,则可能会出现 owner 窗体遮罩层无法打开的情况(如果 owner 参数为 Panuon.WPF.UI.WindowX 类型),如果遇到这种情况,可以尝试在执行代码前,调用 await Task.Delay(300);

请注意,Panuon.WPF.UI.Configurations.PendingBoxSetting
Panuon.WPF.UI.PendingBoxSettings 是两个完全不同的类型(后者带s)。
要统一修改所有 PendingBox 等待框 的样式,你可以在 cs代码 中直接修改 PendingBoxSettings.Setting 属性中的内容,或者也可以选择像示例3 中那样,将属性定义放置在 App.xaml 中。在使用后一种方案时,你仍然可以在 cs代码 中使用前一种方案来覆盖属性的值。
如果要单独为某个 PendingBox 等待框 指定样式,请使用带有 setting 参数的 Show 重载方法,并在 cs代码 中创建 MessageBoxSetting 对象(或资源字典中创建,并使用 Application.Current.FindResource() 等类似的方法找到对象并传入(见示例2))。


方法

Show

该方法带有多个重载,请根据实际需要,选择合适的重载方法。
全部参数:    Window owner, string message, string caption, bool canCancel, MessageBoxXSetting setting
返回值:    Panuon.WPF.UI.IPendingHandler 显示一个等待框。
owner: 指定等待框的 Owner 窗体。如果此参数为空,等待框会显示在屏幕的中央。当此参数不为空时,等待框会显示在该参数窗体的中央。如果该参数窗体是 WindowX 窗体X 类型,等待框在打开和关闭时会自动控制该窗体的遮罩层。
message: 要显示的消息主体。
caption: 要显示的标题。
canCancel: 是否显示取消按钮并允许用户取消等待。
setting: 等待框的属性设定。如果此参数不为空,将不再使用 PendingBoxSettings.Setting 属性中的值。
返回值: 通过此手柄来控制等待框的文本内容、处理取消和关闭事件,或关闭等待框。


PendingBoxSetting 中的属性

InteropOwnersMask

类型:    System.Boolean
默认值:    True
获取或设置是否控制 owner 方法参数窗体的遮罩层(当 ownerWindowX 窗体X 类型时)。

CreateOnNewThread

类型:    System.Boolean
默认值:    True
获取或设置是否在新线程上打开等待框。当此属性值为 True 时,Panuon.WPF.UI会创建一个新的线程来承载等待框。这在执行UI线程长时操作时非常有用。
如果 owner 窗体的遮罩层无法及时打开,请尝试在执行代码前调用 await Task.Delay(300);

CancelButtonStyle

类型:    System.Windows.Style
默认值:    [见资源键[CancelButtonStyle](#CancelButtonStyle)]
获取或设置取消 Button 按钮 控件的样式。

WindowStyle

类型:    System.Windows.Style
默认值:    [见资源键[WindowStyle](#WindowStyle)]
获取或设置 Window 窗体 控件的样式。

SpinStyle

类型:    System.Windows.Style
默认值:    [见资源键[SpinStyle](#SpinStyle)]
获取或设置等待 Spin 等待中 控件的样式。

ContentTemplate

类型:    System.Windows.DataTemplate
默认值:    [见资源键[ContentTemplate](#ContentTemplate)]
获取或设置等待框的内容模板。

CancelButtonContent

类型:    System.Windows.Style
默认值:    [Cancel] / 取 消(zh-CN) / キャンセル(jp-JP)
获取或设置“取消”按钮的内容。


公开的资源键

有关如何使用资源键的更多内容, 请查看命名与约定-资源键
一些无法从外部访问的属性已被隐去。

CancelButtonStyleKey

资源键:    {ComponentResourceKey ResourceId=CancelButtonStyleKey, TypeInTargetAssembly={x:Type pu:PendingBox}}
缩略资源键:    {pu:PendingBox.CancelButtonStyleKey}

等待框取消按钮的样式。

<Style x:Key="{ComponentResourceKey ResourceId=CancelButtonStyleKey, TypeInTargetAssembly={x:Type pu:PendingBox}}"
       TargetType="Button">
    <Setter Property="BorderThickness"
            Value="0" />
    <Setter Property="Background"
            Value="#F1F1F1" />
    <!--如果你将PendingBox.Settings.CreateOnNewThread属性设置为False,则可以使用Panuon.WPF.UI中提供的按钮样式来代替自定义按钮样式。-->
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="Button">
                <Border Background="{TemplateBinding Background}"
                        BorderBrush="{TemplateBinding BorderBrush}"
                        BorderThickness="{TemplateBinding BorderThickness}">
                    <ContentPresenter Margin="20,7"
                                      VerticalAlignment="Center"
                                      HorizontalAlignment="Center" />
                </Border>
            </ControlTemplate>
        </Setter.Value>
    </Setter>
    <Style.Triggers>
        <Trigger Property="IsPressed"
                 Value="True">
            <Setter Property="Background"
                    Value="#FAFAFA" />
        </Trigger>
    </Style.Triggers>
</Style>

ContentTemplate

资源键全称:    {ComponentResourceKey ResourceId=ContentTemplateKey, TypeInTargetAssembly={x:Type pu:PendingBox}}
缩略资源键:    {pu:PendingBox.ContentTemplateKey}

等待框的内容模板。

<DataTemplate x:Key="{ComponentResourceKey ResourceId=ContentTemplateKey, TypeInTargetAssembly={x:Type pu:PendingBox}}">
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="Auto" />
            <RowDefinition />
            <RowDefinition Height="Auto" />
        </Grid.RowDefinitions>
        <TextBlock x:Name="PART_CaptionTextBlock"
                   Margin="5,5,0,0" />
        <Grid Grid.Row="1"
              Margin="40,20">
            <Grid.RowDefinitions>
                <RowDefinition />
                <RowDefinition Height="Auto" />
            </Grid.RowDefinitions>
            <Grid>
                <Grid.ColumnDefinitions>
                    <ColumnDefinition Width="Auto" />
                    <ColumnDefinition />
                </Grid.ColumnDefinitions>
                <local:Spin x:Name="PART_Spin" />
                <TextBlock x:Name="PART_MessageTextBlock"
                           Grid.Column="1"
                           Margin="20,0,0,0"
                           TextWrapping="Wrap"
                           HorizontalAlignment="Center"
                           VerticalAlignment="Center" />
            </Grid>
            <Button x:Name="PART_CancelButton"
                    Grid.Row="1"
                    Visibility="Collapsed"
                    HorizontalAlignment="Center"
                    Style="{x:Null}" />
        </Grid>
    </Grid>
</DataTemplate>

WindowStyle

资源键全称:    {ComponentResourceKey ResourceId=WindowStyleKey, TypeInTargetAssembly={x:Type pu:PendingBox}}
缩略资源键:    {x:Static pu:PendingBox.WindowStyleKey}

等待框窗体的样式。

<Style x:Key="{ComponentResourceKey ResourceId=WindowXStyleKey, TypeInTargetAssembly={x:Type pu:PendingBox}}"
       TargetType="pu:WindowX"
       BasedOn="{StaticResource {x:Static irs:StyleKeys.WindowXStyle}}">
    <Setter Property="pu:WindowXCaption.Buttons"
            Value="Close" />
    <Setter Property="MinWidth"
            Value="350" />
    <Setter Property="MaxWidth"
            Value="500" />
    <Setter Property="MaxHeight"
            Value="350" />
    <Setter Property="MinHeight"
            Value="200" />
    <Setter Property="SizeToContent"
            Value="WidthAndHeight" />
    <Setter Property="Padding"
            Value="15,0,15,15" />
    <Setter Property="ShowInTaskbar"
            Value="False" />
    <Setter Property="InteropOwnersMask"
            Value="True" />
    <Setter Property="ResizeMode"
            Value="NoResize" />
</Style>

SpinStyleKey

资源键全称:    {ComponentResourceKey ResourceId=SpinStyleKey, TypeInTargetAssembly={x:Type pu:PendingBox}}
缩略资源键:    {pu:PendingBox.SpinStyleKey}

等待框 Spin 控件 的样式。

<Style x:Key="{ComponentResourceKey ResourceId=SpinStyleKey, TypeInTargetAssembly={x:Type pu:PendingBox}}"
       TargetType="pu:Spin">
    <Setter Property="Width" Value="50" />
    <Setter Property="Height" Value="50" />
</Style>

示例

示例1

using Panuon.WPF.UI;
···

var handler = PendingBox.Show(this, "正在执行...", "提示");

示例2

将以下定义放置在 App.xaml 中的 ResourceDictionary 中(或其他资源字典文件中,但要确保在 App.xaml 中引用,或通过 cs代码 装填到 Application.Current.Resources.MergedDictionaries 中)。如果不清楚如何放置,请下载源代码并查看 Samples 项目。

xmlns:pu="https://opensource.panuon.com/wpf-ui"
xmlns:puconfig="clr-namespace:Panuon.WPF.UI.Configurations;assembly=Panuon.WPF.UI"
···

<puconfig:PendingBoxSetting x:Key="CustomPendingSetting"
                             CancelButtonContent="CANCEL" />
using Panuon.WPF.UI;
using Panuon.WPF.UI.Configurations;
···

var setting = Application.Current.FindResource("CustomPendingSetting") as PendingBoxSetting;
var handler = PendingBox.Show(this, "正在执行...", "提示", true, setting);

示例3

将以下定义放置在 App.xaml 中的 ResourceDictionary 中(或其他资源字典文件中,但要确保在 App.xaml 中引用,或通过 cs代码 装填到 Application.Current.Resources.MergedDictionaries 中)。如果不清楚如何放置,请下载源代码并查看 Samples 项目。

xmlns:pu="https://opensource.panuon.com/wpf-ui"
···

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
                    xmlns:pu="https://opensource.panuon.com/wpf-ui">
    <!--注意,出于某种未知的原因,无论是否在App.xaml中直接定义,都需要在根资源字典中再嵌套一层资源字典。-->
    <ResourceDictionary.MergedDictionaries>
        <ResourceDictionary>
            <!--x:Key的值是任意的,没有特殊要求-->
            <pu:PendingBoxSettings x:Key="pendingSetting">
                <pu:PendingBoxSettings.SpinStyle>
                    <Style BasedOn="{StaticResource {x:Static pu:PendingBox.SpinStyleKey}}" TargetType="pu:Spin">
                        <Setter Property="SpinStyle" Value="Ring2" />
                        <Setter Property="GlyphBrush" Value="#6CBCEA" />
                    </Style>
                </pu:PendingBoxSettings.SpinStyle>
                <pu:PendingBoxSettings.CancelButtonStyle>
                    <!--注意:PendingBox.Settings.CreateOnNewThread为True时,不能使用Panuon.WPF.UI中提供的按钮样式-->
                    <Style BasedOn="{StaticResource {x:Static pu:PendingBox.CancelButtonStyleKey}}"
                           TargetType="Button">
                        <Setter Property="Background" Value="#6CBCEA" />
                        <Setter Property="Foreground" Value="White" />
                        <Style.Triggers>
                            <Trigger Property="IsPressed" Value="True">
                                <Setter Property="Background" Value="#6CABEA" />
                            </Trigger>
                        </Style.Triggers>
                    </Style>
                </pu:PendingBoxSettings.CancelButtonStyle>
            </pu:PendingBoxSettings>
        </ResourceDictionary>
    </ResourceDictionary.MergedDictionaries>
</ResourceDictionary>

示例4

将以下定义放置在 App.xaml 中的 ResourceDictionary 中(或其他资源字典文件中,但要确保在 App.xaml 中引用,或通过 cs代码 装填到 Application.Current.Resources.MergedDictionaries 中)。如果不清楚如何放置,请下载源代码并查看 Samples 项目。

xmlns:pu="https://opensource.panuon.com/wpf-ui"
···

<ResourceDictionary xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
                    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
                    xmlns:pu="https://opensource.panuon.com/wpf-ui">
    <!--注意,出于某种未知的原因,无论是否在App.xaml中直接定义,都需要在根资源字典中再嵌套一层资源字典。-->
    <ResourceDictionary.MergedDictionaries>
        <ResourceDictionary>
            <!--x:Key的值是任意的,没有特殊要求-->
            <pu:PendingBoxSettings x:Key="pendingSettings">
                <pu:PendingBoxSettings.WindowStyle>
                    <Style TargetType="Window" BasedOn="{StaticResource {x:Static pu:PendingBox.WindowStyleKey}}">
                        <Setter Property="Padding" Value="20,0,20,20" />
                        <Setter Property="MinWidth" Value="300" />
                        <Setter Property="MinHeight" Value="180" />
                        <Setter Property="MaxWidth" Value="300" />
                        <Setter Property="MaxHeight" Value="180" />
                        <Setter Property="SizeToContent" Value="Manual" />
                        <Setter Property="Foreground" Value="White" />
                        <Setter Property="pu:WindowXCaption.Background" Value="Transparent" />
                        <Setter Property="BorderBrush" Value="Gray" />
                        <Setter Property="BorderThickness" Value="1" />
                        <Setter Property="Background" Value="#1E1E1E" />
                    </Style>
                </pu:PendingBoxSettings.WindowStyle>
                <pu:PendingBoxSettings.SpinStyle>
                    <Style TargetType="pu:Spin" BasedOn="{StaticResource {x:Static pu:PendingBox.SpinStyleKey}}">
                        <Setter Property="SpinStyle" Value="Ring2" />
                        <Setter Property="Width" Value="50" />
                        <Setter Property="Height" Value="50" />
                        <Setter Property="Margin" Value="0,0,0,20" />
                        <Setter Property="GlyphSize" Value="2" />
                        <Setter Property="GlyphBrush" Value="#1ABBEA" />
                    </Style>
                </pu:PendingBoxSettings.SpinStyle>
                <pu:PendingBoxSettings.ContentTemplate>
                    <DataTemplate>
                        <Grid VerticalAlignment="Center">
                            <Grid.RowDefinitions>
                                <RowDefinition Height="Auto" />
                                <RowDefinition Height="Auto" />
                                <RowDefinition />
                                <RowDefinition Height="Auto" />
                            </Grid.RowDefinitions>
                            <pu:Spin x:Name="PART_Spin" />
                            <TextBlock x:Name="PART_CaptionTextBlock" Grid.Row="1" Margin="5,5,0,0" extAlignment="Center" />
                            <TextBlock x:Name="PART_MessageTextBlock" Grid.Row="2" TextWrapping="Wrap" TextAlignment="Center" />
                            <Button x:Name="PART_CancelButton" Grid.Row="3" Visibility="Collapsed" HorizontalAlignment="Center" Style="{x:Null}" />
                        </Grid>
                    </DataTemplate>
                </pu:PendingBoxSettings.ContentTemplate>
            </pu:PendingBoxSettings>
        </ResourceDictionary>
    </ResourceDictionary.MergedDictionaries>
</ResourceDictionary>
using Panuon.WPF.UI;
···

var handler = PendingBox.Show(this, "正在执行...", "提示");