WPF菜单栏

WPF设置菜单栏

WPF中有已经写好的菜单栏控件Menu,我们直接在XAML上添加Menu控件就能够实现菜单栏!

1. 只包含一级菜单的Menu控件

xaml代码如下所示,通过在Menu控件中添加MenuItem就可以为菜单栏控件添加一级菜单。下面代码中添加了6个菜单控件,Header属性对应的是菜单栏中以及菜单显示的名称;Click代表菜单的点击事件,当菜单被点击时,执行其对应的Click事件,Click属性对应的值即为后台响应函数的函数名。

<Window ...>
  <Grid>
    ...
    <Menu Grid.Row="0" Background="LightSkyBlue">
      <MenuItem Header="首页" Click="IndexClick"/>
      <MenuItem Header="光源设置" Click="LightSetClick"/>
      <MenuItem Header="相机设置" Click="CameraSetClick"/>
      <MenuItem Header="PLC设置" Click="PlcSetClick"/>
      <MenuItem Header="MES设置" Click="MesSetClick"/>
      <MenuItem Header="帮助文档" Click="HelpClick"/>
    </Menu>
  </Grid>
</Window>

在MainWindow.xaml.cs下添加如下内容

...
namespace wpfbase
{
  public partial class MainWindow : Window
  {
    ...
    private void IndexClick(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了首页");
    }
    private void LightSetClick(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了光源设置");
    }
    private void CameraSetClick(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了相机设置");
    }
    private void PlcSetClick(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了PLC设置");
    }
    private void MesSetClick(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了MES设置");
    }
    private void HelpClick(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了帮助文档");
    }
    private void Level2Click(object sender, RoutedEventArgs e) {
      MessageBox.Show("你选择了二级菜单");
    }
  }
}

点击菜单产生的是一个路由事件:RoutedEventArgs。上面的cs代码为每个菜单添加了路由事件响应函数。

启动程序效果如下:
在这里插入图片描述
2. 多级菜单

多级菜单的设置方法与一级菜单类似,只需要在一级菜单MenuItem的内部嵌入MenuItem即可;

<Window ...>
  <Grid>
    ...
    <Menu Grid.Row="0" Background="LightSkyBlue">
      <MenuItem Header="首页" Click="IndexClick">
        <MenuItem Header="导入文件" Name="file_importfile" Click="File_ImportFile"/>
        <MenuItem Header="导入目录" Name="file_importfolder" Click="File_ImportFolder"/>
        <MenuItem Header="打开"/>
        <MenuItem Header="保存" Click="File_Save"/>
        <MenuItem Header="另存为"/>
        <MenuItem Header="关闭"/>
      </MenuItem>
      <MenuItem Header="光源设置" Click="LightSetClick"/>
      <MenuItem Header="相机设置" Click="CameraSetClick"/>
      <MenuItem Header="PLC设置" Click="PlcSetClick"/>
      <MenuItem Header="MES设置" Click="MesSetClick"/>
      <MenuItem Header="帮助文档" Click="HelpClick"/>
    </Menu>
  </Grid>
</Window>

上面的xaml文件就给一级菜单"首页"添加了多个二级菜单:“导入文件”,“导入目录”,“打开”,“保存”,“另存为”,“关闭”!

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
根据提供的引用内容,WPF MVVM菜单栏是指在WPF应用程序中采用MVVM设计模式来实现菜单栏功能。MVVM是Model-View-ViewModel的缩写,是一种用于分离用户界面(View)和业务逻辑(ViewModel)的模式。在MVVM模式中,菜单栏的操作被封装在ViewModel中,并通过数据绑定与View进行交互。 在引用中,工具栏的显示与隐藏操作被封装在ToolBarExecute方法中。当点击热键(T)时,会执行这个方法来切换工具栏的显示状态。如果工具栏未显示,会创建一个MyToolBar实例并将其添加到窗口中;如果工具栏已显示,会关闭工具栏并从窗口中移除。这里的win是一个List<Window>类型的窗口链表。 在引用中,主窗口的加载事件中会执行ShowTime方法来显示当前时间。通过一个定时器(DispatcherTimer)来定时更新时间的显示。另外,mainpageviewmodel是MainPageViewModel类的一个实例,用于数据绑定和处理逻辑。 在引用中,ShowCurTimer方法被定时器Tick事件调用,用于更新菜单栏工具栏的勾选状态。如果mainpageviewmodel中的toolflag为1,则工具栏菜单项的勾选状态为选中,否则为未选中。ShowTime方法用于显示当前日期和时间。 综上所述,WPF MVVM菜单栏通过MVVM模式的设计和数据绑定实现菜单栏的功能,并通过定时器来实时更新菜单栏的显示状态和当前时间的显示。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [WPF(MVVM)菜单栏小勾与窗口绑定](https://blog.csdn.net/baidu_38131614/article/details/77877974)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值