Foros Club Delphi

Foros Club Delphi (https://www.clubdelphi.com/foros/index.php)
-   Varios (https://www.clubdelphi.com/foros/forumdisplay.php?f=11)
-   -   procedimiento "largo", con envio y recepcion serial (https://www.clubdelphi.com/foros/showthread.php?t=53731)

emeceuy 28-02-2008 11:25:25

procedimiento "largo", con envio y recepcion serial
 
hola, bueno les comento... tengo que desarrollar una aplicación que realiza un chequeo de un dispositivo por el puerto serial rs232, enviando y recibiando datos...
el tema es que el chequeo lleva varios pasos y la verdad que nunca se me había planteado hacer algo así... he trabajado con el paralelo, pero en ese caso los datos los leo cuando quiero... en el caso del serial los datos vienen cuando ellos quieren ! je... y los recibo a través del evenco on RXChar del componente del puerto...

como hago el programa? supongamos que pongo un botón, luego envio un comando luego tendría que esperar a que llegue la respuesta y enviar otro comando y esperar la respuesta, y quizas esperar un par de segundos y volver a enviar otro comando y así sucesivamente...

como hago las demoras? con sleep? eso no me tranca la recepción? y como hago para que luego que pulsé el botón el progrma no quede solamente en ese evento y no se lo pueda detener? (no se si me explico, pero sería un procedimiento de varios segundos y si quiero detenerlo de esa manera no podría)...

la verdad que no tengo claro como puedo hacer... alguna sugerencia?

muchisimas gracias desde ya como siempre,

salu2 ! mArCe

poliburro 28-02-2008 15:49:14

Existe un componente, Mi preferido por cierto, para trabajar con el puerto serie. Y que te proporciona Eventos Para la lectura de datos y escritura.

TComPort.

Es una excelente opción, lo he utilizado para leer o escribir desde un lector de tarjetas hasta una interfaz para básculas industriales.


Suerte

duilioisola 28-02-2008 15:49:15

Para el tema de interrumpir:

Yo pongo una variable global booleana.
Un botón que al ser presionado poner la variable a True.
Todo el procedimiento de envío/recepcion deberá estar dentro de un while que chequee esta variable.

Código Delphi [-]
var
  interrumpir : boolean;

procedure TFMMain.BInterrumpirClick(Sender: TObject);
begin 
   interrumpir := True;
end;

procedure TFMMain.BLecturaEscrituraClick(Sender: TObject);
begin 
   interrumpir := False;
   while (not interrumpir) and (not TermioLecturaEscritura) do
   begin
      {Hacer lo que hay que hacer}
   end;
end;

FGarcia 28-02-2008 18:17:44

Hola!
Por el nombre del evento supongo que usas el Componente TComPort de la biblioteca CPortLib de Djan Cernilla.
El evento RxChar te permite capturar todo lo que entre por el puerto serie caracter a caracter por lo que tu tendrias que evaluar cuantos caracteres crees que vas a recibir o si esperas un caracter en especial interceptarlo y ejecutar un procedimiento o funcion.

Código Delphi [-]
procedure TMiForm.ComPortRxChar(Sender: TObject; Count: Integer);
var
  Cadena: string;
begin
  Cadena := '';
  {AQUI EL COMPONENTE LEE LO QUE RECIBE POR EL PUERTO COM}
  ComPort.ReadStr(Str, Count);
  
  {Aqui copiamos lo capturado.}
  
  //POR EJEMPLO EN UNA VARIABLE
  Cadena := Cadena + Str;
  
  //POR EJEMPLO EN UN MEMO
  Memo.Text := Memo.Text + Str;  }
end;

Sin embargo si conoces las caracteristicas de lo que vas a capturar, por ejemplo su longitud o un caracter terminador en especial es mejor usar el componente ComDataPacket el cual te permite capturar datos que entran como paquetes de longitud fija o limitados por un caracter de inicio y final. por ejemplo:

Cita:

LONGITUD FIJA:

+ 12.3 //9 CARACTERES
CLUB DELPHI //11 CARACTERES

LIMITADOS POR UNO O DOS CARACTERES

- 12.3<CR> //LIMITADO POR EL CARACTER ASCII CR (Carriage Return)
<STX>- 12.3<ETX> //LIMITADO POR CARACTER DE INICIO Y FINAL ASCII STX (Start of Transmition) y ETX (End OF Transmition)
Ambos RxChar y ComDataPacket son excluyentes, es decir que usas uno u otro pero no ambos.
En el ComDataPacket si usas una longitud de cadena fija y usas un caracter limitador final lo que ocurra primero determinara la ejecucion del mismo. Por ejemplo:

Cita:

- 12.3KGM<CR> //LIMITADO POR EL CARACTER ASCII CR (Carriage Return)

ComDataPacket.Length := 8;
ComDataPacket.StopString := #10;
Aqui el evento OnPacket se dispara cuando llegan los primeros 8 caracteres por lo que si te interesaba los otros 3 esos no se capturan.
Espero te sirvan estos comentarios para tus desarrollos.

emeceuy 29-02-2008 02:44:38

hola ! muchas gracias por las respuestas... :) efectivamente uso ese componente y está muy bueno, y hago algo similar a lo que plantean, el tema es que mi pregunta apuntaba más a como lograr eso dentro de un procedimiento... ejemplo:
Código Delphi [-]
procedure MiProcedure;
begin
{ 1. envio un comando }
{ 2. recibo respuesta }
{ 3. envio otro comando }
{ 4. recibo respuesta, etc, etc... }
end;

el tema es que si hago eso dentro de un procedimiento ("miprocedure"), comienzo enviando el comando, si verifico si hay respuesta (el estado de "cadena" como tu primer ejemplo FGarcia) inmediatamente seguramente todavía no haya llegado nada... o sea, tendría que poner demoras tipo sleep en el medio? y ahí como hago si quiero detener el procedimiento?, no se... y el evento de recepcion de caracteres del TComPort se dispara en forma simultanea a "miprocedure" o se detiene "miprocedure" captura la info del puerto y despues sigue?

muchas gracias a todos !!! salu2

duilioisola 29-02-2008 08:53:18

Si haces todo en un mismo procedimiento podrías hacerlo de esta manera:

Código Delphi [-]
procedure MiProcedure;
begin
{ 1. envio un comando }
   while (StringRecibido='') do ; {queda dentro del while hasta que recibe algo}
{ 2. recibo respuesta }
{ 3. envio otro comando }
   while (StringRecibido='') do ; {queda dentro del while hasta que recibe algo}
{ 4. recibo respuesta, etc, etc... }
end;

emeceuy 29-02-2008 18:30:48

ah si ! esa es una buena idea :) voy a probarla, el tema es que se me ocurre que mientras esté dentro de los whileo o dentro del procedure el programa va a quedar como bloqueado, quiero decir que no se va a refrescar el form ni voy a poder salir del procedimiento si quiero...

para eso puedo agregar dentro del while aplication.processmessage y así segurmanente pueda refrescar, etc, el tema es que si pongo el aplication.processmessage dentro de una funcion (en otra unit por ejemplo) me dice el error como que no sabe que es aplication... como lo soluciono?

salu2 y gracias :)

egostar 29-02-2008 18:48:00

Cita:

Empezado por emeceuy (Mensaje 269732)
ah si ! esa es una buena idea :) voy a probarla, el tema es que se me ocurre que mientras esté dentro de los whileo o dentro del procedure el programa va a quedar como bloqueado, quiero decir que no se va a refrescar el form ni voy a poder salir del procedimiento si quiero...

para eso puedo agregar dentro del while aplication.processmessage y así segurmanente pueda refrescar, etc, el tema es que si pongo el aplication.processmessage dentro de una funcion (en otra unit por ejemplo) me dice el error como que no sabe que es aplication... como lo soluciono?

salu2 y gracias :)

Bueno, desde donde yo lo veo, no deberías de tener problemas de que la aplicación se congele, todo parte de un primer envio que será por lo que comentas manual, a partir de ahí es un protocolo de comunicación que debe ser automático, es decir, terminará hasta que dejen de enviarse datos.

Te pongo un ejemplo

1. Dispositivo1 Envia Cadena(MANUAL) a Dispositivo2
2. Dispositivo2 Envia Cadena(AUTO) a Dispositivo1
3. Se verifica la cadena recibida
4. Es fin de Proceso (GOTO paso 6)
5. Dispositivo1 envia cadena(AUTO) a Dispositivo2 (GOTO Paso 2)
6. Terminar proceso

:rolleyes:, Me parece código tipo VB, :D:D:D

Salud OS

JoseFco 26-03-2008 01:22:08

Hola amigos.

Comentado por FGarcia.
Cita:

Ambos RxChar y ComDataPacket son excluyentes, es decir que usas uno u otro pero no ambos.
En el ComDataPacket si usas una longitud de cadena fija y usas un caracter limitador final lo que ocurra primero determinara la ejecucion del mismo. Por ejemplo:
La pregunta mia es la siguiente: En un mismo programa no puedo usar ambos?

Un Saludo.

richy08 28-06-2008 16:26:45

Buenos dias compañeros he leido el post y me parece muy interesanta creen que este componente me pueda leer los puertos seriales com1 o com2 de un conmutador muchas gracias.


La franja horaria es GMT +2. Ahora son las 17:33:48.

Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi