2025-08-20 12:10:13 +08:00
|
|
|
|
using System.Windows.Input;
|
|
|
|
|
|
|
2026-01-02 17:30:41 +08:00
|
|
|
|
namespace Melskin.Utilities;
|
2025-08-20 12:10:13 +08:00
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 一个简单的ICommand实现,用于传递动作。
|
|
|
|
|
|
/// </summary>
|
2025-08-24 13:49:55 +08:00
|
|
|
|
internal class RelayCommand : ICommand
|
2025-08-20 12:10:13 +08:00
|
|
|
|
{
|
2025-10-10 11:19:58 +08:00
|
|
|
|
private readonly Action<object?> execute;
|
2025-08-20 12:10:13 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 当命令的可执行状态更改时发生的事件。
|
|
|
|
|
|
/// 此事件通知UI,当命令的CanExecute方法返回值发生变化时,需要重新查询命令的状态。
|
|
|
|
|
|
/// </summary>
|
2025-10-04 08:52:23 +08:00
|
|
|
|
#pragma warning disable CS0067
|
2025-08-20 12:10:13 +08:00
|
|
|
|
public event EventHandler? CanExecuteChanged;
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 一个简单的ICommand实现,用于传递动作。此命令始终可以执行。
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
public RelayCommand(Action<object> execute) => this.execute = execute;
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 判断命令是否可以执行。
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="parameter">传递给命令的参数。</param>
|
|
|
|
|
|
/// <returns>返回一个布尔值,指示命令是否能够执行。对于此实现,总是返回true。</returns>
|
2025-10-04 08:52:23 +08:00
|
|
|
|
public bool CanExecute(object? parameter) => true;
|
2025-08-20 12:10:13 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 执行命令。
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="parameter">传递给命令的参数。</param>
|
2025-10-10 11:19:58 +08:00
|
|
|
|
public void Execute(object? parameter) => execute(parameter);
|
2025-08-20 12:10:13 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 一个简单的ICommand实现,用于传递动作。此命令始终可以执行。
|
|
|
|
|
|
/// </summary>
|
2025-08-24 13:49:55 +08:00
|
|
|
|
internal class RelayCommand<T> : ICommand
|
2025-08-20 12:10:13 +08:00
|
|
|
|
{
|
2025-10-10 11:19:58 +08:00
|
|
|
|
private readonly Action<T?> execute;
|
|
|
|
|
|
private readonly Predicate<T?>? canExecute;
|
2025-08-20 12:10:13 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 一个简单的ICommand实现,用于传递动作。此命令始终可以执行。
|
|
|
|
|
|
/// </summary>
|
2025-10-10 11:19:58 +08:00
|
|
|
|
public RelayCommand(Action<T?> execute, Predicate<T?>? canExecute = null)
|
2025-08-20 12:10:13 +08:00
|
|
|
|
{
|
|
|
|
|
|
this.execute = execute ?? throw new ArgumentNullException(nameof(execute));
|
|
|
|
|
|
this.canExecute = canExecute;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 当命令的可执行状态更改时触发的事件。
|
|
|
|
|
|
/// 此事件允许UI元素订阅并响应命令可执行性变化,从而能够适时更新其状态(如启用或禁用按钮)。
|
|
|
|
|
|
/// 通过将此事件与CommandManager.RequerySuggested关联,可以确保每当应用程序中的命令状态可能改变时,UI都会自动检查命令是否仍然可执行。
|
|
|
|
|
|
/// </summary>
|
2025-10-04 08:52:23 +08:00
|
|
|
|
public event EventHandler? CanExecuteChanged
|
2025-08-20 12:10:13 +08:00
|
|
|
|
{
|
|
|
|
|
|
add => CommandManager.RequerySuggested += value;
|
|
|
|
|
|
remove => CommandManager.RequerySuggested -= value;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 判断命令是否可以执行。
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="parameter">传递给命令的参数。</param>
|
|
|
|
|
|
/// <returns>返回一个布尔值,指示命令是否能够执行。对于此实现,总是返回true。</returns>
|
2025-10-10 11:19:58 +08:00
|
|
|
|
public bool CanExecute(object? parameter) => canExecute == null || canExecute((T?)parameter);
|
2025-08-20 12:10:13 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 执行命令。
|
|
|
|
|
|
/// </summary>
|
|
|
|
|
|
/// <param name="parameter">传递给命令的参数。</param>
|
2025-10-10 11:19:58 +08:00
|
|
|
|
public void Execute(object? parameter)
|
2025-10-04 08:52:23 +08:00
|
|
|
|
{
|
2025-10-10 11:19:58 +08:00
|
|
|
|
execute((T?)parameter);
|
2025-10-04 08:52:23 +08:00
|
|
|
|
}
|
2025-08-20 12:10:13 +08:00
|
|
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
|
|
/// 通知命令管理器重新查询此命令的CanExecute状态。
|
|
|
|
|
|
/// 此方法用于在命令执行条件可能已更改时更新UI。
|
|
|
|
|
|
/// </summary>
|
2025-10-04 08:52:23 +08:00
|
|
|
|
#pragma warning disable CS0067
|
2025-08-20 12:10:13 +08:00
|
|
|
|
public void RaiseCanExecuteChanged() => CommandManager.InvalidateRequerySuggested();
|
|
|
|
|
|
}
|