我想知道如何从ExcelDNA生成的.dna文件中定义的自定义RibbonUI中检索控件?目前我正在实施登录工作流程,其中一个按钮被禁用。用户登录的位置,如果成功则启用禁用按钮。
答案 0 :(得分:1)
Office功能区界面完全基于回调。因此,您实际上无法检索控制权。从功能区和设置这些属性。您可以通过触发回调来实现状态更改 - 在这种情况下可能是您的getEnabled
回调。
要触发功能区失效,以便再次评估回调,可以在功能区加载时调用功能区界面上的Invalidate。
实现此功能的一些C#代码可能如下所示:
public class MyRibbon: ExcelRibbon
{
private static IRibbonUI _ribbonUi;
// This ribbon xml can be returned in code, or places in the .dna file
public override string GetCustomUI(string uiName)
{
return
@"
<customUI onLoad='Ribbon_Load'
xmlns='http://schemas.microsoft.com/office/2006/01/customui'>
<ribbon>
<tabs>
<tab idMso='TabAddIns'>
<group id='group1' label='Group1'>
<button id='button1' getEnabled='btn_GetEnabled' getLabel='btn_GetLabel' />
</group>
</tab>
</tabs>
</ribbon>
</customUI>
";
}
public void Ribbon_Load(IRibbonUI sender)
{
_ribbonUi = sender;
}
public bool btn_GetEnabled(IRibbonControl control)
{
return true;
}
public bool btn_GetLabel(IRibbonControl control)
{
return "My Button";
}
public static void Refresh()
{
if (_ribbonUi != null) { _ribbonUi.Invalidate(); }
}
}