OpenOffice电子表格监听器

时间:2013-01-21 16:58:46

标签: java openoffice.org openoffice-calc libreoffice uno

我希望使用Java跟踪用户对LibreOffice / OpenOffice电子表格的输入。目前,我从the first LibreOffice examples开始,并希望附加类似于

的内容
  • com.sun.star.chart.XChartDataChangeEventListener(如here所示),也许是
  • com.sun.star.container.XContainerListener到电子表格。

我在尝试将XSpreadsheetDocument转换为XContainer时收到了NullPointerException。 我发现API文档非常难以导航,并且会感谢提示如何:

  • 找出XSpreadsheetDocument的类型层次结构,
  • 哪个侦听器附加到哪个界面,
  • 该接口的工厂链

1 个答案:

答案 0 :(得分:1)

通过猜测,我发现从XComponent加载的private:factory/scalc属于可以转换为接口com.sun.star.util.XModifyBroadcaster的服务,后者又允许安装com.sun.star.util.XModifyListener

这是一个有效的例子:

import com.sun.star.beans.PropertyValue;
import com.sun.star.comp.helper.Bootstrap;
import com.sun.star.comp.helper.BootstrapException;
import com.sun.star.frame.XComponentLoader;
import com.sun.star.lang.EventObject;
import com.sun.star.lang.XComponent;
import com.sun.star.lang.XMultiComponentFactory;
import com.sun.star.sheet.XSpreadsheetDocument;
import com.sun.star.uno.Exception;
import com.sun.star.uno.UnoRuntime;
import com.sun.star.uno.XComponentContext;
import com.sun.star.util.XModifyBroadcaster;

public class CalcListener {
    public static void main( String[] args) {
        try {
            // Lots of verbose code to get a Document instance
            final XComponentContext xRemoteContext = Bootstrap.bootstrap();
            if( xRemoteContext == null ) {
                System.err.println("ERROR: Could not bootstrap default Office.");
                return;
            }
            final XMultiComponentFactory xRemoteServiceManager = xRemoteContext.getServiceManager();
            final Object desktop = xRemoteServiceManager.createInstanceWithContext( "com.sun.star.frame.Desktop", xRemoteContext );
            final XComponentLoader xComponentLoader = (XComponentLoader) UnoRuntime.queryInterface(XComponentLoader.class, desktop);

            final PropertyValue[] loadProps = new PropertyValue[0];
            final XComponent xSpreadsheetComponent = xComponentLoader.loadComponentFromURL("private:factory/scalc", "_blank", 0, loadProps);

            // Cast to interface Document, to do anything useful later
            final XSpreadsheetDocument xSpreadsheetDocument = (XSpreadsheetDocument) UnoRuntime.queryInterface(XSpreadsheetDocument.class, xSpreadsheetComponent);

            // Cast to interface XModifyBroadcaster to attach listener
            final XModifyBroadcaster messageHost = (XModifyBroadcaster) UnoRuntime.queryInterface(XModifyBroadcaster.class, xSpreadsheetDocument );
            messageHost.addModifyListener( new XModifyListener()
            {
                public void modified(EventObject eo) {
                    System.out.println("modified:"+eo.Source);
                }

                public void disposing(EventObject eo) {
                    System.out.println("disposing:"+eo);
                }
            });

            // Do possibly useful stuff
            // ...

        } catch (BootstrapException | Exception ex) {
            System.err.println("bad things happened:"+ex);
        }
    }
}