(29.05.2013 17:15 )Holy schrieb: [ -> ]Du musst den Event mit dem Filter Event "Application Instance Close ?" abfangen und die direkte Ausführung der Operation verhindern, d.h. mittels Discard? = TRUE das Schließen verhindern. Dein Problem ist sozusagen, dass du zwar auf den Event reagierst aber die Operation trotzdem ausgeführt wird und deine Anwendung beendet. Mittels Discard? = TRUE verhinderst du die Ausführung der Operation und kannst danach geordnet selbst dein Programm beenden.
Und dann nicht das LabVIEW Exit aufrufen. Das funktioniert meist nicht nachdem man das Application Instance Close event abgefangen hat (meist darum da es vom Status des Hauptfensters abhängt, wenn es Hidden ist gehts nie, wenn es offen ist nur wenn man zwischen dem Application Instance Close event und dem LabVIEW Exit mindestens einmal den Zustand des Hauptfensters mit VI Server einmal verändert.
Anstelle davon ist es besser um einfach sicher zu stellen dass alle Fenster in der Applikation garantiert geschlossen sind. Dann beendet die LabVIEW Runtime die Applikation automatisch.
Im Moment habe ich noch keine EXE daraus gemacht. Und das Programm läuft noch in der Entwicklungsumgebung.
Ich habe mein VI mal unten angehängt. Konnte auch gut nachvollziehen anhand meiner
Log Datei das mir 12sec. nur bleiben bis Windows Labview
komplett killt.
Leider habe ich auch noch nichts in der Reg von Win 7 gefunden um diese Zeit zu
verlängern.
Danke nochmal für das Muster VI
Ich vermute mal das LabVIEW nach 12 Sekunden dein VI killt und sich selber schließt. Wenn du das VI in eine Anwendung baust dann wird es nicht nach 12 Sekunden geschlossen. Hab das auch extra nochmal getestet.
Hallo jetzt hatte ich nochmal Zeit dies auszuprobieren.
Leider habe ich noch immer ein Problem das die Anwendung nach 12sec geschlossen wird.
Dies habe ich auch mit einer EXE ausprobiert.
Einstellungen in der Reg des PC habe ich auch noch vor genommen:
WaitToKill Service 90000
AutoEndTasks 0
HungAppTimout 90000
WaitToKillAppTimout 90000
Liege ich damit richtig das du nur 12 Sekunden Zeit hast wenn Windows runterfährt? Getestet hab ich ein explizites Taskkill /F und nicht Windows herunterfahren.
Um deine Anwendung runterzufahren sollten doch eigentlich 12 Sekunden reichen? Um das zu umgehen könntest du ggf. auf dein USV Dienstprogramm zurückgreifen, sodenn es eins gibt.
Habe nun 2 Möglichkeiten die funktionieren !!!
1. Abfrage ob Windows einen Shutdown beginnt:
Dies funktioniert mit dem Event Case „Application Instance Close? “
Hier bleiben ca. 12-20 sec. das Programm selber zu schließen und Daten weg zu speichern.
Nach dieser Zeit Schließt Windows einfach das Programm...
Diese Funktion ist sinnvoll wenn Windows einfach heruntergefahren wird
2. Abfrage des Zustandes der USV
Im Rups2000 Manager ( von der USV ) wird der Pfad einer Batch Datei bei
„Befehlsdatei“ ausführen eingetragen.
Kommt es jetzt zu einem Stromausfall merkt dies die USV und startet die Batchdatei nach 1min.
Die Batchdatei kopiert das Dat File „shutdownOrderLV.dat“ vom Ordner „Default_USV“
in den Ordner „check_LV“.
Der Ordner check_LV wird zyklisch von LabView abgefragt ob sich die Datei „schutdownOrderLV“ im Ordner befindet, ist dies der Fall wird das Programm gezielt beendet und die Datei „schutdownOrderLV“ wieder aus dem Ordner gelöscht.
Als kleine Erweiterung schreibe ich noch die Daten weg wann der Befehl der USV kam und wann das Programm beendet wurde.
In der Batchdatei sind die Pfade der Ordner angegeben. Wird vor dem Windows shutdown noch mehr Zeit benötigt muss man einfach nur noch weiter ping Befehle (Wartezeit ) einfügen
Die Batch schaut so aus:
@echo off
xcopy "d:\shutdown_usvPC\Default_USV\shutdownOrderLV.dat" "d:\shutdown_usvPC\check_LV"
ping pc04980 // als Wartezeit
ping pc04980
Um das Polling nach dem File zu vermeiden könntest die Batch auch ein Taskkill /F an deine Anwendung senden lassen. Spart dir außerdem noch den "Extra"-Code dafür, da du wahrscheinlich eh auf "Application Instance Close?" reagierst.
Nein leider ist das nicht so besonders effektiv in der Batch einen Taskkill auszuführen.
Das habe ich am Anfang auch probiert leider bleiben hier nur 12-20 Sec bis Labview
abgeschossen wir von Windows. Ich brauche aber eher 25sec bis alle Programmschritte
bei mir beendet sind.
Die Zeit die ich jetzt habe kann ich einfach in die Länge ziehen je mehr Ping Befehle ich
sende da die USV wartet bis die Batch fertig ist und sendet dann erst den Taskkill-Befehl.
In irgendeiner Verwirrung habe ich hier immer von dem Parameter /F gesprochen ich meinte natürlich /IM. Hab mir es nochmal damit angeschaut und /IM erzwingt das Beenden nicht sondern sendet nur den Befehl. D.h. wenn es dann trotzdem noch zugeht wird es nicht durch diesen Befehl erzwungen sondern andersweitig z.B. durch dein USV-Dienstprogramm.