MVVMにおけるCommandバインド(3)任意のイベントを容易に実現するCommand
WPFではすべてのコントロールにCommand属性があるわけではありませんが、フォームがViewModelでLoadedイベントコマンドや他のイベントのコマンドを処理する必要がある場合、Commandをバインドして完了するのは難しいので、依存属性やイベントなどを登録しなければなりません.面倒です.私は簡潔で効果的な方法が好きで、今私はみんなと一緒に分かち合います.
シーンでは、ButtonのClickとMouseMoveイベントを処理する必要がありますが、後置コードは避けて、できるだけView Modelで取得します.個々のClickはButtonのCommandで行うことができ、前の2つの記事で紹介したように、MouseMoveイベントを処理するにはSystemが必要です.Windows.Interactivity.dll、このdllはBlendをインストールしてからあるもので、C:Program FilesMicrosoft SDKsExpressionBlend.NETFramework\v4.0Librariesディレクトリで、Prismが必要です.dll.
xaml:
注意するxmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"はBlendのdllをインポートし、コントロール内部ででいいです.他のものは、イベントトリガによって、ViewModelの2つのCommandを開始します.2番目のCommandのパラメータはButtonオブジェクトで、ElementName=btnで指定します.
ViewModel:
この部分の内容は前章とほぼ同じです.
では、テストしてみましょう.実現するのは非常に簡潔ではありませんか.△私は以前Javaをやっていたので、コードが簡潔明瞭で一貫したやり方で、生活もそうでした.
コードのダウンロード:http://qing2005.download.csdn.net/
シーンでは、ButtonのClickとMouseMoveイベントを処理する必要がありますが、後置コードは避けて、できるだけView Modelで取得します.個々のClickはButtonのCommandで行うことができ、前の2つの記事で紹介したように、MouseMoveイベントを処理するにはSystemが必要です.Windows.Interactivity.dll、このdllはBlendをインストールしてからあるもので、C:Program FilesMicrosoft SDKsExpressionBlend.NETFramework\v4.0Librariesディレクトリで、Prismが必要です.dll.
xaml:
<Window x:Class="WpfApplication1.Window2"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"
xmlns:vm="clr-namespace:WpfApplication1"
Title="Window2" Height="124" Width="214">
<Window.DataContext>
<vm:Window2ViewModel />
</Window.DataContext>
<Grid>
<Button Name="btn" Content="Button" Height="33" HorizontalAlignment="Left" Margin="40,24,0,0" VerticalAlignment="Top" Width="109">
<i:Interaction.Triggers>
<i:EventTrigger EventName="Click">
<i:InvokeCommandAction Command="{Binding Command1}" CommandParameter="10" />
</i:EventTrigger>
<i:EventTrigger EventName="MouseMove">
<i:InvokeCommandAction Command="{Binding Command2}" CommandParameter="{Binding ElementName=btn}" />
</i:EventTrigger>
</i:Interaction.Triggers>
</Button>
</Grid>
</Window>
注意するxmlns:i="clr-namespace:System.Windows.Interactivity;assembly=System.Windows.Interactivity"はBlendのdllをインポートし、コントロール内部で
ViewModel:
namespace WpfApplication1 {
public class Window2ViewModel {
public ICommand Command1 {
get {
return new DelegateCommand<string>((str) => {
MessageBox.Show("Command1 with parameter:"+str);
});
}
}
public ICommand Command2 {
get {
return new DelegateCommand<Button>((button) => {
Point p = Mouse.GetPosition(button);
button.Content = string.Format("{0},{1}", p.X, p.Y);
});
}
}
}
}
この部分の内容は前章とほぼ同じです.
では、テストしてみましょう.実現するのは非常に簡潔ではありませんか.△私は以前Javaをやっていたので、コードが簡潔明瞭で一貫したやり方で、生活もそうでした.
コードのダウンロード:http://qing2005.download.csdn.net/