Accueil > > > ÉVENEMENT PORT SÉRIE
ÉVENEMENT PORT SÉRIE
Information sur la source
Description
J'ai vu presque tous les codes sur cppfrance qui traîte le port série, mais la gestion du port est généralement mal faite alors j'ai voulu contribuer par cette classe qui un peut plus complète en traîtant les événements du port, j'éspère que sa va aider quelqu'un ! voilà la classe comment elle est définie mais vous trouvez tous dans les fichiers
Source
- // SerialCom.h
-
- #if !defined(AFX_SERIALCOM)
- #define AFX_SERIALCOM
-
- #if _MSC_VER > 1000
- #pragma once
- #endif
-
- // _MSC_VER > 1000
-
- // Farscape-dev@Tiscali.fr : Classe Mininum gestion port série.
- // Release du 01/11/2004: Met private le constructeur de copie et l'operateur d'affectation.
- // Release du 05/05/2004 :Gestion d'un thread de reception des données
- // rajoute les fonctions suivantes:
- //
- // void SetParentNotify(CWnd *pParent){m_pParent=pParent;}
- // bool PurgeCom();
- // boolPurgeRx();
- // boolPurgeTx();
- // bool StartThread(CWnd *pParent);
- // boo lResumeThread();
- // bool StopThread();
- // bool SetTimeouts(DWORD dwRxTimeout=5000,DWORD dwTxTimeout=5000);
- // virtual void OnError(DWORD dwError);
- // bool IsRXEmpty();
- // Modifications et correction de :
- // bool WaitCommEvent(DWORD &rEvtMask);
-
- #define XON 17
- #define XOFF 19
-
- // messages à destination de la fenêtre de traitement.
-
- #define WM_CCOMRCV WM_USER+100 // réceptions sur la voie série
- #define WM_CCOMEVENT WM_USER+101 // evénements sur la voie série.
- #define WM_CCOMERROR WM_USER+102 // erreurs sur la voie série.
-
- class CCom
- {
- public:
- void ThreadEcriture();
- void EnvoiMessage(int num_message);
- CCom();
- ~CCom();
-
- // ouverture du port série
- bool PortOpen(int portnumber,long baudrate,char parity,int wordlength,int stopbits);
- // réglage vitesse ,parité ,longueur de la data et du bit de stop.
- // ex : 1 : Com1 , ’N’ :none , 8 : data 8 bits , 1 ou 2 : bit de stop
- bool PortSet(long baudrate,char parity,int wordlength,int stopbits);
-
- // Fermeture du port.
- bool PortClose();
-
- // Envoie d’une chaîne de caractères la longueur est facultative si elle se termine par ‘\0’
- bool WriteBuffer(const char *buffer,unsigned int ucount=0);
-
- // lecture d’une chaîne de caractères d’une taille donnée.
- // GetCountRead() contiendra la taille reellement lue .
- int ReadBuffer(char *buffer,unsigned int ucount);
-
- // lecture d'un charactere.
- bool ReadChar(char &rchar);
-
- // Réglage du mode de communication XON/XOFF
- bool UseXonXoff(bool bEnable=true);
-
- // Réglage du mode de communication Rts/Cts
- bool UseRtsCts(bool bEnable=true);
-
- // Réglage du mode de communication Dtr/Dsr
- bool UseDtrDsr(bool bEnable=true);
-
- // Renvoie le nombre d'octets dans le buffer de reception avant lecture
- long SizeUsedInRXBuf();
-
- // renvoie true si le buffer de reception est vide.
- bool IsRXEmpty();
-
- // Attente d’un événement fixé par SetCommMask()
- bool WaitCommEvent(DWORD &rEvtMask);
-
- // fixe la gestion des evenements sur le port serie. Voir doc MSDN : EV_RXCHAR
- bool SetCommMask(DWORD EvtMask);
-
- // recupere l'événement en cours.
- DWORD GetCommMask();
-
- // Renvoie sous forme litterale la derniere erreur rencontrée avec GetLastError()
- CString GetStringError(){return m_StrError;}
-
- // Renvoie la derniere valeur du nombre d’octets lus.
- int GetCountRead(){return m_count;}
-
- // fixe la fenetre parent pour les messages en provenance de la voie serie.
- void SetParentNotify(HWND *pParent){m_pParent=pParent;}
-
- // purge le port serie.
- bool PurgeCom();
-
- // purge la réception
- bool PurgeRx();
-
- // purge l'émission
- bool PurgeTx();
-
- // lancer le thread
- bool StartThread(HWND *pParent);
-
- // redemarre le thread
- bool ResumeThread();
-
- // stop le thread.
- bool StopThread();
-
- // réglage du timeout sur la reception et l'émission
- // Note par défaut le reglage de la voie est a 1s.
- bool SetTimeouts(DWORD dwRxTimeout=5000,DWORD dwTxTimeout=5000);
-
- // fonction appelée en cas d'erreur detectée dans le thread.
- // envoie un message à la fenetre parent.
- virtual void OnError(DWORD dwError);
-
- private:
- CCom(const CCom &rCom){ASSERT(0);}
- CCom & operator = (const CCom & arg){ASSERT(0);return *this;}
-
- protected:
-
- // thread de communication.
- static UINT Thread(LPVOID pParam);
-
- // récupération de l’erreur
- DWORD GetError();
-
- protected:
- HWND *m_pParent;
- CString m_StrError;
- DWORD m_comerr;
- HANDLE m_hCom;
- UINT m_nInputBufferSize;
- UINT m_nOutputBufferSize;
- DCB m_dcb;
- DWORD m_EventMask;
- COMMTIMEOUTS m_ComTimeouts;
- OVERLAPPED m_Ov;
- unsigned int m_count;
-
- long m_baudrate;
- char m_parity;
- int m_wordlength;
- int m_stopbits;
- CWinThread* m_pThread;
- HANDLE m_hCloseCom;
- HANDLE m_hArrayEvent[2];
- bool m_bThreadExist;
- };
- #endif
-
- // !defined(AFX_SERIALCOM)
-
- // cpp
// SerialCom.h
#if !defined(AFX_SERIALCOM)
#define AFX_SERIALCOM
#if _MSC_VER > 1000
#pragma once
#endif
// _MSC_VER > 1000
// Farscape-dev@Tiscali.fr : Classe Mininum gestion port série.
// Release du 01/11/2004: Met private le constructeur de copie et l'operateur d'affectation.
// Release du 05/05/2004 :Gestion d'un thread de reception des données
// rajoute les fonctions suivantes:
//
// void SetParentNotify(CWnd *pParent){m_pParent=pParent;}
// bool PurgeCom();
// boolPurgeRx();
// boolPurgeTx();
// bool StartThread(CWnd *pParent);
// boo lResumeThread();
// bool StopThread();
// bool SetTimeouts(DWORD dwRxTimeout=5000,DWORD dwTxTimeout=5000);
// virtual void OnError(DWORD dwError);
// bool IsRXEmpty();
// Modifications et correction de :
// bool WaitCommEvent(DWORD &rEvtMask);
#define XON 17
#define XOFF 19
// messages à destination de la fenêtre de traitement.
#define WM_CCOMRCV WM_USER+100 // réceptions sur la voie série
#define WM_CCOMEVENT WM_USER+101 // evénements sur la voie série.
#define WM_CCOMERROR WM_USER+102 // erreurs sur la voie série.
class CCom
{
public:
void ThreadEcriture();
void EnvoiMessage(int num_message);
CCom();
~CCom();
// ouverture du port série
bool PortOpen(int portnumber,long baudrate,char parity,int wordlength,int stopbits);
// réglage vitesse ,parité ,longueur de la data et du bit de stop.
// ex : 1 : Com1 , ’N’ :none , 8 : data 8 bits , 1 ou 2 : bit de stop
bool PortSet(long baudrate,char parity,int wordlength,int stopbits);
// Fermeture du port.
bool PortClose();
// Envoie d’une chaîne de caractères la longueur est facultative si elle se termine par ‘\0’
bool WriteBuffer(const char *buffer,unsigned int ucount=0);
// lecture d’une chaîne de caractères d’une taille donnée.
// GetCountRead() contiendra la taille reellement lue .
int ReadBuffer(char *buffer,unsigned int ucount);
// lecture d'un charactere.
bool ReadChar(char &rchar);
// Réglage du mode de communication XON/XOFF
bool UseXonXoff(bool bEnable=true);
// Réglage du mode de communication Rts/Cts
bool UseRtsCts(bool bEnable=true);
// Réglage du mode de communication Dtr/Dsr
bool UseDtrDsr(bool bEnable=true);
// Renvoie le nombre d'octets dans le buffer de reception avant lecture
long SizeUsedInRXBuf();
// renvoie true si le buffer de reception est vide.
bool IsRXEmpty();
// Attente d’un événement fixé par SetCommMask()
bool WaitCommEvent(DWORD &rEvtMask);
// fixe la gestion des evenements sur le port serie. Voir doc MSDN : EV_RXCHAR
bool SetCommMask(DWORD EvtMask);
// recupere l'événement en cours.
DWORD GetCommMask();
// Renvoie sous forme litterale la derniere erreur rencontrée avec GetLastError()
CString GetStringError(){return m_StrError;}
// Renvoie la derniere valeur du nombre d’octets lus.
int GetCountRead(){return m_count;}
// fixe la fenetre parent pour les messages en provenance de la voie serie.
void SetParentNotify(HWND *pParent){m_pParent=pParent;}
// purge le port serie.
bool PurgeCom();
// purge la réception
bool PurgeRx();
// purge l'émission
bool PurgeTx();
// lancer le thread
bool StartThread(HWND *pParent);
// redemarre le thread
bool ResumeThread();
// stop le thread.
bool StopThread();
// réglage du timeout sur la reception et l'émission
// Note par défaut le reglage de la voie est a 1s.
bool SetTimeouts(DWORD dwRxTimeout=5000,DWORD dwTxTimeout=5000);
// fonction appelée en cas d'erreur detectée dans le thread.
// envoie un message à la fenetre parent.
virtual void OnError(DWORD dwError);
private:
CCom(const CCom &rCom){ASSERT(0);}
CCom & operator = (const CCom & arg){ASSERT(0);return *this;}
protected:
// thread de communication.
static UINT Thread(LPVOID pParam);
// récupération de l’erreur
DWORD GetError();
protected:
HWND *m_pParent;
CString m_StrError;
DWORD m_comerr;
HANDLE m_hCom;
UINT m_nInputBufferSize;
UINT m_nOutputBufferSize;
DCB m_dcb;
DWORD m_EventMask;
COMMTIMEOUTS m_ComTimeouts;
OVERLAPPED m_Ov;
unsigned int m_count;
long m_baudrate;
char m_parity;
int m_wordlength;
int m_stopbits;
CWinThread* m_pThread;
HANDLE m_hCloseCom;
HANDLE m_hArrayEvent[2];
bool m_bThreadExist;
};
#endif
// !defined(AFX_SERIALCOM)
// cpp
Sources de la même categorie
Commentaires et avis
Discussions en rapport avec ce code source dans le forum
gérer un port série en asynchrone [ par stgi02 ]
bonjour,mon application est de gérer un port série en asynchrone mais je me demande que dois-je mettre comme argument à lpOverlapped je
CreateFile et port COM supérieur à 9 [ par agremlins ]
Bonjour,J'ai une dll qui s'occupe de la connexion avec des périphériques branchés sur le port série.J'utilise La fonction CreateFi
Rediriger des données venant du port série sur l'entrée clavier.... [ par lecods ]
Bonjour,voila mon problème.Lorsqu'on connecte un périphérique comme un lecteur de code à barre sur l'entrée clavier, lorsqu'o
utiliser un port USB comme un port série [ par Radium The Hammer ]
Bonjour, comme je l'ai lu dans le forum on peut utiliser un port USB par l'intermédiare d'un port série. Par exemple, quand j'utilise hyper
Demande d'avis sur une idée de projet [ par beral_ ]
Bonjour à tous!Je voudrais votre avis quand à la possibilité de faire ce qui suit:-Sous visual C++-Application windowsJe voudrais un pr
trouver le numéro de port série bluetooth [ par hdaniel ]
Bonjour, Lorsque l'on créé un port virtuel bluetooth, un numéro de port lui est attribué. Ce numéro change à chaque foi
Port Série [ par Vin Gazoil ]
Salut à tous ! Voila en fait je suis étudiant en informatique, j'ai un projet à réaliser, ce projet consiste à créer un
port série et // [ par pepper18 ]
salut à tous je fais un petit projet en C dans lequel je réceptionne des données avec un modem rs232. j'envoie ces données avec le
fonction lire ds un port série [ par imanewin32 ]
pour réaliser la lecture ds un prog qui gére la communication atravers un port série,j'ai réalisé le codeDWORD comserie::lectport(char* e,int t){ Set
Port série [ par Rafex ]
Bonjours a tous. J'ai un peu regardé quelques post parlant de la prog port série, et je n'ai pas encore vu de liens vers des sites traitant le sujet
|
Derniers Blogs
COMMENT MAPPER UNE VUE SQL SUR UNE COLLECTION DE COMPLEX TYPE?COMMENT MAPPER UNE VUE SQL SUR UNE COLLECTION DE COMPLEX TYPE? par Matthieu MEZIL
Avec EF, les vues doivent être mappées sur des entity types. Le problème c'est que les entity types doivent avoir une clé. Avec EF, nous avons les complex type qui n'ont pas de clé mais les vues ne peuvent pas être mappées dessus. Avec EF4, il est possibl...
Cliquez pour lire la suite de l'article par Matthieu MEZIL [WF4] UN BINDING ACTIVITY/ACTIVITYDESIGNER QUI PASSE MAL?[WF4] UN BINDING ACTIVITY/ACTIVITYDESIGNER QUI PASSE MAL? par JeremyJeanson
Certain d'entre vous on peut être vécu cette situation embarrassante après quelques temps passer avec WF4 : Au début avec mon " ActivityDesigner" , tout allait bien. Et puis un jour j'ai au des problèmes de " Binding" . Alors nous sommes allé sur le site ...
Cliquez pour lire la suite de l'article par JeremyJeanson MYTIC - SHAREPOINT 2010 : DéJà UN MYTHE MICROSOFT ?MYTIC - SHAREPOINT 2010 : DéJà UN MYTHE MICROSOFT ? par junarnoalg
La prochaine session de MyTIC aura lieu à Namur, le 23 mars prochain. Pendant presque une heure, nous parlerons de SharePoint 2010. Voici un aperçu du programme.
Accueil : 17h30 Début de la session : 18h00 - Les nouvelles int...
Cliquez pour lire la suite de l'article par junarnoalg
Logiciels
Academy System (10.9.4.0)ACADEMY SYSTEM (10.9.4.0)Logiciel de gestion des établissements.
- élèves/étudiants (inscription, dossier, absence...)
-... Cliquez pour télécharger Academy System Xilisoft Convertisseur Vidéo Ultimate (5.1.39.0305)XILISOFT CONVERTISSEUR VIDéO ULTIMATE (5.1.39.0305)Xilisoft Convertisseur Vidéo Ultimate est un outil puissant de conversion vidéo, facile à utilise... Cliquez pour télécharger Xilisoft Convertisseur Vidéo Ultimate Xilisoft DVD Ripper Ultimate (5.0.64.0304)XILISOFT DVD RIPPER ULTIMATE (5.0.64.0304)Xilisoft DVD Ripper Ultimate est un logiciel excellent pour copier et convertir DVD vers presque ... Cliquez pour télécharger Xilisoft DVD Ripper Ultimate Rigs of Rods (63.3)RIGS OF RODS (63.3)c'est un jeu de multi-simulation camions,autobus voitures, avions, bateaux, hélicoptère avec défo... Cliquez pour télécharger Rigs of Rods
|