Vytváření posluchačů událostí

Události vyvolané dialogovými okny, dokumenty, formuláři nebo grafickými ovládacími prvky je možné propojit s makry. To se označuje jako programování řízené událostmi. Nejběžnějším způsobem, jak přiřadit události makrům, je karta Události v nabídce Nástroje – Přizpůsobit a panel vlastností ovládacího prvku v editoru dialogových oken, který se spouští volbou Nástroje – Makra – Správce dialogových oken.

Prvky grafického rozhraní, vstupy z klávesnice, pohyb myší a další interakce mezi člověkem a počítačem lze sledovat pomocí posluchačů UNO. Posluchače jsou dynamické programové alternativy k přiřazeným makrům. Je možné vytvořit tolik posluchačů UNO, kolik je sledovaných událostí. Jeden posluchač také může obsluhovat více ovládacích prvků uživatelského rozhraní.

Vytvoření posluchače události

Posluchače se připojují k ovládacím prvkům dialogových oken nebo k událostem v dokumentu či formuláři. Používají se také, když se za běhu programu vytvářejí dialogová okna nebo se do nich přidávají ovládací prvky.

V tomto příkladu se vytvoří posluchač pro ovládací prvek Button4 v okně Dialog1, který je součástí knihovny Standard.

Pomocí Pythonu


         # -*- coding: utf-8 -*-
         from __future__ import unicode_literals
             
         import uno, unohelper
         from com.sun.star.awt import XActionListener
         from com.sun.star.awt import ActionEvent
         from com.sun.star.lang import EventObject
         from com.sun.star.ui.dialogs.ExecutableDialogResults \
             import OK, CANCEL
         import msgbox as util
             
         _MY_BUTTON =  "Button1"
         _MY_LABEL = 'Python naslouchá...'
         _DLG_PROVIDER = "com.sun.star.awt.DialogProvider"
             
         def Main(*args):
             ui = createUnoDialog("Standard.Dialog1", embedded=True)
             ui.Title = "Python X[any]Listener"
             ctl = ui.getControl(_MY_BUTTON)
             ctl.Model.Label = _MY_LABEL
             act = ActionListener()
             ctl.addActionListener(act)
             rc = ui.execute()
             if rc == OK:
                 MsgBox("Uživatel potvrdil dialogové okno.")
             elif rc == CANCEL:
                 MsgBox("Uživatel zrušil dialogové okno.")
             ui.dispose()  # ui.endExecute
             ctl.removeActionListener(act)
             
         def createUnoDialog(libr_dlg: str, embedded=False):
             """ Vytvoří dialogové okno z daného umístění """
             smgr = XSCRIPTCONTEXT.getComponentContext().ServiceManager
             if embedded:
                 model = XSCRIPTCONTEXT.getDocument()
                 dp = smgr.createInstanceWithArguments(_DLG_PROVIDER, (model,))
                 location = "?location=document"
             else:
                 dp = smgr.createInstanceWithContext(_DLG_PROVIDER, ctx)
                 location = "?location=application"
             dlg = dp.createDialog("vnd.sun.star.script:"+libr_dlg+location)
             return dlg
             
         class ActionListener(unohelper.Base, XActionListener):
             """ Naslouchá klepnutím na tlačítko a počítá je """
             def __init__(self):
                 self.count = 0
             
             def actionPerformed(self, evt: ActionEvent):
                 self.count = self.count + 1
                 #mri(evt)
                 if evt.Source.Model.Name == _MY_BUTTON:
                     evt.Source.Model.Label = _MY_LABEL+ str( self.count )
             return
             
             def disposing(self, evt: EventObject):  # povinná metoda
                 pass
             
         def MsgBox(txt: str):
             mb = util.MsgBox(uno.getComponentContext())
             mb.addButton("Ok")
             mb.show(txt, 0, "Python")
             
         g_exportedScripts = (Main,)
      

Příklady posluchačů pro tlačítko obsahuje skript msgbox.py v adresáři {instalace}/program/.

Pomocí jazyka Collabora Office Basic


         Option Explicit
             
         Const MY_LIBRARY = "Standard", MY_DIALOG = "Dialog1", MY_BUTTON = "Button1"
         Const MY_LABEL = "Basic naslouchá..."
         Dim count As Integer
             
         Sub Main
             Dim libr As Object ' com.sun.star.script.XLibraryContainer
             Dim dlg As Object
             Dim ui As Object  ' stardiv.Toolkit.UnoDialogControl
             Dim ctl As Object ' stardiv.Toolkit.UnoButtonControl
             Dim act As Object ' com.sun.star.awt.XActionListener
             Dim rc As Object : rc = com.sun.star.ui.dialogs.ExecutableDialogResults
             
             BasicLibraries.LoadLibrary(MY_LIBRARY)
             libr = DialogLibraries.GetByName(MY_LIBRARY)
             dlg = libr.GetByName(MY_DIALOG)
             ui = CreateUnoDialog(dlg)
             ui.Title = "Basic X[any]Listener example"
             count = 0
             ctl = ui.GetControl(MY_BUTTON)
             ctl.Model.Label = MY_LABEL
             act = CreateUnoListener("awt_", "com.sun.star.awt.XActionListener")
             ctl.addActionListener(act)
             Select Case ui.Execute
                 Case rc.OK : MsgBox "Uživatel potvrdil dialogové okno.",, "Basic"
                 Case rc.CANCEL : MsgBox "Uživatel zrušil dialogové okno.",, "Basic"
             End Select
             ui.dispose ' ui.endExecute()
             ctl.removeActionListener(act)
         End Sub
             
         Private Sub awt_actionPerformed(evt As com.sun.star.awt.ActionEvent)
             ''' Naslouchá klepnutím na tlačítko a počítá je '''
             With evt.Source.Model
                 If .Name = MY_BUTTON Then
                     count = count + 1
                     .Label = MY_LABEL+Cstr(count)
                 End If
             End With
         End Sub ' awt_actionPerformed
             
         Private Sub awt_disposing(evt As com.sun.star.lang.EventObject) ' mandatory Sub
             ' místo pro vlastní kód
         End Sub ' awt_disposing
      

Další posluchače událostí

Posluchače se obvykle připravují pro otevírání dialogového okna. Posluchače lze používat různě, například při obsluze dialogových oken nebo při sledování událostí v dokumentech nebo formulářích.

Podpořte nás!