当前位置: 首页 > news >正文

C# WPF编程-Menu

C# WPF编程-Menu

  • 布局:
  • 代码:
  • 效果

在WPF(Windows Presentation Foundation)中,Menu控件用于创建下拉菜单或上下文菜单,它提供了丰富的定制选项来满足不同的应用需求。下面将介绍如何在WPF应用程序中使用Menu控件,包括基本用法、添加菜单项、设置快捷键以及样式定制。

  • Menu:定义菜单
  • MenuItem: 定义菜单项

布局:

<Window x:Class="WpfBaseDemo.WindowMenuDemo"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
        xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
        xmlns:local="clr-namespace:WpfBaseDemo"
        mc:Ignorable="d"
        Title="WindowMenuDemo" Height="450" Width="800">

   
    <Grid>
        <!-- 背景图 -->
        <Grid.Background>
            <LinearGradientBrush>
                <LinearGradientBrush.GradientStops>
                    <GradientStop Offset="0.00" Color="Red"/>
                    <GradientStop Offset="0.50" Color="LightYellow"/>
                    <GradientStop Offset="1.00" Color="Blue"/>
                </LinearGradientBrush.GradientStops>
            </LinearGradientBrush>
        </Grid.Background>

        
        <StackPanel>
            <Menu>
                <!-- 文件菜单 -->
                <MenuItem Header="_File">
                    <MenuItem Header="_New" Click="MenuItemFileNew_Click">
                        <MenuItem.Icon>
                            <Image Source="Images/filenew.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                    <MenuItem Header="_Open" Click="MenuItemFileOpen_Click">
                        <MenuItem.Icon>
                            <Image Source="Images/fileopen.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                    <MenuItem Header="_Save" Click="MenuItemFileSave_Click">
                        <MenuItem.Icon>
                            <Image Source="Images/filesave.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                </MenuItem>
                
                <!-- 编辑菜单 -->

                <MenuItem Header="_Edit">
                    <MenuItem Header="_Redo">
                        <MenuItem.Icon>
                            <Image Source="Images/edit-redo.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                    <MenuItem Header="_Undo">
                        <MenuItem.Icon>
                            <Image Source="Images/edit-undo.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                    
                    <!-- 分割线 -->
                    <Separator Background="Red"/>

                    <MenuItem Header="_Copy">
                        <MenuItem.Icon>
                            <Image Source="Images/editcopy.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                    <MenuItem Header="_Paste">
                        <MenuItem.Icon>
                            <Image Source="Images/editpaste.png"/>
                        </MenuItem.Icon>
                    </MenuItem>
                    <MenuItem Header="_Cut">
                        <MenuItem.Icon>
                            <Image Source="Images/editcut.png"/>
                        </MenuItem.Icon>
                    </MenuItem>

                    <MenuItem Header="_Delete">
                        <MenuItem.Icon>
                            <Image Source="Images/editdelete.png"/>
                        </MenuItem.Icon>
                    </MenuItem>

                    <!-- 分割线 -->
                    <Separator Height="1" Background="DarkCyan"/>

                    <MenuItem Header="_Find">
                        <MenuItem.Icon>
                            <Image Source="Images/find.png"/>
                        </MenuItem.Icon>
                        <!-- 子菜单项 -->
                        <MenuItem Header="_Kfind">
                            <MenuItem.Icon>
                                <Image Source="Images/kfind.png"/>
                            </MenuItem.Icon>
                        </MenuItem>
                        <MenuItem Header="_Rfind">
                            <MenuItem.Icon>
                                <Image Source="Images/edit-find-replace.png"/>
                            </MenuItem.Icon>
                        </MenuItem>
                    </MenuItem>
                </MenuItem>
                
                <!-- 无图标 菜单 -->
                <MenuItem Header="_Folder">
                    <MenuItem Header="_New Folder"/>
                    <MenuItem Header="_Open Folder"/>
                    <MenuItem Header="_Close Folder"/>
                </MenuItem>
            </Menu>
                        
            <StackPanel Orientation="Vertical">
                <StackPanel >
                    <Image Width="300" Height="200" Source="Images/Linux-logo.png" />
                </StackPanel>
                <StackPanel >
                    <Image Width="300" Height="200" Source="Images/Linux-logo.png" Stretch="Fill" />
                </StackPanel>
            </StackPanel>
        </StackPanel>
    </Grid>
</Window>

代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Shapes;

namespace WpfBaseDemo
{
    /// <summary>
    /// WindowMenuDemo.xaml 的交互逻辑
    /// </summary>
    public partial class WindowMenuDemo : Window
    {
        public WindowMenuDemo()
        {
            InitializeComponent();
        }

        private void MenuItemFileNew_Click(object sender, RoutedEventArgs e)
        {
            MessageBox.Show("File New.");
        }

        private void MenuItemFileOpen_Click(object sender, RoutedEventArgs e)
        {
            MessageBox.Show("File Open.");
        }

        private void MenuItemFileSave_Click(object sender, RoutedEventArgs e)
        {
            MessageBox.Show("File Save.");
        }
    }
}

效果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

相关文章:

  • 戴尔系列电脑安装UBUNTU系统
  • MySQL事务:确保数据一致性的关键机制
  • fastapi+angular宠物领养系统
  • 基于Nvidia Jetson Nano边缘计算设备使用TensorRT部署YOLOv8模型实现目标检测推理
  • 基于Python+Ollama DeepSeek与MySQL进行数据分析探索
  • apache-maven-3.9.9 详细安装配置教程(2025版)
  • 贪心算法作业参考:P1106,P4995,P5019
  • 2000-2019年各省地方财政税收收入数据
  • 深入剖析React中setState的执行机制与实现原理
  • LeetCode算法题(Go语言实现)_04
  • 深入解析 GORM 的 Model 方法:隐式选择与模型绑定的艺术
  • 【安全运营】用户与实体行为分析(UEBA)浅析
  • 【从零开始学习计算机科学与技术】计算机网络(七)应用层
  • ClickHouse Docker 容器迁移指南:从测试环境到离线正式环境
  • 【css酷炫效果】纯CSS实现大风车旋转效果
  • 【2025】LLM(大模型)开源项目介绍与使用场景
  • 火山引擎(豆包大模型)(抖音平台)之火山方舟的Prompt的使用测试
  • 利用大语言模型生成的合成数据训练YOLOv12:提升商业果园苹果检测的精度与效
  • Log4j2漏洞实战
  • 学有所得-Deepin linux操作系统在安装nvidia显卡驱动后的问题修复
  • 国家统计局:2024年城镇单位就业人员工资平稳增长
  • 烤肉店从泔水桶内捞出肉串再烤?西安未央区市监局:停业整顿
  • 张国清将赴俄罗斯举行中俄“长江—伏尔加河”地方合作理事会第五次会议和“东北—远东”政府间合作委员会双方主席会晤
  • 刘强东坐镇京东一线:管理层培训1800人次,最注重用户体验
  • “水运江苏”“航运浙江”,江浙两省为何都在发力内河航运?
  • 哲学新书联合书单|远离苏格拉底