AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Sprachen und Entwicklungsumgebungen Sonstige Fragen zu Delphi Delphi Rechner über RS232 herunterfahren lassen
Thema durchsuchen
Ansicht
Themen-Optionen

Rechner über RS232 herunterfahren lassen

Ein Thema von DoktorD · begonnen am 4. Okt 2007 · letzter Beitrag vom 5. Okt 2007
Antwort Antwort
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#1

Rechner über RS232 herunterfahren lassen

  Alt 4. Okt 2007, 17:36
Hi.

Also habe jetzt schon länger im Forum gesucht, aber nichts gefunden, was mein Problem löst.

Und zwar möchte ich mit dem RS232 (Com-Schnittstelle) Anschluss des Rechners, diesen herunterfahren.
Dies soll aber dadurch passieren, das ich z.B. irgendeinen Pin auf High setze oder mit einem anderen kurzschließe.

Ich hab keine Ahnung wie ich das anstellen soll und hoffe Ihr wisst vielleicht weiter.

Gehen muss das auf jeden fall, denn hier http://www.linuxfocus.org/Deutsch/Ja...ticle186.shtml
gehts ja auch.

Vielen Dank für Eure Mühe.
  Mit Zitat antworten Zitat
Reinhard Kern

Registriert seit: 22. Okt 2006
772 Beiträge
 
#2

Re: Rechner über RS232 herunterfahren lassen

  Alt 4. Okt 2007, 17:48
Zitat von DoktorD:
Hi.

Also habe jetzt schon länger im Forum gesucht, aber nichts gefunden, was mein Problem löst.

Und zwar möchte ich mit dem RS232 (Com-Schnittstelle) Anschluss des Rechners, diesen herunterfahren.
Dies soll aber dadurch passieren, das ich z.B. irgendeinen Pin auf High setze oder mit einem anderen kurzschließe.

Ich hab keine Ahnung wie ich das anstellen soll und hoffe Ihr wisst vielleicht weiter.

Gehen muss das auf jeden fall, denn hier http://www.linuxfocus.org/Deutsch/Ja...ticle186.shtml
gehts ja auch.

Vielen Dank für Eure Mühe.
Hallo,

du brauchst ein ständig laufendes Programm, normalerweise einen Service, der die Schnittstelle überwacht und gegebenfalls das Herunterfahren auslöst. Also suche nach:

1. Wie schreibe ich einen Service

2. Wie spreche ich ein COMx-Port an.

Gruss Reinhard
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#3

Re: Rechner über RS232 herunterfahren lassen

  Alt 4. Okt 2007, 17:53
Ist mir soweit schon klar. Habe auch im Forum schon danach gesucht. Nur wird hier ja immer nur beschrieben, wie ich über den Sendekanal (Rx) mit dem Rechner kommuniziere.

In meinem Fall will ich das aber nicht. Es soll rein über die Potentiale an den Pins gesteuert werden.

Hast du ne Ahnung wo ich darüber infos bekommen kann?
  Mit Zitat antworten Zitat
Benutzerbild von brinkee
brinkee

Registriert seit: 27. Aug 2004
60 Beiträge
 
Delphi 7 Enterprise
 
#4

Re: Rechner über RS232 herunterfahren lassen

  Alt 4. Okt 2007, 17:55
Naja, sowas ist eigentlich ganz einfach:
Du nimmst deinen Taster und verschaltest über ihn den CarrierDetect, wie der Kollege auf der Seite es gamacht hat, mit einem 6.8kOhm Widerstand und DTR. So setzt Du also den Carrier Detect auf 1, sozusagen. Dann kannst Du Dir mal im HyperTerminal ansehen, ob was passiert oder Du suchst Dir halt eine kleine Komponente, die über den COM-Port kommuniziert.

Aber Vorsicht: So Spannungsfest sind die Pins am Com nicht. Mach Dir also nichts kaputt!

LG, Markus
Markus Brinkmann
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#5

Re: Rechner über RS232 herunterfahren lassen

  Alt 4. Okt 2007, 18:11
Die möglichen Pins wurden ja schon genannt; man kann sie über die Funktion GetCommState() abfragen. Zuvor muss man die RS232 über CreateFile öffnen.
Bei Google suchendelphi AND GetcommState AND Createfile
Andreas
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#6

Re: Rechner über RS232 herunterfahren lassen

  Alt 5. Okt 2007, 09:31
Ok. Habe gerade meine Schaltung aufgebaut und diese Funktioniert auch. Das hab ich mit einem Tool getestet, welches ich im Internet gefunden habe. Das zeigt mir an, wenn ich den Taster drücke (CD (Pin1) aktiv).

Nun meine Frage: Wie kann ich das über Delphi abfragen? Oder wie kann ich zum Beispiel die Ausgänge DTR und RTS aktivieren?
  Mit Zitat antworten Zitat
messie

Registriert seit: 2. Mär 2005
Ort: Göttingen
1.592 Beiträge
 
Delphi 2009 Professional
 
#7

Re: Rechner über RS232 herunterfahren lassen

  Alt 5. Okt 2007, 09:47
Zitat von DoktorD:
Nun meine Frage: Wie kann ich das über Delphi abfragen? Oder wie kann ich zum Beispiel die Ausgänge DTR und RTS aktivieren?
Am besten, wenn Du Dir eine Komponente wie TComport (SourceForge) installierst, Da mußt Du dann nur noch den Comport öffnen und auf die Events warten.
Delphi-Quellcode:
TCustomComPort = class(TComponent)
  private
    FOnTxEmpty: TNotifyEvent;
    FOnBreak: TNotifyEvent;
    FOnRing: TNotifyEvent;
    FOnCTSChange: TComSignalEvent;
    FOnDSRChange: TComSignalEvent;
    FOnRLSDChange: TComSignalEvent;
    FOnError: TComErrorEvent;
    FOnRxFlag: TNotifyEvent;
    FOnAfterOpen: TNotifyEvent;
    FOnAfterClose: TNotifyEvent;
    FOnBeforeOpen: TNotifyEvent;
    FOnBeforeClose: TNotifyEvent;
    FOnRx80Full: TNotifyEvent;
Grüße, Messie
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#8

Re: Rechner über RS232 herunterfahren lassen

  Alt 5. Okt 2007, 09:58
Danke für deinen Hinweis. Aber geht das auch anders? Das ich beim öffnen der Schnittstelle einfach RTS und DTR auf High setze?

Hier mein Quellcode beim öffnen der Schnittstelle:
Delphi-Quellcode:
Function TForm1.Com_VerbindungStart (comport:Byte; baudrate:Word; Byte,Parity,StopBits:Byte; var Handle :THandle):Boolean;
Var
    // Variablen für das öffnen der Com-Verbindug
    port : pansichar;
    b_fsuccess, b_RSetMask : Boolean;
    Dcb : TDCB;
    TCOM_com : TCOMMTIMEOUTS;
begin
  case comport of
    1: port := 'com1'; 2: port := 'com2'; 3: port := 'com3';
    4: port := 'com4'; 5: port := 'com5'; 6: port := 'com6';
    7: port := 'com7'; 8: port := 'com8'; 9: port := 'com9';
  end;
  Result := True;
//************** Com-Schnittstellen konfigurieren und öffnen *******************
//******************************************************************************
  Handle:=createfile(port,GENERIC_READ or GENERIC_WRITE,0,nil,OPEN_EXISTING, 0, 0);
  IF Handle=INVALID_HANDLE_VALUE then begin
    Result := False;
    //Application.Terminate;
    MessageDlg('Port "'+port+'" nicht gefunden.', mtWarning, [mbOK], 0);
  end;
//************** Com setzen: *****************************************
  // Lesen der Schnittstellenparameter:
  b_fsuccess := GetcommState(Handle,dcb);
  //-------------------------------------
  dcb.BaudRate := baudrate;
  Dcb.ByteSize := byte;
  Dcb.Parity := Parity; {0-4     = None, Odd, Even, Mark, Space} 
  Dcb.StopBits := StopBits; {0, 1, 2 = 1, 1.5, 2                   }
  dcb.flags :=$1011;



  //Schreiben der Schnittstellenparameter:
  b_fsuccess := SetcommState( Handle, Dcb );
  If b_fsuccess = False Then begin
  Result := False;
  MessageDlg( 'Fehler beim schreiben der Schnittstellenparameter', MtError, [MbOk], 0 );
  end;

  // SPECIFIES A SET OF EVENTS TO BE MONITORED :
  b_RSetMask := SetCommMask( Handle, EV_RXCHAR );
  //-------------------------------------------
  If b_RSetMask = False Then begin
    Result := False;
// MessageDlg( 'SPECIFIES A SET OF EVENTS TO BE MONITORED : FAIL', MtError, [MbOk], 0 );
  end;
  // Festlegen der TimeOuts für die Kommunikation
  TCOM_com.ReadIntervalTimeOut := 500;
  TCOM_com.ReadTotalTimeoutMultiplier := 10;//MAXDWORD;
  TCOM_com.ReadtotalTimeOutConstant := 100;
  //--------------------------------------
  // Setzten des TimeOuts für die Kommunikation
  SetCommTimeouts(Handle,TCOM_com);
  //-----------------------------------
  // Größe von INPUT- und OUTPUT-BUFFER festlegen:
  b_fsuccess := SetupComm( Handle, 2000, 2000 );
  //--------------------------------------------
  If b_fsuccess = False Then begin
    Result := False;
    MessageDlg( 'Festlegen der Größe für Input- und Output-Buffer ist fehlgeschlagen', MtError, [MbOK], 0 );
  end;
end;
  Mit Zitat antworten Zitat
DoktorD

Registriert seit: 13. Dez 2005
153 Beiträge
 
#9

Re: Rechner über RS232 herunterfahren lassen

  Alt 5. Okt 2007, 10:27
Coool hab eben kurz mal mit der TComPort rumgespielt und es geht!!!

Jetzt hab ich aber noch ne Frage. Ich würde jetzt die ganze Zeit die Schnittstelle fragen ob der Eingang auf High ist oder nicht.
Du hattest jetzt ja schon was mit Event erwähnt.

Kann man das als Interrupt verstehen?

Wie kann ich das abfragen (kurzer Beispielquellcode vielleicht)

Schon mal vielen Dank für Eure Hilfe


Achso, hier meine TComPort:
Delphi-Quellcode:
unit uCOMPort;

interface

uses Windows, SysUtils;

const
     //--Konstanten für den Statusreport------------------------------------------------------------
      parity : array[0..4] of String = ('Keine','Ungerade','Gerade','Markierung','Leerzeichen');
      stopbits : array[0..2] of String = ('1','1,5','2');
     //---------------------------------------------------------------------------------------------

     //--Konstanten zum einfachen Setzen der Portflags----------------------------------------------
     dcb_Binary = $00000001; // Binärer Modus - In Windows immer auf 1!
     dcb_ParityCheck = $00000002; // Paritätsüberprüfung

     dcb_OutxCtsFlow = $00000004; // CTS Flusskontrolle - Sendekontrolle mit Hilfe von CTS
     dcb_OutxDsrFlow = $00000008; // DSR Flusskontrolle - Sendekontroll mit Hilfe von DSR

     dcb_DtrControlDisable = $00000000; // DTR Flusskontrolle - Schließt DTR auf 0 bei Verbindung und hält es auf 0
     dcb_DtrControlEnable = $00000010; // DTR Flusskontrolle - Öffnet DTR auf 1 bei Verbindung und hält es auf 1
     dcb_DtrControlHandshake = $00000020; // DTR Flusskontrolle - Handshake-Funktion.
     dcb_DtrControlMask = $00000030;

     dcb_DsrSensitvity = $00000040; // Zustandsänderung auf DSR überwachen

     dcb_TXContinueOnXoff = $00000080; // Stellt ein, ob die Übertragung bei XOff angehalten wird oder nicht

     dcb_OutX = $00000100; // Flusskontrolle mit XOn/XOff beim Senden
     dcb_InX = $00000200; // Flusskontrolle mit XOn/XOff beim Empfangen
     dcb_ErrorChar = $00000400; // Bestimmt, ob Bytes mit falscher Parität durch den Error-Char ersetzt wird.

     dcb_NullStrip = $00000800; // Null-Bytes werden beim Empfangen ignoriert

     dcb_RtsControlDisable = $00000000; // RTS-Flusskontrolle - Schließt RTS auf 0 bei Verbindung und hält es auf 0
     dcb_RtsControlEnable = $00001000; // RTS-Flusskontrolle - Öffnet RTS auf 1 bei Verbindung und hält es auf 1
     dcb_RtsControlHandshake = $00002000; // RTS-Flusskontrolle - Handshake-Funktion
     dcb_RtsControlToggle = $00003000; // RTS-Flusskontrolle - RTS ist an wenn Bytes zu senden sind, wenn keine zu senden sind ist RTS auf 0
     dcb_RtsControlMask = $00003000; // RTS-Flusskontrolle

     dcb_AbortOnError = $00004000; // Wenn ein Fehler auftritt, stoppt jede Transmission und der
                                          // Fehler muss mit Hilfe von ClearCommError beseitigt werden.

     dcb_Reserveds = $FFFF8000; // Reserviert! Nicht benutzen!
//------------------------------------------------------------------------------------------------------------------------

type TComPort = class
 private
    PortHandle : Integer; // Handle (u.a. Zeiger) auf den COM-Port.
    DCB : TDCB; // Data-Control-Block-Struktur zum Kontrollieren der Parameter der seriellen Schnittstelle
    procedure GetDCB;

    procedure SetParity (Parity : byte); // Den Modus der Paritätskontrolle:
    function GetParity : byte; // 0 = Keine, 1=ungerade, 2=gerade, 3=Merkierung, 4=Leerzeichen

    procedure SetBaudRate (Baudrate : Word); // Setzt die Übertragungsgeschwindigkeit des Ports in Baud
    function GetBaudrate : Word;

    function GetStopBits : byte; // Setzt die Anzahl der Stopbits
    procedure SetStopBits (bits : byte); // 0 = 1 Stopbit, 1 = 1.5 Stopbits, 2 = 2 Stopbits

    function GetByteSize : byte; // Fragt die Anzhal der Bits/Byte ab.
    procedure SetByteSize (bytesize : byte); // Setzt die Anzahl der Bits/Byte (Standard: 8)
 public
    function OpenCOM (Port : pchar) : Integer; // Öffnet COM-Port (Parameter-Beispiel: 'COM1')
    procedure CloseCOM; // Schließt das Handle für den COM-Port

    //-------------------------------------------Ausgaben - Indikatoren für angeschlossene Geräte

    procedure TXD (State : integer); // TxD = Sendeleitung --> Hier Prozedur für Dauerspannung auf TxD
    procedure RTS (State : integer); // "Request-To-Send" --> Computer signalisiert, dass er senden möchte
    procedure DTR (State : integer); // "Data-Terminal-Ready" --> Computer ist bereit

    //-------------------------------------------Eingaben - Indikatoren für bestimmte Ereignisse.

    function CTS : integer; // "Clear-To-Send" --> Dem Computer wird angezeigt,
                                                 // dass das angeschlossene Gerät bereit ist Daten zu emfpangen

    function DSR : integer; // "Data-Set-Ready" --> Angeschlossenes Gerät ist bereit
    function RI : integer; // "Ring-Indicator" --> Klingelzeichen, ähnlich beim Telefon
    function DCD : integer; // "Data-Carrier-Detect --> Computer ist bereit Daten zu empfangen
    function INPUTS : integer;
    //--------------------------------------------------------------------------------------------

    function GetHndl : Integer; // Gibt das geöffnete Handle des Ports zurück
    //--------------------------------------------------------------------------------------------

    function GetFlags : Integer; // Fragt die Port-Flags ab.
    function SetFlags (Flag : Integer; Enable : Boolean) : boolean; //Setzt die Port-Flags (siehe weiter oben)

    //------------------------------------------Sendefunktionen-----------------------------------

    procedure BufferSize (Size : Integer); // Setzt die Größe des Sende- und Empfangspuffers für Zeichenübertragungen

    function CharInTXBuffer : Cardinal; // Aktuelle Länge des Sendepuffers
    function CharInRXBuffer : Cardinal; // Aktuelle Länge des Empfangspuffers
    procedure ClearBuffer; // Sende- und Empfangspuffer werden gelöscht
    procedure SENDBYTE (Dat: Integer); // Byte über die serielle Schnittstelle senden
    procedure SENDSTRING(Buffer: Pchar); // Text über die serielle Schnittstelle senden
    function READBYTE() : Integer; // Byte über die serielle Schnittstelle empfangen
    function READSTRING() : Pchar; // Text über die serielle Schnittstelle empfangen
    procedure Timeouts (TOut : Integer); // Setzt die Timeouts zum Senden
    function GetStatusReport : String; // Gibt einen ausführlich formulierten Statusreport des Ports zurück.
    //---------------------------------------------------------------------------------------------
    //-------------Eigenschaftsfestsetzungen - zum leichteren Setzen der Porteigenschaften---------
    property Parity : byte read GetParity write SetParity;
    property BaudRate : Word read GetBaudRate write SetBaudRate;
    property StopBits : byte read GetStopBits write SetStopBits;
    property ByteSize : byte read GetByteSize write SetByteSize;
    //*********************************************************************************************
     destructor Destroy; override;
     constructor Create (AutoInit : Integer);
    //*********************************************************************************************

end;

implementation

constructor TComport.Create (AutoInit : Integer);
begin
 case AutoInit of
  1 : OpenCOM('COM1');
  2 : OpenCOM('COM2');
  end; {CASE}
end;


function TComPort.OpenCOM (port : pchar) : Integer;
var
 PortStr, Parameter : String;

begin
 Result := 0;
 // Wenn Port-Handle geöffnet, dann Handle schließen
 if PortHandle > 0 then CloseHandle(PortHandle);
 // übermittelter COM-Port 'herausfiltern'
 Parameter := port;
 PortStr := copy(Parameter,1,4);
 // COM-Port öffnen
 PortHandle := CreateFile (PChar(PortStr), GENERIC_READ or GENERIC_WRITE,
                           0,nil,OPEN_EXISTING,0,0);
 //Status des Ports überprüfen und DCB-Struktur füllen
 GetCommState(PortHandle,dcb);
 //DCB-Struktur mit Standardwerten füllen
 BuildCommDCB(PChar(Parameter),dcb);
 //Eigene Flags setzen
 DCB.Flags := 1;
 //Änderungen auf den Port anwenden und auf Erfolg überprüfen
 if SetCommState (PortHandle, DCB) then Result := 1;
end;

procedure TComPort.CloseCOM;
begin
 //Port schließen und Handle zurücksetzen (wegen OpenCOM!)
 GetCommState(PortHandle,dcb);
 SetParity(0);
 SetBaudrate(1200);
 SetStopBits(0);
 SetByteSize(8);
 SetCommState(PortHandle,dcb);
 CloseHandle(PortHandle);
 PortHandle := 0;
end;

procedure TComport.TXD (State: Integer); //TxD bei 0 auf Sendemodus stellen, bei 1 auf Dauerspannung (Sendebetrieb nicht möglich)
begin
 if State=0 then
  EscapeCommFunction(PortHandle,CLRBREAK)
 else
  EscapeCommFunction(PortHandle,SETBREAK);

end;

procedure TComPort.RTS (State:Integer); //RTS entweder auf 0 oder auf 1 setzen
begin
 if State=0 then
  EscapeCommFunction(PortHandle,CLRRTS)
 else
  EscapeCommFunction(PortHandle,SETRTS);
end;

procedure TComPort.DTR (State : integer); //DTR entweder auf 0 oder 1 setzen
begin
 if State = 0 then
  EscapeCommFunction(PortHandle,CLRDTR)
 else
  EscapeCommFunction(PortHandle,SETDTR);
end;

function TComPort.CTS : Integer; //CTS auf Status abfragen
var
 mask : DWord;
begin
 GetCommModemStatus(PortHandle,mask);
 if (mask and MS_CTS_ON) = 0 then
  result := 0
 else
  result := 1;
end;

function TComPort.DSR : Integer; // DSR auf Status abfragen
var
 mask : DWord;
begin
 GetCommModemStatus(PortHandle,mask);
 if (mask and MS_DSR_ON) = 0 then
  result := 0
 else
  result := 1;
end;

function TComPort.RI : Integer; // RI auf Status abfragen
var
 mask : DWord;
begin
 GetCommModemStatus(PortHandle,mask);
 if (mask and MS_RING_ON) = 0 then
  result := 0
 else
  result := 1;
end;

function TComPort.DCD : Integer; // DCD auf Status abfragen
var
 mask : DWord;
begin
 GetCommModemStatus(PortHandle,mask);
 if (mask and MS_RLSD_ON) = 0 then
  result := 0
 else
  result := 1;
end;

function TComPort.Inputs : Integer;
var
 mask : DWord;
begin
 GetCommModemStatus(PortHandle,mask);
 result := (mask div 16) and 15;
end;

function TComPort.GetHndl : integer;
begin
 result := PortHandle;
end;

procedure TComPort.SetParity (Parity : byte);
begin
  if (PortHandle > 0) and (Parity in [0..4]) then
   begin
    GetDCB;
    DCB.Parity := Parity;
    windows.SetCommState(PortHandle,DCB)
   end;
end;

function TComport.GetParity : byte;
var
 temp : TDCB;
begin
 if (PortHandle > 0) then
  begin
   GetCommState(PortHandle,temp);
   result := temp.Parity;
  end
 else
  result := 255;
end;

function TComport.GetBaudrate : Word;
var
 temp : TDCB;
begin
 if (PortHandle > 0) then
  begin
   GetCommState(PortHandle,temp);
   result := temp.BaudRate;
  end
 else
  result := 0;
end;

procedure TComPort.SetBaudRate(Baudrate : Word);
begin
 if (PortHandle > 0) then
 begin
  GetCommState(PortHandle,DCB);
  DCB.BaudRate := Baudrate;
  SetCommState(PortHandle,DCB)
 end;

end;

function TComPort.GetFlags : Integer;
var
 temp : TDCB;
begin
 if (PortHandle > 0) then
  begin
   GetCommState(PortHandle,temp);
   result := temp.Flags;
  end
 else
   result := -1;
end;

function TComport.GetStopBits : byte;
var
 temp : TDCB;
begin
 if (PortHandle > 0) then
  begin
   GetCommState(PortHandle,temp);
   result := temp.StopBits;
  end
 else
  result := 255;

end;

procedure TComport.SetStopBits(bits : byte);
begin
 if (bits > 0) and (bits <= 2) then // Der gültige Eingabebereich wird festgelegt
  begin
   GetDCB;
   DCB.StopBits := bits;
   SetCommState (PortHandle,DCB);
  end;

end;

function TComport.GetByteSize : byte;
var
 temp : TDCB;
begin
 GetCommState(PortHandle,temp);
 result := temp.ByteSize;
end;

procedure TComport.SetByteSize(bytesize : byte);
begin
  if bytesize in [1..8] then
   begin
    GetDCB;
    DCB.ByteSize := bytesize;
    SetCommState (PortHandle,DCB);
   end;
end;

procedure TComport.BufferSize(Size : Integer); //Sende -und Empfangspuffer setzen
begin
 SetupComm(PortHandle,Size,Size);
end;

function TComport.CharInTXBuffer : Cardinal; // Zeigt die aktuele Anzahl an Bytes im Sendepuffer an.
var
 Comstat : _Comstat;
 Errors : DWord;
begin
 if windows.ClearCommError(PortHandle,Errors,@Comstat) then
  result := Comstat.cbOutQue else result := 0;
end;

function TComport.CharInRXBuffer : Cardinal; // Zeigt die aktuelle Anzahl an Bytes im Sendepuffer an.
var
 Comstat : _Comstat;
 Errors : DWord;
begin
 if windows.ClearCommError(PortHandle,Errors,@Comstat) then
  result := Comstat.cbInQue else result := 0;
end;

procedure TComport.ClearBuffer; // Alle Puffer sofort leeren. Alle noch zu sendenden bzw zu empfangenden Zeichen gehen verloren!
begin
 windows.PurgeComm(PortHandle,PURGE_TXCLEAR);
 windows.PurgeComm(PortHandle,PURGE_RXCLEAR);
end;

procedure TComport.SENDBYTE (Dat: Integer); // Ein einzelnes Byte (binär codiert) senden
var BytesWritten: DWord;
begin
 WriteFile(PortHandle,Dat,1,BytesWritten,NIL);
END;

function TComport.READBYTE(): Integer; // Einen einzelnes Byte (binär codiert) empfangen
var Dat: Byte;
    BytesRead: DWORD;
begin
 ReadFile(PortHandle,Dat,1,BytesRead,NIL);
 if BytesRead = 1 then Result:=Dat else Result := -1;
end;

procedure TComport.SENDSTRING (Buffer: Pchar); // Einen Character senden.
var BytesWritten: DWord;
begin
  WriteFile(PortHandle,Buffer^,Length(Buffer),BytesWritten,NIL);
END;

function TComport.READSTRING(): Pchar; // Einen Character empfangen
var Dat: Integer;
    Data: STRING;
begin
  Dat := 0;
  while ((Dat > -1) and (Dat <> 13)) do begin
    Dat := ReadByte();
    if ((Dat > -1) and (Dat <> 13)) then Data := Data + Chr(Dat);
  end;
  result := pchar(Data);
end;

destructor TComport.Destroy;
begin
 if PortHandle > 0 then
  CloseCom;
 inherited;
end;

procedure Tcomport.Timeouts (TOut : Integer); // Setzen der Sendetimeouts
var
 Timeout : TCommTimeOuts;
begin
 TimeOut.ReadIntervalTimeout := 1;
 TimeOut.ReadTotalTimeoutMultiplier := 1;
 TimeOut.ReadTotalTimeoutConstant := TOut;
 TimeOut.WriteTotalTimeoutMultiplier := 10;
 TimeOut.WriteTotalTimeoutConstant := TOut;
 SetCommTImeouts(PortHandle,Timeout);
end;

procedure TComport.GetDCB;
begin
 GetCommState(PortHandle,DCB);
end;

function TComport.SetFlags (Flag : Integer; Enable : Boolean) : boolean; // Setzt spezielle Einstellungen des Ports
begin
 GetDCB;
 if Enable then
  DCB.Flags := DCB.Flags or Flag
 else
   DCB.Flags := DCB.Flags and (not Flag);

 result := Boolean(SetCommState(PortHandle,DCB));
end;

function TComport.GetStatusReport : String;
var
 Str : String;
begin
 Str := 'Baudrate von COM1: ' + IntToStr(Baudrate);
 //Str := Str + chr(13) + 'Parität von COM1: ' + parity[Parity];
 Str := Str + chr(13) + 'Flags von COM1: ' + IntToStr(GetFlags);
 Str := Str + chr(13) + 'Bits/Byte von COM1: ' + IntToStr(ByteSize);
 //Str := Str + chr(13) + 'Stopbits von COM1: ' + stopbits[StopBits];
 Str := Str + chr(13) + 'Zeichen im RX-Puffer: ' + IntToStr(CharInRXBuffer);
 Str := Str + chr(13) + 'Zeichen im TX-Puffer: ' + IntToStr(CharInTXBuffer);
 result := Str;
end;


end.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:00 Uhr.
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 by Thomas Breitkreuz