WPF UserControl响应PreviewKeyDown事件方法
程序员文章站
2022-03-04 11:49:02
...
之前在一个项目中,Window窗口嵌入UserControl页面,在UserControl控件页面中添加PreviewKeyDown或者KeyDown事件,软件均不触发事件;在Window窗口可以响应事件,但是由于项目上下文绑定,调用不到想要执行的函数,所以写个文章记录一下,以便后期遇到同样问题,能及时解决。
1、UserControl后台逻辑处理页面中添加
public void CallKeyDown(KeyEventArgs e)
{
if (e.Key == Key.Space)
{
if (DataContext != null)
{
if (((MainViewModel)DataContext).MagnetronVM != null)
if (((MainViewModel)DataContext).MagnetronVM.IsEnabled_Position == true)
((MainViewModel)DataContext).MagnetronVM.StopCtrl();
}
}
}
2、在Window的xaml 窗口设置中添加PreviewKeyDown事件
<Window x:Class="RealStomach_WPF.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:local="clr-namespace:RealStomach_WPF"
Height="950" Width="1800"
PreviewKeyDown="Window_PreviewKeyDown"
>
<Viewbox HorizontalAlignment="Center" VerticalAlignment="Center" Stretch="Fill">
<StackPanel HorizontalAlignment="Stretch" VerticalAlignment="Stretch" Margin="5,0,5,0">
<local:RealMainView x:Name="realView" Background="#FF0E121B"/>
</StackPanel>
</Viewbox>
</Window>
3、Window 后台逻辑处理,响应PreviewKeyDown事件:
private void Window_PreviewKeyDown(object sender, KeyEventArgs e)
{
this.realView.CallKeyDown(e);
}
扩展:
在Panel(StackPanel、Canvas、Grid)上或者是在一些默认不支持Focus的控件上添加了KeyDown或者KeyUp,处理方法在鼠标左键点击事件中,让控件获取到焦点,并且设置该控件Focusable="True";
具体代码示例:
<!--前端UI-->
<StackPanel x:Name="stanpan" Focusable="True"/>
//后台左键响应事件
private void MouseLeftButtonDown(object sender, MouseButtonEventArgs e)
{
Grid1.Focus();
}
上一篇: 【WPF】Xaml用户控件(Usercontrol)绑定属性/事件
下一篇: 自定义标签
推荐阅读
-
iOS touch事件区分单击双击响应的方法
-
c# 给button添加不规则的图片以及用pictureBox替代button响应点击事件的方法
-
iOS touch事件区分单击双击响应的方法
-
Android响应事件onClick方法的五种实现方式小结
-
python基于pygame实现响应游戏中事件的方法(附源码)
-
Android响应事件onClick方法的五种实现方式小结
-
bootstrap动态添加面包屑(breadcrumb)及其响应事件的方法
-
python基于pygame实现响应游戏中事件的方法(附源码)
-
JQueryon()方法绑定动态元素的点击事件无响应问题的解决办法
-
iOS开发中Subview的事件响应以及获取subview的方法