在excel 2007中,我们可以右键单击功能区并选择"最小化功能区"并将其最小化.
我试过了
Application.ExecuteExcel4Macro("show.toolbar(\"ribbon\",false)");
Run Code Online (Sandbox Code Playgroud)
它隐藏了整条色带但我不想隐藏整条色带.
我甚至试过了
Application.SendKeys("^{F1}", true);
Run Code Online (Sandbox Code Playgroud)
但它不可靠,因为有时它不能正常工作.

有没有办法使用C#VSTO代码?
我读了很多关于toggleribbon()功能的但是找不到使用它的方法.
编辑: 有一种方法可以实际找到功能区是否已经最小化.我用了
Office.CommandBars cbs = null;
cbs = Application.CommandBars;
foreach (Office.CommandBar cb in cbs)
{
if (cb.Name == "Ribbon")
{
if (cb.Height > 90)
{
this.Application.ActiveWindow.Activate();
//to get focus on current workbook so that sendkeys will work
Application.SendKeys("^{F1}", true);
}
}
}
Run Code Online (Sandbox Code Playgroud)
SendKeys CTRL+F1有效,但这似乎是执行的时间问题。真正的问题是您不知道功能区何时实际加载到 Excel 中以触发该行为。
这段代码对我来说似乎工作可靠,但它实际上取决于您的加载项加载的速度。如果需要的话您也可以利用Thread.Sleep()。
private void ThisAddIn_Startup(object sender, System.EventArgs e)
{
Task.Factory.StartNew(() => {
//Thread.Sleep(1000); // optional
Application.SendKeys("^{F1}");
}, TaskCreationOptions.AttachedToParent);
}
Run Code Online (Sandbox Code Playgroud)