Macro an Ereignis binden

Antwort erstellen


BBCode ist eingeschaltet
[img] ist ausgeschaltet
[url] ist eingeschaltet
Smileys sind ausgeschaltet

Die letzten Beiträge des Themas
   

Ansicht erweitern Die letzten Beiträge des Themas: Macro an Ereignis binden

Re: Macro an Ereignis binden

von TrueColor » Di, 13.12.2016 08:37

Nach dem mir gestern noch der Gedanke kam, dass ich mal gelesen hab, der Dispatcher würde auf UI-Ebene arbeiten, habe ich einen (nicht schönen, aber zumindest bei mir funktionierenden) Workaround gefunden. Ich habe mit dem Macro-Recorder einfach ein sinnloses Umfärben des Zellhintergrundes außerhalb des Datenbereiches aufgenommen und lasse diese Aktion an Stelle der MsgBox laufen. Kein hakeln mehr, es lässt sich wieder ordentlich bedienen.

Kann das bitte mal wer testen?
Und ich bin immer für Vorschläge offen, das eleganter/einfacher umzusetzen.

Danke!
Dateianhänge
Demo_Doc schließen nach Inaktivität_v00.05_20161213_onload_working.ods
(16.21 KiB) 116-mal heruntergeladen

Re: Macro an Ereignis binden

von TrueColor » Mo, 12.12.2016 15:20

Danke für's testen, Stephan. So kann ich zumindest annehmen, dass nicht meine Unfähigkeit die Ursache ist :-)

Re: Macro an Ereignis binden

von Stephan » Mo, 12.12.2016 09:29

Das Problem tritt auch bei mir auf (OOo 3.3.0) und ich habe keine Idee wie man es beseitigt.


Gruß
Stephan

Re: Macro an Ereignis binden

von TrueColor » Mo, 12.12.2016 08:48

Nochmal nachhaken:
Hat keiner eine Idee, wie ich das flüssig zum laufen bekomme, ohne dass ich eine Interaktion mit einem Oberflächen-Element wie z.B. Werkzeugleiste oder MsgBox erzwingen muss? Oder zumindest eine Idee, warum das so ist?

Oder tritt das Problem nur bei mir auf, dass das dann so rumspinnt?

Re: Macro an Ereignis binden

von TrueColor » Mo, 05.12.2016 11:36

Update. Habe jetzt noch etwas herumprobiert.
Lade den Listener erst nach einem Wait. Bringt aber keine Verbesserung.
Edit: Hab ich wieder rausgeworfen.

Was aber aufgefallen ist: Sobald ich eine UI-Interaktion habe (sei es eine MsgBox im Code, die bestätigt werden muss, oder einfach nur das Benutzen eines Werkzeuges aus der Toolbar, z.B. Zellhintergrund färben) läuft es ohne Probleme. Habe das jetzt erstmal mit MsgBox gemacht. Mir wäre es aber lieber, wenn keine MsgBox nötig wäre, 30 min sollten im Produktiveinsatz ausreichend Zeit sein, ohne explizit warnen zu müssen.

Daraufhin habe ich (mit der MsgBox) nochmal mit den Ereignissen experimentiert:
"Laden des Dokuments beendet" --> kein Reaktion
"Dokument öffnen" --> fkt. wie geplant
Dateianhänge
Demo_Doc schließen nach Inaktivität_v00.04_20161205_onload_working.ods
(15.77 KiB) 205-mal heruntergeladen

Macro an Ereignis binden

von TrueColor » Fr, 02.12.2016 13:33

[System: Win 7, AOO 4.1.2]

Hallo,

ich habe ein Macro (Auto-Save/Close nach Inaktivität), welches in der Datei selbst gespeichert ist und gestartet werden soll, wenn das Dokument (.ods) geladen wurde. Das Macro selbst funktioniert einwandfrei, wenn ich es über eine Schaltfläche starte.

Als geeignete Ereignisse habe ich "Dokument öffnen" und "Laden des Dokuments beendet" gefunden.

Bei "Dokument öffnen" passiert gar nichts. Ich vermute, dass das Ereignis am Beginn des Öffnens ausgeführt werden soll. Und da das Macro in der zu öffnenden Datei enthalten ist, kann da nix passieren.

Bei "Laden des Dokuments beendet" gibt es massive Probleme. Eingaben werden nur verzögert angenommen, es wird fehlerhaft gerendert, das Dokument wird nicht automatisch geschlossen. Beim manuellen Schließen es eine Exception (ok, wohl wegen dem ListenerDispose, muss ich vlt. nochmal separat ans Beenden binden).

Ich hab mal beide Dateien (einmal mit Schaltfläche, einmal onLoad) angehängt, der TimeOut beträgt zum Testen 10 Sekunden.

Hat wer eine Idee, wie ich das "onLoad" zum Laufen bekomme?

Vielen Dank!

p.s. Vermutlich kann ich erst am Montag wieder reinschauen.
Dateianhänge
Demo_Doc schließen nach Inaktivität_v00.03_20161202_onload_test.ods
(15.36 KiB) 114-mal heruntergeladen
Demo_Doc schließen nach Inaktivität_v00.03_20161202_button_test.ods
(16.05 KiB) 113-mal heruntergeladen

Nach oben