Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   GUI-Design mit VCL / FireMonkey / Common Controls (https://www.delphipraxis.net/18-gui-design-mit-vcl-firemonkey-common-controls/)
-   -   Delphi Comport-Exception abfangen und verbindung schließen (https://www.delphipraxis.net/128723-comport-exception-abfangen-und-verbindung-schliessen.html)

delphifant 6. Feb 2009 08:54

Re: Comport-Exception abfangen und verbindung schließen
 
Hallo messie,
ich werde nun als nächster Schritt try...except direkt beim senden und empfangen einsetzen. Bis jetzt hoffte ich, ich könne die Exceptions direkt an einen Punkt im Programm abfangen.

Das Senden läuft momentan auch schon über einen Timer... wenn du willst kann ich auch noch gerne Auszüge davon posten. Jedoch findet in der Timer-Routine nur die Verarbeitung der Antworten statt.

Fand es eine nette Lösung in der Sende-Prozedur eine gewisse Zeit auf die Antwort zu warten oder die Prozedur abzubrechen.

Aber ich lasse mich gerne eines besseren belehren und bin um jede Hilfe froh.

messie 6. Feb 2009 09:03

Re: Comport-Exception abfangen und verbindung schließen
 
Erkläre mal Deine Datenübertragung: machst Du Polling-Betrieb, bei dem vom externen Gerät nur auf einen Befehl hin gesendet wird oder schreibt das Gerät die Daten selbständig?

Grüße, Messie

delphifant 6. Feb 2009 09:30

Re: Comport-Exception abfangen und verbindung schließen
 
Hallo messie,
ich arbeite im Pooling-Betrieb. Ich sende meinen Gerät Befehle im IEEE-Standart (*RST) und mein Gerät meldet sich dann mit einer definierten Antwort z.B "OK<CR><LF>". Hier noch ein Außzug aus der

Dokumentation vom Elektroniker
Zitat:

Schnittstelle: virtueller COM-Port an USB
Baudrate: 921600
Datenbits: 8
Parität: keine
Stoppbits: 1
Handshake: OFF

Synchronisation: Es darf immer nur ein Befehl abgesetzt werden.
Jeder Befehl gibt eine Antwort, auf die der PC
warten muss. Erst dann ist das Gerät bereit für den
nächsten Befehl.
(Das erspart BUSY / READY Flags)
Ach, ich habe nun versucht direkt um meine Befehle zur Schnittstelle mit try..exception-Blöcke das Ergebnis ist jedoch das gleiche
Zitat:

... Klasse EComPort mit der Meldung WriteFile function failed (win error code: 5)' ...

messie 6. Feb 2009 09:59

Re: Comport-Exception abfangen und verbindung schließen
 
Also beim Abziehen des seriellen Kabels sollte es mit try..except klappen. Beim Abziehen des USB-Kabels trennt man die Verbindung zweischen Treiber und Hardware. Das habe ich auch noch nicht abfangen können.

Grüße, Messie

delphifant 6. Feb 2009 12:17

Re: Comport-Exception abfangen und verbindung schließen
 
Hallo messie,
genau da befindet sich mein Problem. Ich arbeite über USB.
Wenn der Konflikt zwischen Hardware und Treiber auftritt, aber ich kann mich auch täuschen, sollte ich nun die USB-Events abfragen und hoffen rechtzeitig darauf reagieren zu können.

Ich habe nun mal die USB-Events abgefangen...jedoch muss ich nun noch versuchen das Event herauszufinden welches mich betrifft.-> Also das Handle meinen Treiber zuzuordnen. Vielleicht gelingt es mir so.

Danke für die Hilfe

Koonunga Hill 22. Apr 2009 17:32

Re: Comport-Exception abfangen und verbindung schließen
 
Hallo Leute,

ich schlage mich mit genau dem gleichen Problem herum und bekomme nach dem Ziehen des USB-Kabels von der TComPort Komponente immer die Meldung PurgeComm Function failed on COM4.
Das Problem ist, daß ich den Port gar nicht mehr dis-connecten kann oder an einem anderen gültigen COM-Port anmelden kann. Auch das Abfragen der USB-Messages von WIndows hilft nicht weiter, da der Port ja schon 'weg' ist, wenn das Event auftritt.

Irgendeine Idee, wie ich den ComPort zur Laufzeit wieder DisConnected bekomme??

Gruß, Michael

messie 22. Apr 2009 21:26

Re: Comport-Exception abfangen und verbindung schließen
 
Schwierig.
Eigentlich geht es nur dann, wenn Du auch die Hardware der Gegestelle programmierst. Dann kannst Du eine Art Watchdogfunktion implementieren. Solange der Treiber keine eindeutige Antwort "Hardwareverbindung getrennt" liefert, bist Du weitgehend hilflos.
Das Problem ist, dass der Treiber bei abgezogener Hardware bisher in der Abfrage steckenbleibt. Dann kannst Du ihn auch nicht durch einen anderen Thread deaktivieren.
Wenn man es schaffen könnte, einen Windows-Treiber zur Laufzeit hart zu deaktivieren und neu initialisieren zu können, könnte das klappen, wenn der Treiber beim Fehler (Kabel abgezogen) eine Meldung macht.

Grüße, Messie


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:56 Uhr.
Seite 2 von 2     12   

Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz