在用Java编写的OpenOffice / LibreOffice Calc(Spreadsheet)的UNO扩展中,如何确定UDF(电子表格函数)实现中的调用单元?
Remarks
-
在Excel / VBA中,这可以通过
Application.Caller
实现 -
获取调用者的主要动机是记录/跟踪/调试,即将调用单元视为堆栈跟踪的一部分 .
-
应该可以获得此信息,因为像"ROW()"和"COLUMN()"这样的内置函数确实具有调用单元的一些知识 .
-
使用此可能性的应用程序(对于Excel)是Obba,电子表格的对象处理程序 . 这里"control panel"提供(Java)异常列表,包括调用单元,即,单元是堆栈跟踪的一部分 . 请参阅以下屏幕截图:
这也是Apache OpenOffice Bugzilla上的功能请求
1 回答
看起来您想要将监听器注册到电子表格组件 . 为了满足您的目标,您可以将侦听器添加到它自己的电子表格对象中,或者添加到另一个实现支持添加的接口的嵌套对象 . EventListener()方法 .
下面是一对(广播/听众),我认为你可以在你的项目中使用:XDocumentEventBroadcaster / XDocumentEventListener
这里解释了UNO事件模型:https://wiki.openoffice.org/wiki/Documentation/DevGuide/ProUNO/Event_Model
以下是如何使用这些侦听器的示例 .
此外,服务SheetCellRange支持XModifyBroadcaster接口 . 如果您向其注册了XModifyListener对象,也许可以获得所需的行为 . 该对象将实现'modified'方法,该方法在调用时接收EventObject . 我相信你可以从EventObject的source属性中获取调用者 . 如果源是整个SheetCellRange,您可以尝试遍历您希望监视的所有单元格,并为每个单元格添加一个XModifyListener . SheetCell服务还支持XModifyBroadcaster接口 .
从CellRange使用XModifyBroadcaster的示例:http://openoffice.2283327.n4.nabble.com/Re-How-to-get-the-XModifyBroadcaster-from-Cell-CellRange-Table-td2771959.html
干杯!