说在前面:

WPF中给按钮或者是具备Command等元素实现快捷键其实是非常简单的,例子如下:

 <Button Content="_Test" Click="Button_Click_1"></Button>

XAML代码很简单,一个Button,设置了Content和事件,细心的小盆友会发现Content的前缀是一个_,这个可不是一般的下划线哦,因为你在运行时候是看不到这个下划线的,这就是快捷键的神奇之处,现在运行程序按下 "Alt+T",你会发现好神奇竟然执行了Click事件。

解释:WPF中的快捷键定义规则是在文本的前边加上下划线,然后按下Alt和下划线后的字母即可实现,比如上例子中我们下划线后边的是T,所以我们按下Alt+t就可以实现快捷操作,当然你也可以是A--Z都ok的。

窃喜:有小盆友开始发现一个致命问题,如果我们内容是中文怎么办,难道我也必须在前边放一个字母吗,这个问题难道我了,可是难不倒WPF,上例子:

 <Button Content="测试(_T)" Click="Button_Click_1"></Button>

哈哈哈,是不是觉得我很坏呢,可是这个就是解决办法,看看VS中的菜单,是不是都是这样的形式呢,同样运行按下Alt+t是不是执行了Click呢,当然对于英文如果我们的快捷键并不是首字母同样可以采取这样的方法。

进入正文:

    <ControlTemplate TargetType="{x:Type MenuItem}" x:Key="headMenuItemTemplate"  >
<Grid HorizontalAlignment="Stretch" VerticalAlignment="Stretch" > <Rectangle Fill="#FF505050"
Name="be"
HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"></Rectangle> <Label HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
HorizontalContentAlignment="Center"
VerticalContentAlignment="Center"
Content="{TemplateBinding Header}"
Name="backLbl"
Margin="10,0,10,0"
Padding="10,0,10,0"
Foreground="#FFC1C1C1"
Visibility="Collapsed"
>
</Label>
<Label HorizontalAlignment="Stretch"
VerticalAlignment="Stretch"
HorizontalContentAlignment="Center"
VerticalContentAlignment="Center"
Content="{TemplateBinding Header}"
Name="contLbl"
Margin="10,0,10,0"
Padding="10,0,10,0"
Foreground="White"
></Label>
<Popup Name="Popup"
Placement="Bottom"
IsOpen="{TemplateBinding IsSubmenuOpen}"
AllowsTransparency="True"
Focusable="False"
PopupAnimation="Slide"
> <StackPanel Orientation="Horizontal"
SnapsToDevicePixels="True"
MinWidth="{TemplateBinding ActualWidth}" >
<Border x:Name="DropDownBorder"
BorderThickness="1"
BorderBrush="Black"
HorizontalAlignment="Center"
Width="{TemplateBinding ActualWidth}"
>
<Border.Background>
<SolidColorBrush Color="#FF535353" />
</Border.Background>
<ScrollViewer Margin="4,6,4,6" SnapsToDevicePixels="True"
HorizontalScrollBarVisibility="Hidden"
VerticalScrollBarVisibility="Hidden"
HorizontalAlignment="Center"
>
<StackPanel IsItemsHost="True" KeyboardNavigation.DirectionalNavigation="Contained" />
</ScrollViewer>
</Border>
</StackPanel>
</Popup>
</Grid> <ControlTemplate.Triggers>
<Trigger Property="IsEnabled" Value="True">
<Setter TargetName="contLbl" Property="Visibility" Value="Visible"></Setter>
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter TargetName="contLbl" Property="Visibility" Value="Collapsed"></Setter>
</Trigger>
<EventTrigger RoutedEvent="UIElement.MouseEnter">
<BeginStoryboard>
<Storyboard>
<ColorAnimation
Storyboard.TargetName="be"
Storyboard.TargetProperty="Fill.Color"
To="Black"
Duration="0:0:0.4"
>
</ColorAnimation>
</Storyboard>
</BeginStoryboard>
</EventTrigger> <EventTrigger RoutedEvent="UIElement.MouseLeave">
<BeginStoryboard>
<Storyboard>
<ColorAnimation
Storyboard.TargetName="be"
Storyboard.TargetProperty="Fill.Color"
To="#FF505050"
Duration="0:0:0.4"
>
</ColorAnimation>
</Storyboard>
</BeginStoryboard>
</EventTrigger>
</ControlTemplate.Triggers>
</ControlTemplate>

上述代码如果觉得好复杂,可以复制到自己的页面中,其实就是一个MenuItem的模板,并且控制了启用和禁用下的样式,就这么多功能。其中最复杂的就是Popup部分,其实就是用于展现子菜单使用的,所以还是要写上的。
使用模板:

    <MenuItem Header="打开(_O)" Template="{StaticResource headMenuItemTemplate}" >
<MenuItem Header="_Best" Click="MenuItem_Click_1" Template="{StaticResource defaultMenuItemTemplate}" ></MenuItem>
<MenuItem Header="_Cest" Click="MenuItem_Click_2" Template="{StaticResource defaultMenuItemTemplate}" ></MenuItem>
<MenuItem Header="_Dest" Click="MenuItem_Click_3" Template="{StaticResource defaultMenuItemTemplate}" ></MenuItem>
</MenuItem>

使用也很简单,运行程序,按下Alt+O,你很难过的发现为什么菜单不会展开呢,哈哈哈,因为代码有问题所以展不开,另外你会发现手动点击开按下子菜单对应的快捷键(B,C,D)竟然没反应,别急按下键同时按下Enter回车即可。

解释:为什么会展不开呢,因为代码少东西:

   <!--菜单高亮的时候展开子菜单-->
<Trigger Property="IsHighlighted" Value="true">
<Setter Property="IsOpen" Value="True" TargetName="Popup"/>
</Trigger>

上述代码我们只针对Enable做了除了,可是当菜单高亮的时候并没有做任何东西,所以加上上述的代码即可,IsOpen是Popup的属性,这样按下快捷键就可以展开菜单了,是不是很简单呢。
好了,这篇东西蛮简单,大家有好的建议多交流。

WPF之给使用了模板的MenuItem添加快捷操作的更多相关文章

  1. WPF学习之深入浅出话模板

    图形用户界面应用程序较之控制台界面应用程序最大的好处就是界面友好.数据显示直观.CUI程序中数据只能以文本的形式线性显示,GUI程序则允许数据以文本.列表.图形等多种形式立体显示. 用户体验在GUI程 ...

  2. WPF Step By Step 自定义模板

    WPF Step By Step 自定义模板 回顾 上一篇,我们简单介绍了几个基本的控件,本节我们将讲解每个控件的样式的自定义和数据模板的自定义,我们会结合项目中的具体的要求和场景来分析,给出我们实现 ...

  3. WPF实现选项卡效果(2)——动态添加AvalonDock选项卡

    原文:WPF实现选项卡效果(2)--动态添加AvalonDock选项卡 简介 在前面一篇文章里面,我们使用AvalonDock实现了类似于VS的选项卡(或者浏览器的选项卡)效果.但是我们是通过xaml ...

  4. webapi修改tt模板给字段添加JsonIgnore特性解决转换json循环引用问题

    0.问题描述 EF生成的model带有导航属性,则json序列化会报循环引用错误,尝试如下 protected void Application_Start() { GlobalConfigurati ...

  5. opencv笔记4:模板运算和常见滤波操作

    time:2015年10月04日 星期日 00时00分27秒 # opencv笔记4:模板运算和常见滤波操作 这一篇主要是学习模板运算,了解各种模板运算的运算过程和分类,理论方面主要参考<图像工 ...

  6. WPF中通过代码定义模板

    WPF中可以再XAML中定义模板,也可以通过C#代码定义模板,通过代码可能更清楚的看清其逻辑,而且代码的好处就是可以随时动态的去操作,而在XAML中定义的一般都是静态的. //控件呈现的显示内容1(这 ...

  7. WPF学习(10)模板

    在前面一篇我们粗略说了Style和Behaviors,如果要自定义一个个性十足的控件,仅仅用Style和Behaviors是不行的,Style和Behaviors只能通过控件的既有属性来简单改变外观, ...

  8. wpf中的样式与模板

    1.WPF样式类似于Web应用程序中的CSS,在WPF中可以为控件定义统一的样式(Style).样式属于资源的一种,例如为Button定义统一的背景颜色和字体: <Window.Resource ...

  9. WPF有关控件和模板样式设计的微软官方文档

    说明 如果你正在使用WPF开发应用程序,相信这篇博客会对你有用.希望你能认真的阅读 正文 此文主要以Button为例进行介绍此文档的组成部分. Button Parts Button控件没有任何命名的 ...

随机推荐

  1. 【leetcode】363. Max Sum of Rectangle No Larger Than K

    题目描述: Given a non-empty 2D matrix matrix and an integer k, find the max sum of a rectangle in the ma ...

  2. 【leetcode】10.Regular Expression Matching

    题目描述: Implement regular expression matching with support for '.' and '*'. '.' Matches any single cha ...

  3. String 转Clob

    把String转Clob java.sql.Clob c = new javax.sql.rowset.serial.SerialClob("abc".toCharArray())

  4. mysql 恢复备份时出错 Unknown command ‘\”

    今天恢复mysql备份时,出现了Unknown command ‘\”这样的错误,原以为是备份文件出错,重新备份导入时还是出错.研究了一凡是因为编码的问题,解决方案如下: 使用你导出备份时的编码重新导 ...

  5. 【转】winform与web 按钮button去掉边框

    ref:http://blog.csdn.net/wangzh300/article/details/5264316 WinForm的话 设置Button属性的FlatStyle为Flat,并且设置F ...

  6. JSONP 含jquery 实例

     前言: 由于Sencha Touch 2这种开发模式的特性,基本决定了它原生的数据交互行为几乎只能通过AJAX来实现. 当然了,通过调用强大的PhoneGap插件然后打包,你可以实现100%的Soc ...

  7. Django的templates模版

    前面介绍的都是django.http.HttpResponse 把内容直接返回到网页上,这次介绍通过渲染模版的方法来显示内容 步骤: 1.创建一个项目(略) 2.创建一个app(略) 3.添加项目到s ...

  8. 怎样下载安装Firebug和使用Firebug

    Firebug是基于火狐(FireFox)浏览器的一个插件,它的作用是给Web页面开发者一个很好的测试前端页面代码的工具.所以深受网页开发者或网页布局爱好者的喜爱.像我们用DIV+CSS和html所写 ...

  9. Programming Collective Intelligence

    最近正在拜读 O'reilly出版的Programming Collective Intelligence,准备研究研究搜索引擎了,童鞋们,到时候会考虑公布源码哦!

  10. c语言指针用法

    一.指针 int t 定义整型变量 int *p p为指向整型数据的指针变量 int a[n] 定义整型数组a,它有n个元素 int *p[n] 定义指针数组p,它由n个指向整形数据的指针元素组成 i ...