简易精晓,简单理解

命令(Command)

命令(Command)

2018/1/10 19:06:35

命令可以约束代码,还足以约束步骤逻辑。(事件的功用是发布和传唱一些音讯,对什么响应事件不做规定,每个接收者能够运用自己的所作所为来响应事件。也就是说事件不持有约束力)

2018/1/10 19:06:35

一声令下可以约束代码,还足以约束步骤逻辑。(事件的功能是宣布和散播一些消息,对什么样响应事件不做规定,每个接收者可以运用自己的行为来响应事件。也就是说事件不持有约束力)

命令系统的中央因素

·命令(Command):实际上就是促成了ICommand接口的类,平常接纳最多的是RoutedCommand类
·命令源(Command Source):实现了ICommandResource接口的类(Button)
·命令目的(Command Target):必须是促成了IInputCommand接口的类
·命令关联(Command
Binding):负责把外围逻辑与命令关联起来,比如执行以前对命令是否可以进行举办判定、命令执行后还有哪些后续工作等

一声令下系统的为主元素

·命令(Command):实际上就是兑现了ICommand接口的类,通常利用最多的是RoutedCommand类
·命令源(Command Source):实现了ICommandResource接口的类(Button)
·命令目的(Command Target):必须是贯彻了IInputCommand接口的类
·命令关联(Command
Binding):负责把外场逻辑与命令关联起来,比如执行在此之前对命令是否足以实施举行判定、命令执行后还有什么后续工作等

一声令下的利用

命令的接纳

1.创建命令类

即获取一个落实ICommand接口的类,假若命令与实际业务逻辑无关,则应用WPF类库中的RoutedCommand即可。假如想赢得与作业逻辑相关的专有命令,则需要成立RoutedCommand(或者ICommand)的派生类。

1.创制命令类

即获取一个落实ICommand接口的类,如若命令与实际工作逻辑无关,则采纳WPF类库中的RoutedCommand即可。假诺想得到与业务逻辑相关的专有命令,则需要创设RoutedCommand(或者ICommand)的派生类。

2.声称命令实例

技巧:一般景色下,只需要操作一个发令实例与之对应即可。因而先后中的命令多采纳单件格局(Singletone
Pattern)以压缩代码复杂度。

澳门新葡亰网址,2.注明命令实例

技术:一般意况下,只需要操作一个下令实例与之对应即可。因而先后中的命令多应用单件情势(Singletone
Pattern)以减掉代码复杂度。

3.点名命令源

命令源拥有命令和命令源五个特性。
同一个命令可以有五个源。
设若把命令指派给命令源,命令源就会受命令影响,命令不可能执行的时候作为命令源的控件不可用。革命临官发送命令的方法不尽相同,例如单机双击。

3.指定命令源

命令源拥有命令和命令源六个属性。
同一个指令可以有四个源。
一经把命令指派给命令源,命令源就会受命令影响,命令不可能进行的时候作为命令源的控件不可用。革命临官发送命令的方法不尽相同,例如单机双击。

4.点名命令目的

指令目的不是命令的属性而是命令源的属性。无论这几个命令源是否具备核心都会吸收这一个命令。假设没有点名命令目标,默认为当前问题对象就是命令目的。

4.点名命令目标

指令目的不是命令的习性而是命令源的特性。无论那么些命令源是否有所要旨都会收到这多少个命令。虽然没有点名命令目的,默认为当前热点对象就是命令目标。

5.装置命令关联(命令绑定)

WPf需要CommandBinding在实施前扶掖判断是不是足以推行,在实践后做一些风波来“打扫战场”。命令目的向命令关联发送路由事件,命令关联捕捉并拍卖路由事件,向命令反馈音讯。

5.装置命令关联(命令绑定)

WPf需要CommandBinding在履行前扶掖判断是不是足以实施,在实施后做一些事件来“打扫战场”。命令目的向命令关联发送路由事件,命令关联捕捉并拍卖路由事件,向命令反馈新闻。

1.ICommand接口包含三个方法和一个事变

Execute()方法包含应用程序逻辑(例如打印文档);
CanExecute()方法重回命令状态(命令可用再次来到true,不可用再次来到false);
CanExecuteChanged事件,命令状态改变时引发,这是提示信号,表示应该调用CanExecute()检查命令状态。

1.ICommand接口包含多少个点子和一个事变

Execute()方法包含应用程序逻辑(例如打印文档);
CanExecute()方法再次回到命令状态(命令可用再次回到true,不可用再次来到false);
CanExecuteChanged事件,命令状态改变时引发,那是提示信号,表示应该调用CanExecute()检查命令状态。

2.RoutedCommand类自动实现ICommmand接口的类

不含有其他应用程序逻辑,只代表命令。为事件冒泡和隧道添加了一些外加的根基结构

2.RoutedCommand类自动实现ICommmand接口的类

不包含其他应用程序逻辑,只代表命令。为事件冒泡和隧道添加了部分万分的基础结构

3.RoutedUICommand类继承自RoutedCommand类

用以所有文本的通令,只增添了Text属性

3.RoutedUICommand类继承自RoutedCommand类

用于所有文本的一声令下,只扩充了Text属性

执行命令

RoutedUIIcommand类没有其他编码的遵从,只表示命令。为触发命令,需要有命令源(也可应用代码)。为响应命令,需要有指令绑定,命令绑定将执行转发给普通的事件处理程序。

执行命令

RoutedUIIcommand类没有此外编码的机能,只表示命令。为触发命令,需要有命令源(也可采取代码)。为响应命令,需要有发号施令绑定,命令绑定将举办转发给普通的事件处理程序。

1.命令源

ICommandSource定义了两个特性:
·Command:指向连接的通令,必需
·CommandParameter:提供其他希望随命令发送的多寡
·CommandTarget:确定将在其中执行命令的要素
譬如说:下面的按钮使用Command属性连接到ApplicationCommands.New命令:

<Button Command="ApplicationCommands.New">New</Button>
1.命令源

ICommandSource定义了五个特性:
·Command:指向连接的一声令下,必需
·CommandParameter:提供任何希望随命令发送的数目
·CommandTarget:确定将在里头执行命令的元素
诸如:下边的按钮使用Command属性连接到ApplicationCommands.New命令:

<Button Command="ApplicationCommands.New">New</Button>
2.命令绑定

明确:
·当命令被触发时执行什么样操作
·怎么样规定命令是否能被执行(可选)
·命令在啥地方起功效

2.指令绑定

明确:
·当命令被触发时执行什么样操作
·如何确定命令是否能被执行(可选)
·命令在何方起效果

命令实例:

概念一个指令,使用Button来发送这一个命令,当命令送达TextBox时,TextBox被清空(假诺没有文字则不发送命令)
·界面代码:

<Window x:Class="WpfApplication1.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="Command"
    Background="LightBlue" Height="350" Width="525">
<StackPanel x:Name="stackPanel">
    <Button x:Name="button1" Content="Send Command" Margin="5"/>
    <TextBox x:Name="textBoxA" Margin="5,0" Height="100"/>
</StackPanel>
</Window>

·后台代码:

//实现:定义一个命令,使用Button来发送这个命令,当命令送达TextBox时,TextBox被清空(如果没有文字则不发送命令)

namespace WpfApplication1
{
/// <summary>
/// MainWindow.xaml 的交互逻辑
/// </summary>
public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
        InitializeCommand();
    }
    //声明并定义命令
    private RoutedCommand clearCmd = new RoutedCommand("CLear", typeof(MainWindow));

    private void InitializeCommand()
    {
        //把命令赋值给命令源(发送者)并指定快捷键
        this.button1.Command = this.clearCmd;
        this.clearCmd.InputGestures.Add(new KeyGesture(Key.C, ModifierKeys.Alt));//按Alt+C键

        //指定命令目标
        this.button1.CommandTarget = this.textBoxA;

        //创建命令关联
        CommandBinding cb = new CommandBinding();
        cb.Command = this.clearCmd;//只关注与clearCmd相关的事件
        cb.CanExecute += new CanExecuteRoutedEventHandler(cb_CanExecute);
        cb.Executed +=new ExecutedRoutedEventHandler(cb_Executed);

        //把命令关联安置在外围控件上
        this.stackPanel.CommandBindings.Add(cb);
    }

    //当探测命令是否可以执行时,此方法被调用
    void cb_CanExecute(object sender, CanExecuteRoutedEventArgs e)
    {
        if(string.IsNullOrEmpty(this.textBoxA.Text))
        { e.CanExecute = false; }
        else
        { e.CanExecute = true; }

        //避免继续向上传而降低程序性能
        e.Handled = true;
    }

    //当命令送达目标后,此方法被调用
    void cb_Executed(object sender, ExecutedRoutedEventArgs e)
    {
        this.textBoxA.Clear();
        //避免继续向上传而降低程序性能
        e.Handled = true;
    }
}

解释:
·运行程序,在TextBox中输入文字后Button在指令可举行境况的景观下成为可用,此时单击Button或者按Alt+C键,TextBox都会被清空。
·RoutedCommand并不对命令目的做其他操作,而是由CommandBinding操作的。
·无论是探测命令是否推行或者命令送达目的,都会刺激命令目标发送路由事件,这么些路由事件会顺着UI元素树向上传递并末了被CommandBinding所捕捉。
·CommandBinding被安装在外侧的StackPanel上,CommandBinding起一个侦听器的效能,而且特别针对clearCmd命令捕捉与其有关的路由事件。
·当CommandBinding捕捉到CanExecute事件,就会调用cb_CanExecute方法判断命令执行标准是否满意,并反馈给命令供其震慑命令源的情况;当捕捉到Execute事件,表示命令的Execute方法已经执行了,或者说命令已经意义在了指令目的上(RoutedCommand只承担让命令目的激发Executed),则调用Executed方法。
·CommandBingding一定要安装在命令目的的外场控件上,不然不可能捕捉到CanExecute和Executed等路由事件。

一声令下实例:

概念一个限令,使用Button来发送那多少个命令,当命令送达TextBox时,TextBox被清空(尽管没有文字则不发送命令)
·界面代码:

<Window x:Class="WpfApplication1.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="Command"
    Background="LightBlue" Height="350" Width="525">
<StackPanel x:Name="stackPanel">
    <Button x:Name="button1" Content="Send Command" Margin="5"/>
    <TextBox x:Name="textBoxA" Margin="5,0" Height="100"/>
</StackPanel>
</Window>

·后台代码:

//实现:定义一个命令,使用Button来发送这个命令,当命令送达TextBox时,TextBox被清空(如果没有文字则不发送命令)

namespace WpfApplication1
{
/// <summary>
/// MainWindow.xaml 的交互逻辑
/// </summary>
public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();
        InitializeCommand();
    }
    //声明并定义命令
    private RoutedCommand clearCmd = new RoutedCommand("CLear", typeof(MainWindow));

    private void InitializeCommand()
    {
        //把命令赋值给命令源(发送者)并指定快捷键
        this.button1.Command = this.clearCmd;
        this.clearCmd.InputGestures.Add(new KeyGesture(Key.C, ModifierKeys.Alt));//按Alt+C键

        //指定命令目标
        this.button1.CommandTarget = this.textBoxA;

        //创建命令关联
        CommandBinding cb = new CommandBinding();
        cb.Command = this.clearCmd;//只关注与clearCmd相关的事件
        cb.CanExecute += new CanExecuteRoutedEventHandler(cb_CanExecute);
        cb.Executed +=new ExecutedRoutedEventHandler(cb_Executed);

        //把命令关联安置在外围控件上
        this.stackPanel.CommandBindings.Add(cb);
    }

    //当探测命令是否可以执行时,此方法被调用
    void cb_CanExecute(object sender, CanExecuteRoutedEventArgs e)
    {
        if(string.IsNullOrEmpty(this.textBoxA.Text))
        { e.CanExecute = false; }
        else
        { e.CanExecute = true; }

        //避免继续向上传而降低程序性能
        e.Handled = true;
    }

    //当命令送达目标后,此方法被调用
    void cb_Executed(object sender, ExecutedRoutedEventArgs e)
    {
        this.textBoxA.Clear();
        //避免继续向上传而降低程序性能
        e.Handled = true;
    }
}

解释:
·运行程序,在TextBox中输入文字后Button在指令可实施状况的意况下成为可用,此时单击Button或者按Alt+C键,TextBox都会被清空。
·RoutedCommand并不对命令目的做其他操作,而是由CommandBinding操作的。
·无论是探测命令是否推行或者命令送达目的,都会激发命令目的发送路由事件,这么些路由事件会沿着UI元素树向上传递并最终被CommandBinding所捕捉。
·CommandBinding被装置在外边的StackPanel上,CommandBinding起一个侦听器的法力,而且特别针对clearCmd命令捕捉与其休戚相关的路由事件。
·当CommandBinding捕捉到CanExecute事件,就会调用cb_CanExecute方法判断命令执行规范是否知足,并申报给命令供其震慑命令源的气象;当捕捉到Execute事件,表示命令的Execute方法已经举行了,或者说命令已经意义在了指令目的上(RoutedCommand只承担让命令目的激发Executed),则调用Executed方法。
·CommandBingding一定要设置在指令目的的外侧控件上,不然不可能捕捉到CanExecute和Executed等路由事件。

命令库

指令具有“一处表明,处处使用”的特性。便携的命令库包括:ApplicationCommands,ComponentCommands,NavigationCommands,MediaCommands,EditingCommands.都是静态类。例如我们得以从来拿命令库用这一个专业命令,不需要自己讲明:Open,Save,Play,Stop。(属于ApplicationCommand)

命令库

指令具有“一处表明,处处使用”的表征。便携的命令库包括:ApplicationCommands,ComponentCommands,NavigationCommands,MediaCommands,EditingCommands.都是静态类。例如我们得以一贯拿命令库用那多少个专业命令,不需要协调评释:Open,Save,Play,Stop。(属于ApplicationCommand)

自定义Command

———————待更新

自定义Command

———————待更新

Leave a Comment.