117 lines
5.5 KiB
C#
117 lines
5.5 KiB
C#
namespace NeoUI.Controls;
|
||
|
||
|
||
// 定义通知类型
|
||
/// <summary>
|
||
/// 该枚举定义了ToastControl控件中可以使用的不同类型的通知。每种类型对应不同的视觉样式和图标,用于在用户界面上显示不同性质的消息,如成功、信息、警告或错误。
|
||
/// </summary>
|
||
public enum ToastType
|
||
{
|
||
/// <summary>
|
||
/// 表示成功通知的枚举值。当设置为该值时,ToastControl控件将使用预定义的颜色和图标来显示一条成功消息。背景颜色为浅绿色(#F0F9EB),前景颜色为深绿色(#67C23A),并且会显示一个表示成功的图标。
|
||
/// </summary>
|
||
Success,
|
||
|
||
/// <summary>
|
||
/// 表示信息通知的枚举值。当设置为该值时,ToastControl控件将使用预定义的颜色和图标来显示一条普通消息。背景颜色为浅蓝色(#E6F7FF),前景颜色为深蓝色(#409EFF),并且会显示一个表示信息的图标。
|
||
/// </summary>
|
||
Info,
|
||
|
||
/// <summary>
|
||
/// 表示错误通知的枚举值。当设置为该值时,ToastControl控件将使用预定义的颜色和图标来显示一条错误消息。背景颜色为浅红色(#FEF2F2),前景颜色为深红色(#F56C6C),并且会显示一个表示错误的图标。
|
||
/// </summary>
|
||
Error,
|
||
|
||
/// <summary>
|
||
/// 表示警告通知的枚举值。当设置为该值时,ToastControl控件将使用预定义的颜色和图标来显示一条警告消息。背景颜色为浅黄色(#FDF6EC),前景颜色为橙色(#E6A23C),并且会显示一个表示警告的图标。
|
||
/// </summary>
|
||
Warning
|
||
}
|
||
|
||
/// <summary>
|
||
/// ToastControl 是一个自定义的 WPF 控件,用于在用户界面中显示简短的通知消息。它支持不同类型的通知(如成功、信息、警告和错误),并能够根据通知类型自动调整其视觉样式。
|
||
/// </summary>
|
||
public partial class ToastControl
|
||
{
|
||
/// <summary>
|
||
///
|
||
/// </summary>
|
||
public ToastControl()
|
||
{
|
||
InitializeComponent();
|
||
}
|
||
|
||
// 依赖属性,用于从外部设置消息和类型
|
||
/// <summary>
|
||
/// 该依赖属性用于存储和获取ToastControl控件中显示的消息文本。通过设置此属性,可以动态地更改用户界面上显示的通知消息内容。
|
||
/// </summary>
|
||
public static readonly DependencyProperty MessageProperty = DependencyProperty.Register(
|
||
nameof(Message), typeof(string), typeof(ToastControl), new PropertyMetadata(string.Empty, OnMessageChanged));
|
||
|
||
/// <summary>
|
||
/// 该依赖属性用于存储和获取ToastControl控件中显示的通知类型。通过设置此属性,可以指定通知的种类(如成功、信息、警告或错误),从而影响通知的视觉表现,比如颜色和图标。
|
||
/// </summary>
|
||
public static readonly DependencyProperty TypeProperty = DependencyProperty.Register(
|
||
nameof(Type), typeof(ToastType), typeof(ToastControl), new PropertyMetadata(ToastType.Info, OnTypeChanged));
|
||
|
||
/// <summary>
|
||
/// 用于获取或设置ToastControl控件中显示的消息文本。通过更改此属性,可以动态更新用户界面上的通知消息内容。
|
||
/// </summary>
|
||
public string Message
|
||
{
|
||
get => (string)GetValue(MessageProperty);
|
||
set => SetValue(MessageProperty, value);
|
||
}
|
||
|
||
/// <summary>
|
||
/// 该依赖属性用于存储和获取ToastControl控件中显示的通知类型。通过设置此属性,可以指定通知的种类(如成功、信息、错误或警告),从而影响用户界面上通知的视觉呈现方式。
|
||
/// </summary>
|
||
public ToastType Type
|
||
{
|
||
get => (ToastType)GetValue(TypeProperty);
|
||
set => SetValue(TypeProperty, value);
|
||
}
|
||
|
||
private static void OnMessageChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
|
||
{
|
||
((ToastControl)d).MessageTextBlock.Text = (string)e.NewValue;
|
||
}
|
||
|
||
// 当类型改变时,更新颜色和图标
|
||
private static void OnTypeChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
|
||
{
|
||
var control = (ToastControl)d;
|
||
var icon = "";
|
||
Brush background = Brushes.Gray;
|
||
Brush foreground = Brushes.White;
|
||
|
||
switch ((ToastType)e.NewValue)
|
||
{
|
||
case ToastType.Success:
|
||
icon = "\uE930"; // Success icon
|
||
background = new SolidColorBrush(Color.FromRgb(240, 249, 235));
|
||
foreground = new SolidColorBrush(Color.FromRgb(103, 194, 58));
|
||
break;
|
||
case ToastType.Info:
|
||
icon = "\uE946"; // Info icon
|
||
background = new SolidColorBrush(Color.FromRgb(237, 246, 253));
|
||
foreground = new SolidColorBrush(Color.FromRgb(64, 158, 255));
|
||
break;
|
||
case ToastType.Warning:
|
||
icon = "\uE7BA"; // Warning icon
|
||
background = new SolidColorBrush(Color.FromRgb(253, 246, 236));
|
||
foreground = new SolidColorBrush(Color.FromRgb(230, 162, 60));
|
||
break;
|
||
case ToastType.Error:
|
||
icon = "\uEA39"; // Error icon
|
||
background = new SolidColorBrush(Color.FromRgb(254, 242, 242));
|
||
foreground = new SolidColorBrush(Color.FromRgb(245, 108, 108));
|
||
break;
|
||
}
|
||
control.IconTextBlock.Text = icon;
|
||
control.IconTextBlock.Foreground = foreground;
|
||
control.RootBorder.Background = background;
|
||
control.RootBorder.BorderBrush = background;
|
||
}
|
||
}
|