问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

C# excel addin如何实现Ribbon上一个按钮显示一个UserControl?

发布网友 发布时间:2022-05-01 21:54

我来回答

1个回答

热心网友 时间:2023-10-05 08:05

得把uc 添加到CustomTaskPaneCollection 中才行
给你一个参考:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Xml.Linq;
using Word = Microsoft.Office.Interop.Word;
using Office = Microsoft.Office.Core;
using Microsoft.Office.Tools.Word;
using Microsoft.Office.Tools;
namespace FinWordHelper
{
public partial class ThisAddIn
{
private void ThisAddIn_Startup(object sender, System.EventArgs e)
{
this.Application.DocumentOpen += Application_DocumentOpen;
this.Application.DocumentChange += Application_DocumentChange;
}
void Application_DocumentChange()
{
FinPaneManager.Instance.CollectWordPanes();
}

void Application_DocumentOpen(Word.Document Doc)
{
FinPaneManager.Instance.CollectWordPanes();
}
private void ThisAddIn_Shutdown(object sender, System.EventArgs e)
{
}
#region VSTO 生成的代码
/// <summary>
/// 设计器支持所需的方法 - 不要
/// 使用代码编辑器修改此方法的内容。
/// </summary>
private void InternalStartup()
{
this.Startup += new System.EventHandler(ThisAddIn_Startup);
this.Shutdown += new System.EventHandler(ThisAddIn_Shutdown);
}

#endregion
}
#region FinPaneManager
public class FinPaneManager
{
private FinPaneManager()
{
custPanes = Globals.ThisAddIn.CustomTaskPanes;
}
private static FinPaneManager m_Instance = new FinPaneManager();
public static FinPaneManager Instance
{
get { return m_Instance; }
}
private CustomTaskPaneCollection custPanes;
public CustomTaskPane GetFinWordFormatPane()
{
Word.Window window = Globals.ThisAddIn.Application.ActiveWindow;
foreach (CustomTaskPane ctp in custPanes)
{
if (ctp.Title == "Fin格式化工具" && ctp.Window == window)
{
return ctp;
}
}
var cp = custPanes.Add(
new WordFormatter(),
"Fin格式化工具",
window
);
cp.Width = 250;
return cp;
}
public CustomTaskPane GetFinWordCheckPane()
{
Word.Window window = Globals.ThisAddIn.Application.ActiveWindow;
foreach (CustomTaskPane ctp in custPanes)
{
if (ctp.Title == "拼写检查" && ctp.Window == window)
{
return ctp;
}
}
var cp = custPanes.Add(
new WordSpellCheck(),
"拼写检查",
window
);
cp.Width = 250;
return cp;
}
public void CollectWordPanes()
{
for (int i = custPanes.Count - 1; i >= 0; i--)
{
if (custPanes[i].Window == null)
{
custPanes.RemoveAt(i);
}
}
}
}
#endregion
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using Microsoft.Office.Tools.Ribbon;
namespace FinWordHelper
{
public partial class CustomRibbon //按钮调用在这里
{
private void CustomRibbon_Load(object sender, RibbonUIEventArgs e)
{
}
private void button1_Click(object sender, RibbonControlEventArgs e)
{
FinPaneManager.Instance.GetFinWordFormatPane().Visible = true;
}
private void button2_Click(object sender, RibbonControlEventArgs e)
{
FinPaneManager.Instance.GetFinWordCheckPane().Visible = true;
}
}
}
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
乾隆小时候的书童是谁 下面对句式判断有误的一项是( ) A.当立者乃公子扶苏(判断句) ...为折线,把 折起,使平面 平面 ,连接 (1)求证: ;(2)求二面角 图中由线段OA、AB组成的折线表示的是小明步行所走的路程和时间之间的关... 动态图像粒度粒形分析仪 oppor9splus视频通话怎么开美颜 微信视频聊天怎么开美颜oppor9 谁家出售二手胶囊填充机NJP1200 NJP-1200A硬胶囊填充机仪器特点简介 NJP-1200A硬胶囊填充机仪器参数 dotnetbar ribbonControl中按钮下拉菜单的问题 如何修改ribbon控件的宽度 如何添加 devexpress.xtrabars.ribbon.ribboncontrol 如何引用iribboncontrol控件类型 我想将dotnetbar中的RibbonControl功能区最小化,求代码!或相关的属性 wpf中Ribbon控件的使用问题 c# 第三方控件 如何隐藏RibbonControl的最大化&#47;最小化按钮,我的form是继承Ribbonform求大神帮助 dotnetbar ribboncontrol的问题 ppt在美国又叫什么? 什么是 PPT 为什么Google slides里的几页PPT丢失 ScienceSlides 2005 在PPT里没有加载项 Ppt vba 如何设置,每个slide的放映时间,比如放映后,每格5分钟自动切换slides1到 08日本电影《收敛师》哪有的看? 怎么样才可以招收更多的代理,我都免费送代理了,还是没人来啊 有微商招代理吗 微商有免费招代理的吗 求几篇小学生关于师德师风的朗诵稿 如何运用宏随机排列PPT里的slides? 听教师师德师风演1o月24日新阳街小学 招生代理一般上哪找 C# devexpress ribbonControl 左上角 图标 怎样弄出来呢? windows7VS2013无法使用ribbon 如何在应用程序中添加BCGControlBar的Ribbon控件 DevExpress控件ribbon 怎么默认收缩 VB.NET如何往Ribbon中添加东西 怎么替换devExpress 的ribbon控件左上角的工具菜单的图标&quot;dx Excel的VBA运行错误,请大师帮忙看下如何解决谢谢! dev 在ribbon菜单上添加控件吗 容器控件中怎么调用XtraUserControl控件 还是VBA代码的问题,请高手解释一下? 女性朋友过生日发多少合适 女性朋友的生日红包发多少比较好 女性朋友过50岁生日送多少红包合适? 女性明友过29岁生日,发多少红包好? 女孩18生日发多少红包 生日发红包一般发多少合适 我一女性朋友明天过19生日 我今天晚上12点想给她发个红包祝她生日快乐 发19块钱行吗 给女性朋友发多少生日红包好 女性朋友过生日,发多少钱红包有意义 一个女性好朋友过19岁生日,要发多少红包给他 卡士发酵箱发面后为什么面很粘?