begin process at 2012 05 28 11:33:51
  Trouver un code source :
 
dans
 
Accueil > Forum > 

Archive C/C++

 > 

Archives

 > 

Au secours

 > 

Aide pour un programme,création variable


Derniers messages déposésPoser une question dans le forum ou lancer une discussion

Aide pour un programme,création variable

lundi 11 avril 2005 à 15:35:10 | Aide pour un programme,création variable

pirana

bonjour à vous tous ... Voila je suis un débutant en C... j'ai récupéré ce code sur le site et j'aimerai me simplifié la vie...mais je n'y arrive pas c'est pour cela que je fais appel à vous ...
Je m'explique : ce code permet d'envoyer ou de recevoir une trame à travers un RS232 ...  
Ce que j'aimerai faire c'est crée une variable qui me permetterai d'envoyer un caractère ou une chaine de caractère plus simplement, que de travailler avec gets(buffer)
un truc du style :  
Je veux envoyer '04'
send='04';
et ca me fait tt le traitement d'un coup  

Car j'aimertai envoyé un octet de Start et un de stop en fonction du menu dans lequel on rentre
 
J'espère avoir été assez clair , si ce nest po le cas ... contacté moi  
 
MERCI

Code :
  • /******************************************************************************
  •   TestCOM.c :
  •    
  •    fonctions de base pour l'envoi et la réception de donner sur un port
  •    série RS232.
  • ******************************************************************************/
  • #include <windows.h>
  • #include <stdio.h>
  • #include <stdlib.h>
  • #include <conio.h>
  • /*=============================================================================
  •   Définition de constantes
  • =============================================================================*/
  • #define RX_SIZE         4096    /* taille tampon d'entrée  */
  • #define TX_SIZE         4096    /* taille tampon de sortie */
  • #define MAX_WAIT_READ   5000    /* temps max d'attente pour lecture (en ms) */
  • /*=============================================================================
  •   Variables globales.
  • =============================================================================*/
  • /* Handle du port COM ouvert */
  • HANDLE g_hCOM = NULL;
  • /* Délais d'attente sur le port COM */
  • COMMTIMEOUTS g_cto =
  • {
  •     MAX_WAIT_READ,  /* ReadIntervalTimeOut          */
  •     0,              /* ReadTotalTimeOutMultiplier   */
  •     MAX_WAIT_READ,  /* ReadTotalTimeOutConstant     */
  •     0,              /* WriteTotalTimeOutMultiplier  */
  •     0               /* WriteTotalTimeOutConstant    */
  • };
  • /* Configuration du port COM */
  • DCB g_dcb =
  • {
  •     sizeof(DCB),        /* DCBlength            */
  •     9600,               /* BaudRate             */
  •     TRUE,               /* fBinary              */
  •     FALSE,              /* fParity              */
  •     FALSE,              /* fOutxCtsFlow         */
  •     FALSE,              /* fOutxDsrFlow         */
  •     DTR_CONTROL_ENABLE, /* fDtrControl          */
  •     FALSE,              /* fDsrSensitivity      */
  •     FALSE,              /* fTXContinueOnXoff    */
  •     FALSE,              /* fOutX                */
  •     FALSE,              /* fInX                 */
  •     FALSE,              /* fErrorChar           */
  •     FALSE,              /* fNull                */
  •     RTS_CONTROL_ENABLE, /* fRtsControl          */
  •     FALSE,              /* fAbortOnError        */
  •     0,                  /* fDummy2              */
  •     0,                  /* wReserved            */
  •     0x100,              /* XonLim               */
  •     0x100,              /* XoffLim              */
  •     8,                  /* ByteSize             */
  •     NOPARITY,           /* Parity               */
  •     ONESTOPBIT,         /* StopBits             */
  •     0x11,               /* XonChar              */
  •     0x13,               /* XoffChar             */
  •     '?',                /* ErrorChar            */
  •     0x1A,               /* EofChar              */
  •     0x10                /* EvtChar              */
  • };
  • /*=============================================================================
  •   Fonctions du module.
  • =============================================================================*/
  • BOOL OpenCOM    (int nId);
  • BOOL CloseCOM   ();
  • BOOL ReadCOM    (void* buffer, int nBytesToRead, int* pBytesRead);
  • BOOL WriteCOM   (void* buffer, int nBytesToWrite, int* pBytesWritten);
  • /******************************************************************************
  •   main : point d'entrée du programme.
  • ******************************************************************************/
  • int main()
  • {
  •     /* variables locales */
  •     char buffer[256];
  •     int nId, nChoice, nBytesWritten, nBytesRead;
  •     /* demande du numéro du port COM */
  •     printf("Entrez le numero du port COM : ");
  •     scanf("%d", &nId);
  •     /* tentative d'ouverture */
  •     printf("Ouverture et configuration du port COM%d...\r\n", nId);
  •     if(!OpenCOM(nId)) return -1;
  •     printf("...OK\r\n");
  •     /* boucle tant que l'on ne quitte pas */
  •     do
  •     {
  •         /* menu */
  •         printf("\r\n");
  •         printf("1 : Envoyer des donnees.\r\n");
  •         printf("2 : Recevoir des donnees.\r\n");
  •         printf("3 : Quitter.\r\n");
  •         printf("Choix : ");
  •         scanf("%d", &nChoice);
  •         /* enoyer des données */
  •         if(nChoice == 1)
  •         {
  •             printf("\r\n");
  •             printf("Donnees a envoyer :\r\n");
  •             fflush(stdin);
  •             gets(buffer);
  •             printf("\r\n");
  •             printf("Envoi des donnees...\r\n");
  •             if(WriteCOM(buffer, strlen(buffer), &nBytesWritten))
  •                 printf("%d octet(s) envoye(s).\r\n", nBytesWritten);
  •             else
  •                 printf("Erreur lors de l'envoi.\r\n");
  •         }
  •         /* recevoir des données */
  •         if(nChoice == 2)
  •         {
  •             printf("\r\n");
  •             printf("Reception de donnees...\r\n");
  •             if(ReadCOM(buffer, sizeof(buffer)-1, &nBytesRead))
  •             {
  •                 buffer[nBytesRead] = '\0';
  •                 printf("%d octet(s) recu(s) :\r\n%s\r\n", nBytesRead, buffer);
  •             }
  •             else
  •                 printf("Erreur lors de la réception.\r\n");
  •         }
  •     }while(nChoice != 3);
  •     /* fermeture du port COM et retour */
  •     CloseCOM();
  •     return 0;
  • }
  • /******************************************************************************
  •   OpenCOM : ouverture et configuration du port COM.
  •   entrée : nId : Id du port COM à ouvrir.
  •   retour : vrai si l'opération a réussi, faux sinon.
  • ******************************************************************************/
  • BOOL OpenCOM(int nId)
  • {
  •     /* variables locales */
  •     char szCOM[16];
  •     /* construction du nom du port, tentative d'ouverture */
  •     sprintf(szCOM, "COM%d", nId);
  •     g_hCOM = CreateFile(szCOM, GENERIC_READ|GENERIC_WRITE, 0, NULL,
  •                         OPEN_EXISTING, FILE_ATTRIBUTE_SYSTEM, NULL);
  •     if(g_hCOM == INVALID_HANDLE_VALUE)
  •     {
  •         printf("Erreur lors de l'ouverture du port COM%d", nId);
  •         return FALSE;
  •     }
  •     /* affectation taille des tampons d'émission et de réception */
  •     SetupComm(g_hCOM, RX_SIZE, TX_SIZE);
  •     /* configuration du port COM */
  •     if(!SetCommTimeouts(g_hCOM, &g_cto) || !SetCommState(g_hCOM, &g_dcb))
  •     {
  •         printf("Erreur lors de la configuration du port COM%d", nId);
  •         CloseHandle(g_hCOM);
  •         return FALSE;
  •     }
  •     /* on vide les tampons d'émission et de réception, mise à 1 DTR */
  •     PurgeComm(g_hCOM, PURGE_TXCLEAR|PURGE_RXCLEAR|PURGE_TXABORT|PURGE_RXABORT);
  •     EscapeCommFunction(g_hCOM, SETDTR);
  •     return TRUE;
  • }
  • /******************************************************************************
  •   CloseCOM : fermeture du port COM.
  •   retour : vrai si l'opération a réussi, faux sinon.
  • ******************************************************************************/
  • BOOL CloseCOM()
  • {
  •     /* fermeture du port COM */
  •     CloseHandle(g_hCOM);
  •     return TRUE;
  • }
  • /******************************************************************************
  •   ReadCOM : lecture de données sur le port COM.
  •   entrée : buffer       : buffer où mettre les données lues.
  •            nBytesToRead : nombre max d'octets à lire.
  •            pBytesRead   : variable qui va recevoir le nombre d'octets lus.
  •   retour : vrai si l'opération a réussi, faux sinon.
  • -------------------------------------------------------------------------------
  •   Remarques : - la constante MAX_WAIT_READ utilisée dans la structure
  •                 COMMTIMEOUTS permet de limiter le temps d'attente si aucun
  •                 caractères n'est présent dans le tampon d'entrée.
  •               - la fonction peut donc retourner vrai sans avoir lu de données.
  • ******************************************************************************/
  • BOOL ReadCOM(void* buffer, int nBytesToRead, int* pBytesRead)
  • {
  •     return ReadFile(g_hCOM, buffer, nBytesToRead, pBytesRead, NULL);
  • }
  • /******************************************************************************
  •   WriteCOM : envoi de données sur le port COM.
  •   entrée : buffer        : buffer avec les données à envoyer.
  •            nBytesToWrite : nombre d'octets à envoyer.
  •            pBytesWritten : variable qui va recevoir le nombre d'octets
  •                            envoyés.
  •   retour : vrai si l'opération a réussi, faux sinon.
  • ******************************************************************************/
  • BOOL WriteCOM(void* buffer, int nBytesToWrite, int* pBytesWritten)
  • {
  •     /* écriture sur le port */
  •     return WriteFile(g_hCOM, buffer, nBytesToWrite, pBytesWritten, NULL);
  • }




lundi 11 avril 2005 à 17:36:50 | Re : Aide pour un programme,création variable

ymca2003

BYTE buffer[32];
buffer[0] = 0x12;
buffer[1] = 0x34;
...
buffer[len-1] = 0x56; (len <= 32)
WriteCOM(buffer, len, &nBytesWritten);

pour envoyer un seul octet :
BYTE b = 0x45;
WriteCOM(&b, 1, &nBytesWritten);
lundi 11 avril 2005 à 17:42:20 | Re : Aide pour un programme,création variable

Arnotic

Administrateur CodeS-SourceS
De plus sur le site tu as de multiples exemples complets :

http://www.cppfrance.com/gma/rs223

@+
Arnotic,
Admin CS, MVP Visual C++
lundi 11 avril 2005 à 19:02:17 | Re : Aide pour un programme,création variable

pirana

merci à toi ymca2003 :

mais je n'est pas tt compris dans ton code ... tu pourrais m'expliqué un peu plus ..

BYTE buffer[32];   // Définition du type de buffer ... (est ce compatible avec mon autre déclaration de buffer )
buffer[0] = 0x12;  
buffer[1] = 0x34;
...
buffer[len-1] = 0x56; (len <= 32)  // questque "len" pour envoyer un serie d'octet ?
WriteCOM(buffer, len, &nBytesWritten);

pour envoyer un seul octet :
BYTE b = 0x45;
WriteCOM(&b, 1, &nBytesWritten);

Question ??
Estceque je peux déclarer plusieur buffer du style ..

BYTE buffer[32]; 
char buffer_reception[256];

buffer[len-1] = 0x56; (len <= 32)
WriteCOM(buffer, len, &nBytesWritten);

WriteCOM(buffer_reception, len, &nBytesWritten);

merci






mardi 12 avril 2005 à 09:07:50 | Re : Aide pour un programme,création variable

ymca2003

BYTE : il s'agit en fait du type unsigned char soit en fait des octets non signés, c'est ce qu'il y a de plus simple pour des buffers contenant du binaire.
Avec la fct WriteCOM on peut envoyer n'importe quoi (un buffer, une chaîne, un entier, une structure...) vu que le type est void* (pointeur sur tout et n'importe quoi). Il suffit de bien précisé le nombre d'octets (strlen pour les chaîne, sizeof pour des structures...)

'len' est en fait une variable pour stocker la longueur (lenght in english, sorry c'est par habitude) du buffer (j'ai mis <= 32 car il y a 32 octets dans le buffer que j'ai déclaré)


Cette discussion est classée dans : buffer, port, printf, false, hcom


Répondre à ce message

Sujets en rapport avec ce message

Communication RS232 : Pb de vitesse [ par arb ] Bonjour Je me suis insipiré du code de ymca2003 (Code source N°22441) pour faire un petit programme qui envoie le contenu d'un fichier via une liais Communication RS232 : Pb de vitesse [ par arb ] Bonjour Je me suis insipiré du code de ymca2003 (Code source N°22441) pour faire un petit programme qui envoie le contenu d'un fichier via une liais Com RS232 [ par Dohko10270 ] Bonjour, Actuellement je cherche à récupérer une trame via la liaison RS232, je réussi très bien à faire ce que je veux à l'aide d'hyperterminal, c'e besoin d'aide sur communication [ par keast ] salut tout le monde, Voila je suis vraiment nul en info et j'ai un problème en ce moment sur un projet. Je dois piloté un appareil qui celui-ci fonct Erreur d'execution d'uns dll [ par fabrice91 ] Bonjour tout le monde, voici mon problème : J'ai récupéré un code sur ce fabuleux site qu'est cppfrance;) (http://www.cppfrance.com/codes/BASE-COMMUNI SOS reception et affichage sur port serie [ par dgac ] J'ai dévellopé le programme suivant pour recevoir et afficher une chaine de carractére pour un port serie . J'aimerai de l'aide pour recevoir un carra ouverture d'un port serie [ par KryztL ] bonjour tout le monde,j aurai besoin d aide pour le projet que je suis entrain de programmer.je souhaite ouvrir un port serie sous visual studio C++, RS232 [ par th62d ] Bonjour,J'essaie de faire communiquer mon pc via le port serie RS232.....Quand je lance le programme TestCOM.c j'ai l'erreur suivante à la compilation prb a la compilation vous vc++ [ par shadow1779 ] Bonjour,j'ai tenté de faire un programme en C utilisant les sockets, la personne qui lance son programme choisi elle meme l'ip et le port a se connect client irc [ par tagboys ] bon j'ai trouver une source sur ce site ces un socket bot j'aimerait y rajouter quelque commands .la seul chose qu'il a ces le pong reply .j'aimerait


Nos sponsors


Sondage...

CalendriCode

Mai 2012
LMMJVSD
 123456
78910111213
14151617181920
21222324252627
28293031   

Consulter la suite du CalendriCode

A découvrir



 
Développement réalisé par Nicolas SOREL (Nix) avec l'aide de : Cyril DURAND et Emmanuel (EBArtSoft), Merci à Vincent pour ses précieux conseils.
CodeS-SourceS.com© Toute reproduction même partielle est interdite sauf accord écrit du Webmaster
CodeS-SourceS.com© est une marque déposée tous droits réservés

Google Coop CodeS-SourceS Google Coop CodeS-SourceS
Temps d'éxécution de la page : 1,716 sec (4)

Nous contacter | Annoncer sur CodeS-SourceS | Mentions légales