WPF动态创建消息弹窗,2秒自动消失

样式代码,放入App.xaml中

在这里插入图片描述

App.xaml

<Application x:Class="WpfSnqkGasAnalysis.App"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:local="clr-namespace:WpfSnqkGasAnalysis"
             StartupUri="Login.xaml">
    <Application.Resources>
        <ResourceDictionary Source="Dictionary1.xaml" />
    </Application.Resources>
</Application>

Dictionary1.xaml,消息框样式

  <!--消息提示框-->
    <Style x:Key="TextBlock_Alert" TargetType="TextBlock">
        <Setter Property="Background" Value="Lime"></Setter>
        <Setter Property="Padding" Value="20,10"></Setter>
        <Setter Property="FontSize" Value="18"></Setter>
         <Setter Property="Margin" Value="4"></Setter> 
        <Setter Property="HorizontalAlignment" Value="Center"></Setter>
        <Setter Property="VerticalAlignment" Value="Top"></Setter>
        <Setter Property="TextWrapping" Value="Wrap"></Setter>
        <!--<Setter Property="Panel.ZIndex" Value="3000"></Setter>-->        
    </Style>

后端代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Controls.Primitives;
using System.Windows.Media;
using System.Windows.Media.Animation;
using System.Windows.Threading;



namespace WpfSnqkGasAnalysis
{
    /// <summary>
    /// 消息框封装,消息2秒后消失
    /// </summary>
    /// 创建时间:2022年11月30日15:08:25。
    public static class ShowAlertHelpter
    {
         
        //上一次显示的top位置
        static double lastTop = 0;
        static double lastLeft = 0;

        //上一次显示时间
        static DateTime lastShowTime = DateTime.Now;

        /// <summary>
        /// 提示消息。消息2秒后消失
        /// </summary>
        /// <param name="msg">消息</param>        
        /// <param name="alwaysShow">是否一直显示</param>
        public static void ShowAlert(string msg,  bool alwaysShow = false)
        {
            //Grid grid = Application.Current.Windows[0].FindName("mainGrid") as Grid;          

            //Grid grid = null;
            //if (page is Window)
            //{
            //    Window window = (Window)page;
            //    grid = window.Content as Grid;
            //}
            //else if (page is Page)
            //{
            //    Page args = (Page)page;
            //    grid = args.Content as Grid;
            //}
            //else if (page is Grid)
            //{
            //    grid = page as Grid;
            //}

            Application.Current.Dispatcher.BeginInvoke(
               () =>
            {
	            Window? win = Application.Current.Windows[0];                
                //Grid grid = win?.Content as Grid;
                Grid grid = win.TryGetChildPartFromVisualTree<Grid>();
	            if (grid == null)
	            {
	                return;
	            }
	            
                //Popup使消息在最前面显示
                Popup popup = new Popup();
                popup.Placement = PlacementMode.Top;//显示位置
                popup.PopupAnimation = PopupAnimation.Fade;//渐入
                popup.AllowsTransparency = true;//设置Popup透明
                popup.Margin = new Thickness(10);
                popup.VerticalOffset = 200;
                popup.HorizontalOffset = 600;
                popup.HorizontalAlignment = HorizontalAlignment.Center;
                //popup.IsOpen = false;
                popup.IsOpen = true;
                popup.ToolTip = "点击关闭";

                TextBlock textBlock = new TextBlock();
                textBlock.Text = msg;
                textBlock.Style = (System.Windows.Style)grid.FindResource("TextBlock_Alert");

                //边框阴影
                System.Windows.Media.Effects.DropShadowEffect effect = new System.Windows.Media.Effects.DropShadowEffect();
                effect.BlurRadius = 20;
                effect.Color = Color.FromRgb(158, 158, 158);
                textBlock.Effect = effect;

                if (lastTop > 0 && (DateTime.Now - lastShowTime).TotalSeconds < 3)
                {
                    //字符多,增加偏移
                    double space = 50d;
                    if (msg.Length > 22)
                    {
                        space = 70d;
                    }
                    popup.HorizontalOffset = lastLeft + space;
                    popup.VerticalOffset = lastTop + space;
                }

                //一直显示消息
                if (alwaysShow || msg.Contains("失败") || msg.Contains("异常") || msg.Contains("出错")  || msg.Contains("error"))
                {
                    textBlock.Background = Brushes.Orchid;//红色背景
                    goto SKIP_END;
                }

                //消息提示自动消失
                DispatcherTimer timer = new DispatcherTimer();
                timer.Interval = TimeSpan.FromMilliseconds(2000);
                timer.Tick += (s, e) =>
                {
                    grid.Children.Remove(popup);
                    timer.Stop();

                    if (lastTop > 500)
                    {
                        lastTop = 0;
                        lastLeft = -200;
                    }
                };
                timer.Start();

            SKIP_END:
                lastTop = popup.VerticalOffset;
                lastLeft = popup.HorizontalOffset;
                lastShowTime = DateTime.Now;

                popup.Child = textBlock;
                grid.Children.Add(popup);

                //点击就移除
                popup.MouseLeftButtonUp += (s, e) =>
                {
                    grid.Children.Remove(popup);
                };

            });
        }

    }
}


调用显示消息

private void btnSearch_Click(object sender, RoutedEventArgs e)
{
	ShowAlertHelpter.ShowAlert("操作成功");
}		
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: 在WPF中,使用MVVM模式可以动态创建多种控件。MVVM是一种架构模式,将应用程序分为三个主要组成部分:模型(Model)、视图(View)和视图模型(ViewModel)。 首先,可以在视图模型中创建数据绑定属性,这些属性将用于动态创建控件。例如,可以创建一个名为"ControlType"的属性,用于指定要创建的控件类型。可以使用枚举类型或字符串来定义不同的控件类型。 接下来,在视图中,使用数据绑定将控件类型属性与控件的创建进行绑定。可以使用WPF的ItemControl控件,例如ListBox或ItemsControl,将视图模型中的控件类型属性绑定到控件的ItemsSource属性。这样,每当控件类型属性的值发生变化时,新的控件将被动态添加到视图中。 最后,通过控制模板(DataTemplate)或样式(Style)来定义不同控件类型的外观和行为。可以为每种控件类型创建对应的控制模板或样式,并绑定到视图模型中的控件类型属性。这样,每次创建新的控件时,该控件将自动应用相应的控制模板或样式。 需要注意的是,在MVVM模式中,控件的创建和定义应该尽量在视图模型中完成,而不是在视图中进行直接编写。这样可以提高应用程序的可测试性和可维护性,同时也使得视图与业务逻辑的解耦更加彻底。 总之,使用MVVM模式可以方便地动态创建多种控件。通过在视图模型中定义数据绑定属性和控件类型,然后在视图中进行数据绑定和控件模板的设置,就可以根据需要动态创建不同类型的控件,并保持应用程序的整洁和可扩展性。 ### 回答2: MVVM是一种设计模式,用于在WPF应用程序中实现数据与视图的分离。动态创建多种控件意味着根据需要在运行时生成不同类型的控件。 在MVVM中,可以通过ViewModel层来实现动态创建多种控件。首先,我们可以在ViewModel中定义一个属性,用于存储需要动态创建的控件类型。例如,可以使用一个字符串属性来表示要创建的控件类型的名称。 然后,在XAML中,我们可以使用数据绑定将ViewModel中的属性与控件的类型属性进行绑定。这样,当ViewModel中的属性值发生变化时,控件的类型也会相应改变。 接下来,我们可以使用一个DataTemplateSelector来根据控件的类型选择相应的数据模板。通过在XAML中定义多个数据模板,并使用DataTemplateSelector来根据控件类型选择合适的数据模板,我们可以实现在运行时动态创建多种控件。 最后,将ViewModel的属性与控件的数据模板进行绑定。这样,当ViewModel中的属性值改变时,控件会自动使用相应的数据模板进行渲染,从而实现动态创建多种控件的效果。 总结来说,通过在ViewModel中定义属性,使用数据绑定将属性与控件类型进行绑定,使用DataTemplateSelector选择控件的数据模板,并将属性与控件的数据模板进行绑定,可以实现在MVVM和WPF动态创建多种控件的功能。 ### 回答3: MVVM是一种软件架构模式,用于将应用程序的图形用户界面(GUI)从业务逻辑(业务逻辑)和数据库(数据)中解耦。在WPF中,MVVM是一种常用的模式,用于构建灵活、可扩展和易于测试的应用程序。 在MVVM模式下,动态创建多种控件是一种常见的需求。可以通过ViewModel中的命令和属性来实现。首先,在ViewModel中创建一个Properties集合,该集合用于存储需要动态创建的控件的属性,如名称、类型、值等。然后,使用ItemsControl或ListBox等控件绑定到Properties集合,并使用数据模板来定义每个属性的外观。 在数据模板中,可以使用数据绑定来设置控件的属性,以及使用WPF的资源和样式来自定义控件的外观。根据属性的类型,可以使用不同的控件来显示不同的内容,例如TextBox、ComboBox、CheckBox等。通过使用数据模板,可以根据需求动态地创建不同类型的控件,并将其与ViewModel中的属性进行绑定。 例如,假设我们需要动态创建一个属性为"Name"的TextBox和一个属性为"IsChecked"的CheckBox。可以在ViewModel的Properties集合中添加这两个属性,并在XAML中使用ItemsControl来绑定到Properties集合。然后,为TextBox和CheckBox创建数据模板,并使用数据绑定将它们与ViewModel中的对应属性绑定起来。通过这样的方式,我们可以根据需要动态地创建不同类型的控件。 总结起来,通过MVVM模式,在WPF中可以动态创建多种控件。我们可以使用ViewModel中的集合来存储需要创建的控件的属性,并使用数据模板来根据属性的类型创建不同的控件。这种方法使得在应用程序中可以灵活地根据需求生成不同类型的控件,并且能够保持UI逻辑与业务逻辑的解耦。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王焜棟琦

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值