如何解决读取自定义文档属性的公共值并使其在功能区中被选中
DocumentProperties properties;
var wb = Globals.ThisAddIn.Application.ActiveWorkbook;
or
var wb = Globals.ThisAddIn.Application.ThisWorkbook;
if (wb is null)
{
return "";
}
properties = ( DocumentProperties)wb.CustomDocumentProperties;
foreach (DocumentProperty prop in properties)
{
if (prop.Name == propertyName)
{
return prop.Value.ToString();
}
}
打开excel时ActiveWorkbook和ThisWorkbook都为空。
我想要做的是读取 customdocumentproperties 的公共值并在功能区中选中它。
解决方法
不清楚这些值是否已知和预定义。让我们考虑这两种情况,然后...
-
如果值是预定义的,您可以根据预定义控件列表设计自定义 UI。通过使用
getEnabled
回调,您可以管理按钮状态。例如,默认情况下,控件被禁用并显示为灰色。只要用户打开具有自定义文档属性的文档,您就可以读取值并强制刷新自定义功能区 UI。IRibbonUI
接口的 Invalidate 或 InvalidateControl 方法允许使功能区用户界面的所有控件(或特定控件)的缓存值无效。 -
在未知值的情况下,您可以使用可在运行时填充的控件。因此,当打开文档并读取自定义文档属性时,您可以在运行时使用
getContent
控件的dynamicMenu
回调填充控件。回调的签名如下所示:
C#: string GetContent(IRibbonControl control)
VBA: Sub GetContent(control As IRibbonControl,ByRef content)
C++: HRESULT GetContent([in] IRibbonControl *pControl,[out,retval] BSTR *pbstrContent)
Visual Basic: Function GetContent(control As IRibbonControl) As String
在以下系列文章中阅读有关 Fluent UI(又名 Ribbon UI)的更多信息:
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。