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

以上代码运行后会在单元格右键菜单上增加一个"查看菜单"菜单项,位置在第一个。如下图所示:

23 增加自定义菜单项

如果把代码中

Before:=1

修改为

Before:=5

那么菜单项将增加到第5个位置,如下图所示:

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

相关推荐
ZC跨境爬虫19 小时前
跟着 MDN 学CSS day_27:(处理不同方向的文本)
前端·javascript·css·ui·html
巴巴博一19 小时前
【AI 赋能前端】告别手写样式!ui-ux-pro-max-skill 插件完整使用指南(附高阶 Prompt 模板)
前端·css·人工智能·ui
仰望.20 小时前
vxe-table 导出 Excel 进阶教程:自定义样式与高级功能
前端·javascript·vue.js·excel·vxe-table·vxe-ui
ZC跨境爬虫20 小时前
跟着 MDN 学CSS day_24:(CSS调试完全指南)
前端·css·ui·html·tensorflow
ZC跨境爬虫1 天前
跟着 MDN 学CSS day_21:(图像溢出控制与表单元素样式定制)
前端·javascript·css·ui·交互
Access开发易登软件1 天前
Access 和 SQLite,根本不在一个赛道上
java·jvm·数据库·sqlite·excel·vba·access开发
FrameNotWork1 天前
HarmonyOS 智感握姿开发指南:让 UI 跟着握姿自动换边
ui·华为·harmonyos
ting94520001 天前
深度解析 Google Stitch 3.0:文本驱动跨端 UI 生成技术原理、架构与工程实现
人工智能·ui·架构
UXbot2 天前
无需设计经验也能做原型:AI辅助工具功能评测
前端·人工智能·低代码·ui·ios·交互
ZC跨境爬虫2 天前
跟着 MDN 学CSS day_23:(表单与表格综合样式化实战)
前端·javascript·css·ui·html·tensorflow