示例:推荐一个应用Adorner做的消息对话框

发布于:2024-06-20 ⋅ 阅读:(147) ⋅ 点赞:(0)

一、目的:开发过程中,经常用到对话框,下面演示一个应用Adorner做的带遮盖层蒙版的控件,使用MainWindow的Adorner实现不需要额外定义遮盖层,使用Object作为参数,可自定义DataTemplate定制消息显示样式


二、效果

二、使用方式

1、安装nuget包:H.Modules.Messages.Dialog

2、执行代码 

        private async void Button_AdornerDialog_Click(object sender, RoutedEventArgs e)
        {
            await AdornerDialog.ShowPresenter("我是AdornerDialog");
        }

AdornerDialog会使用MainWindow的Adorner层去显示遮罩层的对话框,不需要额外配置可以直接使用

更多其他可选设置

            var r = await AdornerDialog.ShowPresenter("我是AdornerDialog", x =>
            {
                x.DialogButton = DialogButton.SumitAndCancel;
                x.Height = 100;
                x.VerticalContentAlignment = VerticalAlignment.Top;
                x.Padding = new Thickness(20);
                });
            if (r == true)
                System.Diagnostics.Debug.WriteLine("点击了确定");
            if (r == null)
                System.Diagnostics.Debug.WriteLine("点击了关闭按钮");
            if (r == true)
                System.Diagnostics.Debug.WriteLine("点击了取消");

效果如下 

 

四、更多示例

源码位置

WPF-Control/Source/Modules/H.Modules.Messages.Dialog/AdonerDialog/AdornerDialog.cs at main · HeBianGu/WPF-Control · GitHub

五、需要了解的知识点

Adorner 类 (System.Windows.Documents) | Microsoft Learn

六、源码地址

GitHub - HeBianGu/WPF-ControlDemo: 示例

GitHub - HeBianGu/WPF-ControlBase: Wpf封装的自定义控件资源库

GitHub - HeBianGu/WPF-Control: WPF轻量控件和皮肤库

七、了解更多

System.Windows.Controls 命名空间 | Microsoft Learn

https://github.com/HeBianGu

HeBianGu的个人空间-HeBianGu个人主页-哔哩哔哩视频


网站公告

今日签到

点亮在社区的每一天
去签到