简简单单明了,简单明了

每个接收者可以使用自己的行为来响应事件,每个接收者可以使用自己的行为来响应事件

命令(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;
    }
}

解释:
opebet官网,·运行程序,在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

———————待更新