私は[〜#〜] mvvm [〜#〜]および[〜#〜] wpf [〜#〜]を学習しています。プロジェクトにxaml
ファイルがあり、コードビハインドに単純なクリックイベントハンドラーがあります。
[〜#〜] mvvm [〜#〜]でも同じようにしたい。私はたくさんの記事を読み、sofで多くの答えも読みました。しかし、まだこれを行うことはできません。
ボタンclickイベントが[〜#〜] mvvm [〜#〜]で実行される簡単な例を誰かに教えてもらえますか?.
編集
<Window x:Class="WhiteBalance.BaseCalWindow"
xmlns="http://schemas.Microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.Microsoft.com/winfx/2006/xaml"
xmlns:uc="clr-namespace:NumberUpDownControl;Assembly=NumberUpDownControl"
xmlns:viewn="clr-namespace:WhiteBalance.ViewModels"
Title="RefImgSettingWindow" Height="900" Width="1000" ResizeMode="NoResize"
BorderThickness="4">
<Window.Resources>
<viewn:DashBoardViewModel x:Key="demokey"></viewn:DashBoardViewModel>
</Window.Resources>
<Grid x:Name="gdParent" DataContext="{StaticResource demokey}">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="490" />
<ColumnDefinition Width="488*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="300" />
<RowDefinition Height="300" />
<RowDefinition Height="*" />
</Grid.RowDefinitions>
<StackPanel Grid.Row="0" Grid.Column="0">
<Label Content="{Binding Path=NAME,Mode=TwoWay}" Height="28" Name="lblTest" />
<Button Content="Capture" Height="23" Name="btnCapture" Width="75" Command="{Binding Path=SaveCommand}"
Canvas.Left="94" Canvas.Top="254" />
</StackPanel>
</Grid>
</Window>
namespace WhiteBalance.ViewModels
{
public class DashBoardViewModel: ObservableObject
{
private string _name = "dsqdasd";
public string NAME
{
get { return _name; }
set { _name = value; }
}
public ICommand SaveCommand
{
get;
set;
}
private bool CanExecuteSaveCommand()
{
return true; // !string.IsNullOrEmpty(LastName);
}
private void CreateSaveCommand()
{
SaveCommand = new RelayCommand(SaveExecute, CanExecuteSaveCommand);
}
public void SaveExecute()
{
//Person.Save(_newPerson);
NAME = "Changed Name";
}
public DashBoardViewModel()
{
//objModel.TestText = "This will change";
NAME = "TestName";
}
}
}
前もって感謝します。
ボタンの Command プロパティを、 ICommand を返す任意のプロパティにバインドできます。 プリズム は、非常に使いやすい DelegateCommand と呼ばれる便利なコマンドを実装しています( ここにノックオフ が含まれています)。
public ICommand MyButtonClickCommand
{
get { return new DelegateCommand<object>(FuncToCall, FuncToEvaluate); }
}
private void FuncToCall(object context)
{
//this is called when the button is clicked
}
private bool FuncToEvaluate(object context)
{
//this is called to evaluate whether FuncToCall can be called
//for example you can return true or false based on some validation logic
return true;
}
<Button x:Name="myButton" Command="{Binding MyButtonClickCommand}" />
CodeProjectの例 WPFでコマンドを使用する方法 は、非常によく似たコードで簡単に処理できる例です。前のスタックオーバーフローの質問には、静的にバインドされているRoutedCommandsを使用した例があります。 閉じるコマンドをボタンにバインドする方法 、および WPFボタンをViewModelBaseのコマンドにバインドする方法は? は、少し高度な例です。
このICommandインターフェイスを実装する多くの答えを見て、私は組み込みのSystem.Windows.Input
を使用する、より簡単なオプションを提案します
次に例を示します。
Xamlビュー:
<Window
xmlns="http://schemas.Microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.Microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.Microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
x:Class="SomeDialog"
SizeToContent="WidthAndHeight"
WindowStartupLocation="CenterOwner"
ResizeMode="CanResizeWithGrip">
<StackPanel>
<Button Width="Auto" Command="{Binding ClearCommand}" Content="Clear"/>
</StackPanel>
</Window>
後ろのコードを見る:
using System.Windows;
public partial class SomeDialog : Window
{
public SomeDialog()
{
var vm = new ViewModel();
DataContext = vm;
CommandBindings.AddRange(vm.Commands);
InitializeComponent();
}
}
モデルを見る:
using System.Windows.Input;
public class ViewModel : ViewModelBase
{
readonly CommandBindingCollection commands = new CommandBindingCollection();
public static RoutedUICommand ClearCommand { get; set; } = new RoutedUICommand("Clear", "ClearCommand", typeof(ErrorDialog));
public CommandBindingCollection Commands
{
get
{
commands.Add(new CommandBinding(ClearCommand, OnClearExecuted);
return commands;
}
}
void OnClearExecuted(object sender, ExecutedRoutedEventArgs e)
{
view.DialogResult = true; //Indicate things
view.Close(); //Close the window
}
}
このように呼び出します:
public void OpenSomeDialog()
{
var dialog = new SomeDialog() {Owner = Application.Current.MainWindow};
bool? b = dialog.ShowDialog();
if (b != null && (bool) b)
//Do things
}
ダイアログに移動します。