Excel VSTO开发11-自定义菜单项

版权声明:本文为博主原创文章,转载请在显著位置标明本文出处以及作者网名,未经作者允许不得用于商业目的。

11 自定义菜单项

自定义菜单项可以在插件启动时候添加,即增加到ThisAddIn_Startup() 内。

下面以具体代码说明:

代码7\] 增加自定义菜单项 '插件启动时候 Private Sub ThisAddIn_Startup() Handles Me.Startup ...... Call addMenu() End Sub Private Sub addMenu() '单元格右键时候的弹出菜单 Dim cMenuControl As Office.CommandBar = Globals.ThisAddIn.Application.CommandBars("Cell") '增加菜单项到菜单第一个 Dim cButtonControl As Microsoft.Office.Core.CommandBarControl = cMenuControl.Controls.Add(Microsoft.Office.Core.MsoControlType.msoControlButton, Before:=1) '转换为CommandBarButton Dim cButton As Microsoft.Office.Core.CommandBarButton = CType(cButtonControl, Microsoft.Office.Core.CommandBarButton) cButton.Caption = "查看菜单" cButton.Tag = "这是自定义菜单项" cButton.FaceId = 22 '增加菜单项按下事件 AddHandler cButton.Click, AddressOf menu_click End Sub 以上代码运行后会在单元格右键菜单上增加一个"查看菜单"菜单项,位置在第一个。如下图所示: ![](https://file.jishuzhan.net/article/1700852870951211010/de4147a761d34d93b7ecaa164060ac2d.jpeg) ******图**** ****23**** ****增加自定义菜单项****** 如果把代码中 Before:=1 修改为 Before:=5 那么菜单项将增加到第5个位置,如下图所示: ![](https://file.jishuzhan.net/article/1700852870951211010/ae4d36eda88245fdbf202ada21f29ea3.jpeg) ******图**** ****2**** ****4**** ****自定义菜单项位置改变后****** 在实际中,以上代码会存在一定问题,读者可以测试,当运行多次后会发现多出很多相同的菜单项,也就是菜单项重复被添加。 修改后的代码如下: Private Sub addMenu() '单元格右键时候的弹出菜单 Dim cMenuControl As Office.CommandBar = Globals.ThisAddIn.Application.CommandBars("Cell") '列出当前菜单的所有菜单项 For Each cControl As Microsoft.Office.Core.CommandBarControl In cMenuControl.Controls '下面一句代码可以输出当前所有菜单项 'System.Diagnostics.Debug.WriteLine(cControl.Caption \& " " \& cControl.Id) ' 如果已经存在我们自定义的菜单项 If cControl.Caption = "查看菜单" Then '1、可以退出 'Exit Sub '2、可以将之前已经存在的菜单项删除 cControl.Delete() End If Next '增加菜单项到菜单第一个 Dim cButtonControl As Microsoft.Office.Core.CommandBarControl = cMenuControl.Controls.Add(Microsoft.Office.Core.MsoControlType.msoControlButton, Before:=1) '转换为CommandBarButton Dim cButton As Microsoft.Office.Core.CommandBarButton = CType(cButtonControl, Microsoft.Office.Core.CommandBarButton) cButton.Caption = "查看菜单" cButton.Tag = "这是自定义菜单项" cButton.FaceId = 22 '增加菜单项按下事件 AddHandler cButton.Click, AddressOf menu_click End Sub 顺便将自定义菜单项的事件增加如下: '菜单项按下事件:列出所有的命令栏ID和名称 Public Sub menu_click(ByVal control As Office.CommandBarButton, ByRef cancelDefault As Boolean) '在Excel里面随时记住从1开始,而非vb中的0开始 Dim i As Integer = 1 Dim Wbook As Excel.Workbook = Application.Workbooks(1) Dim Wsheet As Excel.Worksheet Wsheet = Wbook.Worksheets("sheet1") For Each cMenuControl As Office.CommandBar In Globals.ThisAddIn.Application.CommandBars Wsheet.Cells(i, 1).Value = cMenuControl.Id Wsheet.Cells(i, 2).Value = cMenuControl.Name Select Case cMenuControl.Type Case 0 Wsheet.Cells(i, 3).Value = "msoBarTypeNormal" Case 1 Wsheet.Cells(i, 3).Value = "msoBarTypeMenuBar" Case 2 Wsheet.Cells(i, 3).Value = "msoBarTypePopup" Case Else End Select i += 1 Next MsgBox("ok") End Sub

相关推荐
UI设计兰亭妙微1 天前
医疗设备UI设计核心准则与案例拆解——以临床场景为核心的专业设计逻辑
ui·用户体验设计·移动端界面设计
hqyjzsb1 天前
从爱好到专业:AI初学者如何跨越CAIE认证的理想与现实鸿沟
大数据·c语言·人工智能·信息可视化·职场和发展·excel·业界资讯
我命由我123451 天前
Photoshop - Photoshop 工具栏(46)渐变工具
经验分享·笔记·学习·ui·职场和发展·学习方法·photoshop
许泽宇的技术分享1 天前
当AI开始“画“界面:A2UI协议如何让.NET应用告别写死的UI
人工智能·ui·.net·blazor·a2ui
vfvfb1 天前
excel对比找不同人名 双xlsx双列对比
excel·excel多列对比
我命由我123451 天前
Photoshop - Photoshop 工具栏(45)历史记录艺术画笔工具
学习·ui·职场和发展·求职招聘·职场发展·学习方法·photoshop
许泽宇的技术分享1 天前
当AI遇见UI:用.NET Blazor实现Google A2UI协议的完整之旅
人工智能·ui·.net·blazor·a2ui
holeer1 天前
React UI组件封装实战——以经典项目「个人博客」与「仿手机QQ」为例
前端·javascript·react.js·ui·前端框架·软件工程
许泽宇的技术分享1 天前
当AI遇见UI:A2UI协议在.NET Blazor中的完整实现与深度剖析
人工智能·ui·.net·a2ui