0
我開發了Excel插件到Visual Studio 2012.使用項目Excel 2010加載項。在該項目中創建了一個功能區(XML):Excel插件。缺少功能區(XMl)
[ComVisible(true)]
public class PricelistRibbon : Office.IRibbonExtensibility
{
private Office.IRibbonUI _ribbon;
public PricelistRibbon()
{
}
public event EventHandler ClickButtonRibben;
protected virtual void OnClickButtonRibben()
{
var handler = ClickButtonRibben;
if (handler != null) handler(this, EventArgs.Empty);
}
#region IRibbonExtensibility Members
public string GetCustomUI(string ribbonID)
{
return GetResourceText("ProcessingPricelist.PricelistRibbon.xml");
}
#endregion
#region Ribbon Callbacks
//Create callback methods here. For more information about adding callback methods, select the Ribbon XML item in Solution Explorer and then press F1
public void Ribbon_Load(Office.IRibbonUI ribbonUI)
{
_ribbon = ribbonUI;
}
public void OnAction(Office.IRibbonControl control)
{
OnClickButtonRibben();
}
#endregion
#region Helpers
private static string GetResourceText(string resourceName)
{
Assembly asm = Assembly.GetExecutingAssembly();
string[] resourceNames = asm.GetManifestResourceNames();
for (int i = 0; i < resourceNames.Length; ++i)
{
if (string.Compare(resourceName, resourceNames[i], StringComparison.OrdinalIgnoreCase) == 0)
{
using (StreamReader resourceReader = new StreamReader(asm.GetManifestResourceStream(resourceNames[i])))
{
if (resourceReader != null)
{
return resourceReader.ReadToEnd();
}
}
}
}
return null;
}
#endregion
}
在的ThisAddIn絲帶的工作是這樣的:
public partial class ThisAddIn
{
private void ThisAddIn_Startup(object sender, EventArgs e)
{
}
private void ThisAddIn_Shutdown(object sender, EventArgs e)
{
}
protected override Microsoft.Office.Core.IRibbonExtensibility CreateRibbonExtensibilityObject()
{
var pricelistRibbon = new PricelistRibbon();
pricelistRibbon.ClickButtonRibben += PricelistRibbonOnClickButtonRibben;
return pricelistRibbon;
}
private void PricelistRibbonOnClickButtonRibben(object sender, EventArgs eventArgs)
{
var control = sender as Office.IRibbonControl;
if (control == null) return;
try
{
Application.ScreenUpdating = false;
switch (control.Id)
{
case "customButton1":
CreateSpecification();
break;
//..............
}
}
catch (Exception throwedException)
{
MessageBox.Show(throwedException.Message, @"Ошибка", MessageBoxButtons.OK, MessageBoxIcon.Error);
}
finally
{
Application.ScreenUpdating = true;
}
}
private void CreateSpecification()
{
}
#region VSTO generated code
/// <summary>
/// Required method for Designer support - do not modify
/// the contents of this method with the code editor.
/// </summary>
private void InternalStartup()
{
Startup += ThisAddIn_Startup;
Shutdown += ThisAddIn_Shutdown;
}
#endregion
}
接下來,我通過的ClickOnce部署該插件。安裝MS Office 2007. Addin已成功部署。在這些設置中你可以看到安裝了Excel插件,但在磁帶上看不到我的TabControl。 當磁帶出現TabControl時,如果我創建功能區(可視化設計器)而不是Ribbon(xml)。我該如何解決它?
請發佈您的Ribbon.xml – Kiru 2013-04-04 13:30:12