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

WPF Button点击鼠标左键弹出菜单

目录

  • ContextMenu介绍
  • WPF实现点击鼠标左键弹出菜单
  • 如何禁用右键菜单
  • 如何修改菜单样式
  • 菜单位置设置


本篇博客介绍WPF点击按钮弹出菜单,效果如下:

在这里插入图片描述
菜单的位置、央视可以自定义。
实现技巧:不在xaml里菜单,在按钮左键按下的点击事件里写,弹出菜单需要用到ContextMenu。

ContextMenu介绍

ContextMenu 是 WPF 中的一个控件,它允许你在用户执行特定动作(通常是右键单击)时显示一个弹出式菜单。这个菜单可以包含多个菜单项,每个菜单项都可以执行一个特定的命令或者打开一个子菜单。

以下是一个简单的 ContextMenu 的例子:

<Button Content="Right Click Me"><Button.ContextMenu><ContextMenu><MenuItem Header="First Item" Click="FirstItem_Click"/><MenuItem Header="Second Item" Click="SecondItem_Click"/><MenuItem Header="Third Item" Click="ThirdItem_Click"/></ContextMenu></Button.ContextMenu>
</Button>

在这个例子中,我们创建了一个包含三个菜单项的上下文菜单。当这些菜单项被单击时,它们会触发相应的 Click 事件处理器。

ContextMenu 控件还提供了一些属性和事件,让你可以更加精细地控制菜单的行为和外观。例如:

  • IsOpen 属性:这个属性表示菜单是否当前是打开的。你可以设置这个属性来手动打开或者关闭菜单。
  • Placement 属性:这个属性允许你控制菜单的位置。你可以使菜单出现在目标元素的左边、右边、上方、下方,或者在鼠标指针的当前位置。
  • Closed 事件:这个事件在菜单被关闭时触发,无论是由于用户选择了一个菜单项,还是由于其他原因(例如,用户点击了菜单以外的地方)。

注意,虽然 ContextMenu 通常与用户的右键单击动作关联,但你也可以在其他情况下显示 ContextMenu。例如,你可以在用户点击一个按钮或者选择一个菜单项时显示 ContextMenu。这可以通过设置 IsOpen 属性或者调用 ContextMenuIsOpen 方法来实现。

最后,你还可以通过定义样式和模板来自定义 ContextMenuMenuItem 的外观。这使得你可以创建符合你应用程序视觉主题的菜单。

WPF实现点击鼠标左键弹出菜单

代码如下:

private void Btn2_Click(object sender, RoutedEventArgs e)
{// 引用按钮ContextMenu contextMenu = new ContextMenu();contextMenu.Style = (Style)FindResource("ContextMenuStyle");MenuItem menuItem1 = new MenuItem { Header = "Option 1" };menuItem1.Click += MenuItem_Click;menuItem1.Style = (Style)FindResource("MenuItemStyle");contextMenu.Items.Add(menuItem1);MenuItem menuItem2 = new MenuItem { Header = "Option 2" };menuItem2.Click += MenuItem_Click;menuItem2.Style = (Style)FindResource("MenuItemStyle");contextMenu.Items.Add(menuItem2);MenuItem menuItem3 = new MenuItem { Header = "Option 3" };menuItem3.Click += MenuItem_Click;menuItem3.Style = (Style)FindResource("MenuItemStyle");contextMenu.Items.Add(menuItem3);contextMenu.Closed += ContextMenu_Closed;btn2.ContextMenu = contextMenu;contextMenu.PlacementTarget = btn2;// 显示在按钮下方// contextMenu.Placement = System.Windows.Controls.Primitives.PlacementMode.Bottom;// 任意调整位置contextMenu.Placement = System.Windows.Controls.Primitives.PlacementMode.RelativePoint;contextMenu.HorizontalOffset = 10;contextMenu.VerticalOffset = btn2.Height;btn2.ContextMenu.IsOpen = true;
}

如何禁用右键菜单

同时需要禁用掉右键菜单,因为ContextMenu是右键菜单,在按钮上右击鼠标时也会弹出菜单,不符合设计预期,链接ContextMenu的Closed事件,当ContextMenu关闭时把ContextMenu设为空,代码如下:

// 在关闭上下文菜单时,将其从按钮中移除
private void ContextMenu_Closed(object sender, RoutedEventArgs e)
{btn2.ContextMenu = null;
}

菜单项事件:

private void MenuItem_Click(object sender, RoutedEventArgs e)
{MenuItem menuItem = (MenuItem)sender;MessageBox.Show("You clicked " + menuItem.Header);
}

如何修改菜单样式

菜单样式修改和常规的xaml写法不同,因为此时的菜单是在C#代码里写的,但是可以通过资源的形式设置,xaml代码如下:

<Window x:Class="WpfControl_Button.MainWindow"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:WpfControl_Button"mc:Ignorable="d"Title="MainWindow" Height="450" Width="800"><!--按你菜单样式,在cs代码里可以调用,然后设置菜单的样式--><Window.Resources><Style TargetType="ContextMenu" x:Key="ContextMenuStyle"><Setter Property="Background" Value="LightGray"/><Setter Property="Foreground" Value="Black"/></Style><Style TargetType="MenuItem" x:Key="MenuItemStyle"><Setter Property="Background" Value="LightBlue"/><Setter Property="Foreground" Value="Black"/></Style></Window.Resources><Grid><Canvas><Button x:Name="btn" Content="Button" Canvas.Left="20" Canvas.Top="100" Width="100" Height="50" Click="btn_Click"/><Button x:Name="btn2" Content="Button2" Canvas.Left="200" Canvas.Top="100" Width="100" Height="50" Click="Btn2_Click"/></Canvas></Grid>
</Window>

在C#代码里查找设置ContextMenuStyle和MenuItemStyle即可实现菜单的样式修改。

菜单位置设置

使用Placement属性可以控制ContextMenu的弹出位置。PlacementMode枚举提供了多种可选的位置模式:

Absolute:弹出菜单的左上角在屏幕的特定位置。
AbsolutePoint:弹出菜单在屏幕上的特定位置。
Bottom:弹出菜单在其目标的下方。
Center:弹出菜单位于其目标的中央。
Left:弹出菜单位于其目标的左边。
Mouse:弹出菜单在鼠标位置。
MousePoint:弹出菜单在鼠标位置,同Mouse。
Relative:弹出菜单相对于其目标的特定位置。
RelativePoint:弹出菜单相对于其目标的特定位置。
Right:弹出菜单位于其目标的右边。
Top:弹出菜单在其目标的上方。
如果你想要在任意位置显示ContextMenu,你可以使用Absolute或AbsolutePoint模式,并设置HorizontalOffset和VerticalOffset属性来指定菜单的具体位置。

需要注意的是,一定要设置菜单的目标控件,然后再设置位置,代码如下:

contextMenu.PlacementTarget = btn2;// 显示在按钮下方
// contextMenu.Placement = System.Windows.Controls.Primitives.PlacementMode.Bottom;// 任意调整位置
contextMenu.Placement = System.Windows.Controls.Primitives.PlacementMode.RelativePoint;
contextMenu.HorizontalOffset = 10;
contextMenu.VerticalOffset = btn2.Height;

上面代码使用的是相对位置RelativePoint,然后做便宜来调整弹出菜单的位置。

相关文章:

WPF Button点击鼠标左键弹出菜单

目录 ContextMenu介绍WPF实现点击鼠标左键弹出菜单如何禁用右键菜单如何修改菜单样式菜单位置设置 本篇博客介绍WPF点击按钮弹出菜单&#xff0c;效果如下&#xff1a; 菜单的位置、央视可以自定义。 实现技巧&#xff1a;不在xaml里菜单&#xff0c;在按钮左键按下的点击事件里…...

http库requests

http库requests requets简介第一个requestsrequests发送基本的HTTP请求requests处理请求参数requests处理响应requests处理Cookiesrequests处理sessionrequests使用代理requests设置请求头requests处理SSL证书验证requests错误处理和异常处理requests连接池requests请求重试...

package.json 依赖版本中的符号含义

依赖包的版本问题 实例说明~1.2.3主版本次要版本补丁版本;1.2.3 < version < 1.3.0;~1.2主版本次要版本;1.2.0 < version < 1.3.0~1主版本;1.0.0 < version < 2.0.0 符号实例版本范围说明1.0.01.0.0锁定1.0.0版本&#xff0c;必须这个版本。^会匹配最新的大…...

Python try except 用法

关键字解释trytry 就是执行代码的部分&#xff0c;但是对这部分代码没有信心就试一试嘛&#xff0c;这就是tryexcept很不幸&#xff0c;试的时候有错误&#xff0c;没事儿&#xff0c;except 帮你来兜底&#xff0c;它会输出错误&#xff0c;并继续执行下去else程序没有错误&am…...

代码随想录二刷 | 链表 | 翻转链表

代码随想录二刷 &#xff5c; 链表 &#xff5c; 翻转链表 题目描述解题思路 & 代码实现双指针法递归法 206.翻转链表 题目描述 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4…...

每日一题(LeetCode)----链表--两两交换链表中的节点

每日一题(LeetCode)----链表–两两交换链表中的节点 1.题目&#xff08;[24. 两两交换链表中的节点](https://leetcode.cn/problems/spiral-matrix/)&#xff09; 给你一个链表&#xff0c;两两交换其中相邻的节点&#xff0c;并返回交换后链表的头节点。你必须在不修改节点内…...

竞赛选题 身份证识别系统 - 图像识别 深度学习

文章目录 0 前言1 实现方法1.1 原理1.1.1 字符定位1.1.2 字符识别1.1.3 深度学习算法介绍1.1.4 模型选择 2 算法流程3 部分关键代码 4 效果展示5 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 毕业设计 图像识别 深度学习 身份证识别…...

什么时候用@MapperScan 注解?

hello,我是小索奇&#xff0c;给大家讲解一下MapperScan注解的用法。 MapperScan 注解是 MyBatis 框架中的一个注解&#xff0c;它的主要作用是扫描指定包路径下的 Mapper 接口&#xff0c;将其注册为 Spring 的 Bean。这样&#xff0c;在使用 MyBatis 进行数据库操作时&#…...

MQTT.js

MQTT.js mqtt.js简介MQTT测试工具mqttboxMQTTX mqtt使用mqtt引入&#xff08;方式一&#xff09;mqtt引入&#xff08;方式二&#xff09;创建mqtt客户端连接到mqtt代理订阅topic处理接收到的消息重新连接取消订阅发布消息断开连接关闭客户端MQTT APIMQTT在VUE中使用MQTT在Reac…...

html滑动文章标题置顶

position: sticky; 基于用户的滚动位置来定位 首先封装一个组件 例如&#xff1a;AAA组件&#xff08;注意&#xff0c;只能有一层盒子&#xff0c;不能在外面继续包一层div&#xff09; <template><div class"box">{{title}}</div> </templa…...

Android11 桌面默认横屏导致任务键近期任务布局UI显示错误!

/frameworks/base/services/core/java/com/android/server/policy/PhoneWindowManager.java 定义变量&#xff1a;private boolean stch false; keyCode KeyEvent.KEYCODE_APP_SWITCH 取消原来逻辑&#xff0c;采用广播打开近期任务后台 /*/ if (!keyguardOn…...

「Verilog学习笔记」根据状态转移图实现时序电路

专栏前言 本专栏的内容主要是记录本人学习Verilog过程中的一些知识点&#xff0c;刷题网站用的是牛客网 这是一个典型的米利型状态机。三段式即可解决。 米利型状态机&#xff1a;即输出不仅和当前状态有关&#xff0c;也和输入有关。 其中ST0&#xff0c;ST1&#xff0c;ST3的…...

使用DHorse发布SpringBoot项目到K8S

前言 在介绍DHorse的操作之前&#xff0c;先来介绍一下使用k8s发布应用的步骤&#xff0c;以SpringBoot应用为例进行说明。 1.首先从代码仓库下载代码&#xff0c;比如GitLab&#xff1b; 2.接着进行构建&#xff0c;比如使用Maven&#xff1b; 3.如果要使用k8s作为编排&am…...

Java修仙记之记录一次与前端女修士论道的经历

文章开始之前&#xff0c;想跟我念一句&#xff1a;福生无量天尊&#xff0c;无量寿佛&#xff0c;阿弥陀佛 第一场论道&#xff1a;id更新之争 一个天气明朗的下午&#xff0c;前端的小美女长发姐告诉我&#xff1a;嘿&#xff0c;小后端&#xff0c;你的代码报错了 我答道&am…...

初识linux(1)

文章目录 什么是linux什么是操作系统&#xff1f;开源 怎么装linux的环境基础指令lspwdcdtouchmkdirrmdir与rmmancpmv 什么是linux linux是一款开源操作系统 什么是操作系统&#xff1f; 操作系统&#xff1a;一种对计算机所有计算机软硬件进行控制和管理的系统软件 开源 开源&…...

投资黄金:如何选择正确的黄金品种增加收益?

黄金一直以来都是备受投资者青睐的避险资产&#xff0c;然而&#xff0c;在庞大的黄金市场中&#xff0c;选择适合自己的黄金品种成为影响收益的关键因素。黄金投资并不只有一种方式&#xff0c;而是有很多种不同的黄金品种可以选择。每种黄金品种都有其独特的特点和风险&#…...

Rust错误处理机制:优雅地管理错误

大家好&#xff01;我是lincyang。 今天&#xff0c;我们要探讨的是Rust语言中的错误处理机制。 Rust作为一种系统编程语言&#xff0c;对错误处理的重视程度是非常高的。它提供了一套既安全又灵活的机制来处理可能出现的错误。 Rust错误处理的两大类别 在Rust中&#xff0…...

docker-compose安装harbor

docker-compose安装harbor 环境&#xff1a;centos7 1、安装docker 官方文档 https://docs.docker.com/engine/install/centos/ 1、卸载旧版本 $ sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate …...

【python学习】基础篇-常用模块-shutil文件和目录操作

shutil模块是Python标准库中的一个模块&#xff0c;提供了对文件和目录进行高级操作的函数。 以下是shutil模块的一些常用函数&#xff1a; 1.复制文件&#xff1a; 将源文件src复制到目标文件dst。如果follow_symlinks为True,则会跟随符号链接。 shutil.copy(src, dst, *, f…...

鸿蒙系统调研适配

写在前面&#xff1a; 以下内容基于我个人翻阅的官方资料以及自己的理解写的&#xff0c;可能存在认知和理解上的偏差&#xff0c;有些地方并不一定是对的&#xff0c;请谨慎对待&#xff0c;注意甄别&#xff01; 一、鸿蒙OS是什么&#xff1f; 华为推出的多端统一平台&…...

终极指南:如何在Windows上使用com0com虚拟串口驱动实现零成本串口通信

终极指南&#xff1a;如何在Windows上使用com0com虚拟串口驱动实现零成本串口通信 【免费下载链接】com0com Null-modem emulator - The virtual serial port driver for Windows. Brought to you by: vfrolov [Vyacheslav Frolov](http://sourceforge.net/u/vfrolov/profile/)…...

React聊天机器人组件集成指南:从UI定制到AI后端连接

1. 项目概述与核心价值最近在折腾一个基于React的前端聊天机器人项目&#xff0c;核心想法是把类似ChatGPT的对话交互体验&#xff0c;无缝集成到自己的Web应用里。这个需求其实挺普遍的&#xff0c;无论是做客服助手、智能问答面板&#xff0c;还是想给自己的产品加个AI对话的…...

MATLAB|抽水蓄能电站系统的最优竞价策略研究

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…...

在Node.js后端服务中集成Taotoken实现多模型智能对话功能

&#x1f680; 告别海外账号与网络限制&#xff01;稳定直连全球优质大模型&#xff0c;限时半价接入中。 &#x1f449; 点击领取海量免费额度 在Node.js后端服务中集成Taotoken实现多模型智能对话功能 为Node.js后端服务添加智能对话能力&#xff0c;是现代应用开发中的常见…...

2026届学术党必备的降AI率神器实测分析

Ai论文网站排名&#xff08;开题报告、文献综述、降aigc率、降重综合对比&#xff09; TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 作为一款基于自然语言处理跟深度学习技术的智能辅助工具&#xff0c;AI 写作软件可以快速生成…...

从URDF到真实控制:手把手教你用ros2_control驱动一个两关节机器人(RRBot实战)

从URDF到真实控制&#xff1a;手把手教你用ros2_control驱动一个两关节机器人&#xff08;RRBot实战&#xff09; 当你第一次尝试让URDF模型在ROS2中真正动起来时&#xff0c;ros2_control框架可能会让你既兴奋又困惑。这个看似简单的目标背后&#xff0c;隐藏着硬件接口、控制…...

告别固定类别!用YOLO-World v2模型,5分钟实现自定义物体检测(附Python代码)

5分钟定制专属AI检测器&#xff1a;YOLO-World v2实战指南 去年帮朋友改造智能花房时&#xff0c;遇到个头疼的问题——市面上现成的物体检测模型根本识别不出他那些稀有兰花品种。正当我准备动手标注上千张图片重新训练模型时&#xff0c;偶然发现了YOLO-World这个"变形…...

HCOMM获取拓扑层级rank数量

HcclRankGraphGetRankSizeByLayer 【免费下载链接】hcomm HCOMM&#xff08;Huawei Communication&#xff09;是HCCL的通信基础库&#xff0c;提供通信域以及通信资源的管理能力。 项目地址: https://gitcode.com/cann/hcomm 产品支持情况 Ascend 950PR/Ascend 950DT&…...

基于时空图对比学习的尼古丁成瘾脑功能环路识别方法

1. 项目概述&#xff1a;从“烟瘾”到“脑环路”的科学解码干了这么多年神经影像数据分析&#xff0c;我越来越觉得&#xff0c;很多看似复杂的成瘾行为&#xff0c;其背后的大脑“电路图”其实有迹可循。就拿尼古丁成瘾来说&#xff0c;我们常听到“戒烟难”、“心瘾难除”&am…...

TPFanCtrl2:ThinkPad风扇控制的终极解决方案

TPFanCtrl2&#xff1a;ThinkPad风扇控制的终极解决方案 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 你是否厌倦了ThinkPad风扇在安静办公时突然狂转&#xff1f;或…...