我仍在使用Commands和RoutedEvents。不使用RoutedCommands,我尝试实现一个简单的程序。
这是我的Command类:
public class ColorChanger : ICommand
{
public static readonly RoutedEvent ChangeMyColor = EventManager.RegisterRoutedEvent("ChangeMyColor", RoutingStrategy.Direct, typeof(RoutedEventHandler), typeof(ColorChanger));
public void Execute(object parameter)
{
RoutedEventArgs eventArgs = new RoutedEventArgs(ChangeMyColor);
Keyboard.FocusedElement.RaiseEvent(eventArgs);
}
public bool CanExecute(object parameter)
{
return true;
}
public event EventHandler CanExecuteChanged;
public static void AddChangeMyColorHandler(DependencyObject o, RoutedEventHandler handler)
{
((UIElement)o).AddHandler(ColorChanger.ChangeMyColor, handler);
}
public static void RemoveChangeMyColorHandler(DependencyObject o, RoutedEventHandler handler)
{
((UIElement)o).AddHandler(ColorChanger.ChangeMyColor, handler);
}
}
为了确保我对该命令有静态访问权限,我创建了一个静态类来保存所有命令:
public static class AppCommands
{
private static ColorChanger colorChanger = new ColorChanger();
public static ColorChanger ColorChanger
{
get { return colorChanger; }
}
}
您可以在我的MainWindow.xaml中找到:
<StackPanel>
<Menu>
<MenuItem Command="{x:Static local:AppCommands.ColorChanger}" Header="ClickMe"
CommandTarget="{Binding ElementName=mainTextBox}" x:Name="menue1"/>
</Menu>
<TextBox Name="mainTextBox"/>
</StackPanel>
我想要的是通过点击menue1项目'mainTextBox'的背景发生变化。 那么让我们看看我的MainWindow.cs:
public partial class MainWindow : Window
{
public MainWindow()
{
InitializeComponent();
AddHandler(ColorChanger.ChangeMyColor,new RoutedEventHandler(test));
}
public void test(object sender, RoutedEventArgs args)
{
Control someCtl = (Control) args.OriginalSource;
someCtl.Background = Brushes.BlueViolet;
}
}
该程序正在运行 - 但不正确:)它总是更改MainWindow的背景,而不是我的CommandTarget。
所以 - 我做错了什么? 我忘了什么吗?
答案 0 :(得分:0)
OriginalSource
是基于纯命中测试的事件的报告源。见:http://msdn.microsoft.com/en-us/library/system.windows.routedeventargs.originalsource.aspx。
在这种情况下,它会返回您的窗口,因为它不会解析为其可视树中的任何子元素。
要访问CommandTarget,您应该使用args.Source
。