Collabora Office 21.06 帮助
建立一个收听者实例。
许多 Uno 接口允许您在特定的监听器接口上注册监听器,这样就可以侦听特定的事件,并可以调用适当的监听器方法。CreateUnoListener 函数等待调用的监听器接口,然后将一个该接口支持的对象传送给接口。接着该对象被传送到注册监听器的方法中。
oListener = CreateUnoListener( Prefixname, ListenerInterfaceName )
以下示例以一个 Basic 库对象为例。
Dim oListener
oListener = CreateUnoListener( "ContListener_","com.sun.star.container.XContainerListener" )
CreateUnoListener 方法需要两个参数。第一个参数是一个前缀,下面对它进行了详细介绍。第二个参数是要使用的收听者接口的全限定名称。
然后,需要将收听者加入到广播对象中,通过调用相应的方法来加入收听者即可实现此操作。有关方法通常位于「addFooListener」模式后面,其中「Foo」是收听者接口类型 (无「X」)。在此示例中,调用 addContainerListener 方法来注册 XContainerListener:
Dim oLib
oLib = BasicLibraries.Library1 ' Library1 必须存在!
oLib.addContainerListener( oListener ) ' 注册收听者
这样就注册了监听器。当事件发生时,相应的监听器将从 com.sun.star.container.XContainerListener 接口中调用适当的方法。
前缀将从 Basic 子例程中调用已注册的收听者。Basic 运行时系统搜寻并调用名为「PrefixListenerMethode」的 Basic 子例程或函数。如果不成功,将发生运行时错误。
在此示例中,收听者接口使用了以下方法:
disposing:
收听者基本接口 (com.sun.star.lang.XEventListener): 所有收听者接口的基本接口
elementInserted:
com.sun.star.container.XContainerListener 接口的方法
elementRemoved:
com.sun.star.container.XContainerListener 接口的方法
elementReplaced:
com.sun.star.container.XContainerListener 接口的方法
在此示例中,前缀是 ContListener_,因此,需要在 Basic 中执行以下子例程:
ContListener_disposing
ContListener_elementInserted
ContListener_elementRemoved
ContListener_elementReplaced
每个收听者类型中都存在一个含有事件信息的事件结构类型。当调用收听者方法时,会将此事件的一个实例作为参数传送到方法。只要子程序声明中传送了相应的参数,Basic 收听者方法就会调用这些事件对象。例如:
Sub ContListener_disposing( oEvent )
MsgBox "disposing"
MsgBox oEvent.Dbg_Properties
End Sub
Sub ContListener_elementInserted( oEvent )
MsgBox "elementInserted"
MsgBox oEvent.Dbg_Properties
End Sub
Sub ContListener_elementRemoved( oEvent )
MsgBox "elementRemoved"
MsgBox oEvent.Dbg_Properties
End Sub
Sub ContListener_elementReplaced( oEvent )
MsgBox "elementReplaced"
MsgBox oEvent.Dbg_Properties
End Sub
如果不使用事件对象,则无需包括对象参数:
' 最小的子程序处置实现
Sub ContListener_disposing
End Sub
「始终」都必须实现收听者方法,以避免 Basic 运行时错误。