CreateUnoListener 函数

建立一个收听者实例。

许多 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 子例程或函数。如果不成功,将发生运行时错误。

在此示例中,收听者接口使用了以下方法:

在此示例中,前缀是 ContListener_,因此,需要在 Basic 中执行以下子例程:

每个收听者类型中都存在一个含有事件信息的事件结构类型。当调用收听者方法时,会将此事件的一个实例作为参数传送到方法。只要子程序声明中传送了相应的参数,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 运行时错误。


请支持我们!