WPF and Silverlight 学习笔记(十四):键盘输入、鼠标输入、焦点处理[转]
一、键盘类和键盘事件
WPF提供了基础的键盘类(System.Input.Keyboard类),该类提供与键盘相关的事件、方法和属性,这些事件、方法和属性提供有关键盘状态的信息。Keyboard的事件也通过UIElement等XAML基元素类的事件向外提供。
对于键盘操作,其常用的事件有两组:
- KeyDown事件和PreviewKeyDown事件:处理键盘键按下
- KeyUp事件和PreviewKeyUp事件:处理键盘键抬起
其中KeyDown和KeyUp事件属于冒泡路由事件,而PreviewKeyDown和PreviewKeyup属于隧道路由事件。
为了使元素能够接收键盘输入,该元素必须可获得焦点。默认情况下,大多数 UIElement 派生对象都可获得焦点。如果不是这样,则要使元素可获得焦点,请将基元素上的 Focusable 属性设置为 true。像 StackPanel 和 Canvas 这样的 Panel 类将 Focusable 的默认值设置为 false。因此,对要获取键盘焦点的这些对象而言,必须将 Focusable 设置为 true。
例如:在笔者的Notebook中有“静音”、“增大音量”、“减小音量”这三个快捷键,在一个应用程序的窗体上处理这三个键的点击可以:
1: <Window x:Class="InputCommandAndFocus.Window1"
2: xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
3: xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
4: Title="Window1" Height="300" Width="480"
5: Focusable="True" PreviewKeyDown="Window_PreviewKeyDown">
6: <Canvas>
7: <!-- ... -->
8: </Canvas>
9: </Window>
1: private void Window_PreviewKeyDown(object sender, KeyEventArgs e)
2: {
3: if (e.Key == Key.VolumeMute)
4: {
5: // 按下“静音”键
6: txtMessage.Text = "Mute";
7: e.Handled = true;
8: }
9: else if (e.Key == Key.VolumeUp)
10: {
11: // 按下“增大音量”键
12: txtMessage.Text = "Up";
13: e.Handled = true;
14: }
15: else if (e.Key == Key.VolumeDown)
16: {
17: // 按下“减小音量”键
18: txtMessage.Text = "Down";
19: e.Handled = true;
20: }
21: }
二、鼠标类和鼠标事件
WPF提供的System.Input.Mouse类提供与鼠标相关的事件、方法和属性,这些事件、方法和属性提供有关鼠标状态的信息。与Keyboard类类似,其事件也通过UIElement等基元素向外提供。
其事件主要有以下几组(每个事件均包含XXX冒泡路由事件和PreviewXXX隧道路由事件)
- MouseDown、MouseUp事件:处理鼠标键的按下与抬起
- MouseEnter、MouseLeave、MouseMove:处理鼠标进入、离开控件及在控件上移动
- MouseWheel:处理鼠标滚轮滚动
另外,对于鼠标位置的捕获,使用Mouse类的GetPosition方法,其参数是一个UIElement,表示其鼠标位置基于哪一个控件的坐标系。
例如,对于一个矩形图形,设置其鼠标的各种事件:
1: <Rectangle Canvas.Left="246" Canvas.Top="46" Height="118"
2: Name="mainRectangle" Stroke="Black" Width="200" Fill="White"
3: MouseEnter="mainRectangle_MouseEnter" MouseLeave="mainRectangle_MouseLeave"
4: MouseMove="mainRectangle_MouseMove" MouseDown="mainRectangle_MouseDown"
5: MouseWheel="mainRectangle_MouseWheel"/>
1: private void mainRectangle_MouseEnter(object sender, MouseEventArgs e)
2: {
3: // 鼠标进入控件时,控件的颜色为红色
4: mainRectangle.Fill = new SolidColorBrush(Colors.Red);
5: }
6:
7: private void mainRectangle_MouseLeave(object sender, MouseEventArgs e)
8: {
9: // 鼠标离开控件时,控件的颜色为红色
10: mainRectangle.Fill = new SolidColorBrush(Colors.White);
11: }
12:
13: private void mainRectangle_MouseMove(object sender, MouseEventArgs e)
14: {
15: // 获取基于Rectangle的鼠标的坐标
16: Point pointBaseRectangle = Mouse.GetPosition(mainRectangle);
17: txtMessage.Text = string.Format(
18: "Mouse Position (Base the Rectangle) is ({0},{1})",
19: pointBaseRectangle.X, pointBaseRectangle.Y);
20:
21: txtMessage.Text += "\r\n";
22:
23: // 获取基于窗体的鼠标的坐标
24: Point pointBaseWindow = Mouse.GetPosition(this);
25: txtMessage.Text += string.Format(
26: "Mouse Position (Base the Window) is ({0},{1})",
27: pointBaseWindow.X, pointBaseWindow.Y);
28: }
29:
30: private void mainRectangle_MouseDown(object sender, MouseButtonEventArgs e)
31: {
32: // 获取点出的鼠标的按钮
33: MouseButton button = e.ChangedButton;
34:
35: txtMessage.Text += "\r\n";
36: txtMessage.Text += string.Format(
37: " Mouse Button is {0}", button.ToString());
38: }
39:
40: private void mainRectangle_MouseWheel(object sender, MouseWheelEventArgs e)
41: {
42: if (e.Delta > 0)
43: {
44: // 如果向上推动滚轮,图形的宽度增加
45: rectangle1.Width++;
46: }
47:
48: if (e.Delta < 0)
49: {
50: // 如果向下推动滚轮,图形的宽度减小
51: rectangle1.Width--;
52: }
53: }
三、焦点处理
在 WPF 中,有两个与焦点有关的主要概念:键盘焦点和逻辑焦点。 键盘焦点指接收键盘输入的元素,而逻辑焦点指焦点范围中具有焦点的元素。
1、键盘焦点:
键盘焦点指当前正在接收键盘输入的元素。 在整个桌面上,只能有一个具有键盘焦点的元素。 在 WPF 中,具有键盘焦点的元素会将 IsKeyboardFocused 设置为 true。 Keyboard 类的静态属性 FocusedElement 获取当前具有键盘焦点的元素。
为了使元素能够获取键盘焦点,基元素的 Focusable 和 IsVisible 属性必须设置为 true。 有些类(如 Panel 基类)默认情况下将 Focusable 设置为 false;因此,如果您希望此类元素能够获取键盘焦点,必须将 Focusable 设置为 true。
可以通过用户与 UI 交互(例如,按 Tab 键定位到某个元素或者在某些元素上单击鼠标)来获取键盘焦点。 还可以通过使用 Keyboard 类的 Focus 方法,以编程方式获取键盘焦点。 Focus 方法尝试将键盘焦点给予指定的元素。 返回的元素是具有键盘焦点的元素,如果有旧的或新的焦点对象阻止请求,则具有键盘焦点的元素可能不是所请求的元素。
2、逻辑焦点
逻辑焦点指焦点范围中的 FocusManager..::.FocusedElement。 焦点范围是一个跟踪其范围内的 FocusedElement 的元素。 当键盘焦点离开焦点范围时,焦点元素会失去键盘焦点,但保留逻辑焦点。 当键盘焦点返回到焦点范围时,焦点元素会再次获得键盘焦点。 这使得键盘焦点可以在多个焦点范围之间切换,但确保了在焦点返回到焦点范围时,焦点范围中的焦点元素再次获得键盘焦点。
一个应用程序中可以有多个具有逻辑焦点的元素,但在一个特定的焦点范围中只能有一个具有逻辑焦点的元素。
GetFocusScope 返回指定元素的焦点范围。
WPF 中默认情况下即为焦点范围的类有 Window、MenuItem、ToolBar 和 ContextMenu。
GetFocusedElement 获取指定焦点范围的焦点元素。SetFocusedElement 设置指定焦点范围中的焦点元素。SetFocusedElement 通常用于设置初始焦点元素。
3、键盘导航
当按下导航键之一时,KeyboardNavigation 类将负责实现默认键盘焦点导航。 导航键有:Tab、Shift+Tab、Ctrl+Tab、Ctrl+Shift+Tab、向上键、向下键、向左键和向右键。
可以通过设置附加的 KeyboardNavigation 属性 TabNavigation、ControlTabNavigation 和 DirectionalNavigation 来更改导航容器的导航行为。 这些属性是 KeyboardNavigationMode 类型,可能值有 Continue、Local、Contained、Cycle、Once 以及 None。 默认值是 Continue,这意味着元素不是导航容器。
4、焦点事件
与键盘焦点相关的事件有 PreviewGotKeyboardFocus、GotKeyboardFocus、PreviewLostKeyboardFocus 以及 LostKeyboardFocus。 这些事件定义为 Keyboard 类的附加事件,但更便于作为基元素类上的等效路由事件来访问。
当元素获取键盘焦点时,会引发 GotKeyboardFocus。当元素失去键盘焦点时,会引发 LostKeyboardFocus。 如果处理了 PreviewGotKeyboardFocus 事件或 PreviewLostKeyboardFocusEvent 事件,并且 Handled 设置为 true,则焦点将不会改变。
转载于:https://www.cnblogs.com/junbird-nest/archive/2012/06/06/2538137.html
WPF and Silverlight 学习笔记(十四):键盘输入、鼠标输入、焦点处理[转]相关推荐
- 吴恩达《机器学习》学习笔记十四——应用机器学习的建议实现一个机器学习模型的改进
吴恩达<机器学习>学习笔记十四--应用机器学习的建议实现一个机器学习模型的改进 一.任务介绍 二.代码实现 1.准备数据 2.代价函数 3.梯度计算 4.带有正则化的代价函数和梯度计算 5 ...
- Polyworks脚本开发学习笔记(十四)-WORKSPACE信息读取及管理
Polyworks脚本开发学习笔记(十四)-WORKSPACE信息读取及管理 Polyworks的工作任务存储分为工作区和项目两级,通过WORKSPACE命令获取工作任务信息,实现更好的任务管理. 下 ...
- python学习[第十四篇] 文件的输入与输出
python学习[第十四篇] 文件的输入与输出 标准文件类型 一般来说只要程序一执行,就会访问3个文件: 标准输入(键盘) stdin 标准输出(显示器缓冲区) stdout 默认输出到屏幕 标准错误 ...
- WPF and Silverlight 学习笔记(二十):WPF数据绑定概述
WPF数据绑定为应用程序提供了一种表示数据和与数据交互的简单而又一致的方法.元素能够以公共语言运行库 (CLR) 对象和 XML 的形式绑定到各种数据源中的数据. 一.数据绑定的基本概念: 数据绑定涉 ...
- 【神经网络】学习笔记十四——Seq2Seq模型
本文简要介绍seq2seq,即序列到序列的基本知识,是深度学习和NLP中一个重要的知识. 从三部分来说,seq2seq基本简介,应用场景和原理解析. 一.什么是Seq2Seq 所谓Seq2Seq(Se ...
- WPF and Silverlight 学习笔记(十八):WPF样式(Style)与模板(Template)
一.WPF样式 类似于Web应用程序中的CSS,在WPF中可以为控件定义统一的样式(Style).样式属于资源的一种,例如为Button定义统一的背景颜色和字体: 1: <Window.Reso ...
- WPF and Silverlight 学习笔记(十):WPF控件模型
WPF对控件其类型的继承方式如下 (其中绿色表示的类是抽象类,蓝色表示的类是非抽象类) 控件内容模型 System.Windows.Controls.Control类:表示 用户界面 (UI ...
- WPF and Silverlight 学习笔记(十二):WPF Panel内容模型、Decorator内容模型及其他...
由于园子里昨天使用Live Writer上传出现问题,昨天只能使用Web上的文本编辑器上传本文,造成代码.内容等格式的错误,现重发本文. 一.Panel内容模型 Panel内容模型指从System.W ...
- WPF and Silverlight 学习笔记(十九):WPF更换主题
如果要做到一个应用程序其基本的内容不变,但改变整个应用程序的外观可以这样做: 对于每一套外观定义一个ResourceDictionary 在应用程序中,动态加载此应用程序(或窗体)的Resource ...
最新文章
- 【Linux驱动】ThinkPad笔记本wifi模块rtl8821ce在ubuntu16.04的驱动(默认没有)
- php和java融合_JSP、PHP与JAVA融合的开发环境之二
- 05用线程类Thread开启线程
- Java中Comparable和Comparator区别小结
- 啊啊啊...每次需求评审总被boss虐成狗?解药来了
- python 解析url上的xml_如何从python中的URL读取XML文件?
- CentOS安装SVN服务器并配置HTTPS连接
- POJ - 2513 Colored Sticks(字典树+并查集+欧拉回路)
- Weblogic的缓存
- EntityFramework进阶——继承
- oracle 创建表空间_Oracle 创建和管理表
- 计算机网络工程毕业论文题目,计算机网络技术专业毕业论文题目(2)
- Steam游戏上线初期的总结与思考
- 如何给拍好的短视频配音?最简单的方法推荐!
- Java Web应用案列:蒙西购物1
- 安全多方计算与证券业数据生态
- Object的wait()和notify()以及notifyAll()和interrupt()方法
- linux(centos)服务器时间校正
- simulink模糊PID控制在机车速度控制中的应用
- 从DQN到Double DQN和Dueling DQN——pytorch实操
热门文章
- 应用密码学的笑话之MD5+Salt不安全
- 【kibana】kibana 7.* 设置中文 汉化
- 【Kafka】Confluent Schema Registry
- 【janino】janino 加载自定义函数
- 【janino】CompileException Closing single quote missing
- 《spring-boot学习》-06-thymeleaf详解
- 数据结构知识点大汇总(八)
- 从性能方面选择for,map和forEach
- 云计算实战系列十六(SQL II)
- php require 输出乱码,php输出乱码