RS232Model.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  1. /*************************************************
  2. /* Copyright (C), 2010-2012,StoneU. Co., Ltd.
  3. /* File name: St_3c3ex40ks.h
  4. /* Author: Zero.t
  5. /* Version: Ver1.0.0.1
  6. /* Date: 2012-04-16
  7. /* Description: 山特 3C3系列UPS,3C3 Ex 40ks;本类首次使用在项目四川 澳新银行;
  8. /* Others: UPS协议类,不做控制设备操作,本协议同样可用以伊顿UPS;
  9. /* Function List: ###
  10. /* History:
  11. 1.Date: 2012.10.26
  12. Author: Zero.t
  13. Modification: 简化了部分内容;
  14. /* 测试通过否: OK
  15. *************************************************/
  16. #ifndef RS232MODEL_H
  17. #define RS232MODEL_H
  18. #pragma once
  19. #include "CommInterface.h"
  20. class RS232Model:public CCommInterface
  21. {
  22. #define DEBGU_RS232MODEL 1 // 模拟测试控制开关;
  23. // 此枚举放在全局中;
  24. //enum __ERRO_CODE_
  25. //{
  26. // ERR_CODE_COM_FAULT = 50201 , //设备串口通信故障
  27. // ERR_CODE_COM_BUSY , //设备串口通信忙
  28. // ERR_CODE_COM_READ_NO_DATA , //设备没有读到数据
  29. // ERR_CODE_COM_READ_LEN_OVER , //设备读到数据长度超时限制
  30. // ERR_CODE_COM_LRC_LOST , //设备lrc校验失败
  31. // EER_CODE_COM_WRITE_DATA , //设备写串口错误
  32. // EER_CODE_COM_REGNUM , //设备寄存器数
  33. // ERR_CODE_COM_VARLEN , //设备变量长度非法
  34. // ERR_CODE_COM_INVALIDRES , //设备无效应答
  35. //};
  36. public:
  37. RS232Model(char *szPath,char *szIniName,int nCommPort,int nAddr,int nRate,int nDataBit,int nStopBit,int nParity,int nInterval);
  38. ~RS232Model(void);
  39. BOOL RS232ModelOpenComm(int nCommPort, int nAddr, int nRate, int nDataBit, int nStopBit, int nParity, int nInterval);
  40. // 发送读请求;
  41. int SendReadRequest(
  42. char *szPath, // 程序所在路径
  43. char *szIniName, // 配置文件名称
  44. int nCommPort, // 串行端口
  45. int nAddr, // 设备地址
  46. char *szCmd, // 请求命令
  47. char *szMsg, // 响应的值
  48. int nReversed1, // 预留整形参数1接口
  49. int nReversed2, // 预留整形参数2接口
  50. int nReversed3, // 预留整形参数3接口
  51. int nReversed4, // 预留整形参数4接口
  52. int nReversed5, // 预留整形参数5接口
  53. float fReversed1, // 预留float参数1接口
  54. float fReversed2, // 预留float参数2接口
  55. float fReversed3, // 预留float参数3接口
  56. char *szReversed1, // 预留字符数组参数1接口
  57. char *szReversed2, // 预留字符数组参数2接口
  58. char *szReversed3, // 预留字符数组参数3接口
  59. char *szReversed4, // 预留字符数组参数4接口
  60. char *szReversed5 // 预留字符数组参数5接口
  61. );
  62. // 发送写设置;
  63. int SendSetReuest(
  64. char *szPath, // 程序所在路径
  65. char *szIniName, // 配置文件名称
  66. int nCommPort, // 串行端口
  67. int nAddr, // 设备地址
  68. char *szCmd, // 请求命令
  69. char *szMsg, // 响应的值
  70. int nReversed1, // 预留整形参数1接口
  71. int nReversed2, // 预留整形参数2接口
  72. int nReversed3, // 预留整形参数3接口
  73. int nReversed4, // 预留整形参数4接口
  74. int nReversed5, // 预留整形参数5接口
  75. float fReversed1, // 预留float参数1接口
  76. float fReversed2, // 预留float参数2接口
  77. float fReversed3, // 预留float参数3接口
  78. char *szReversed1, // 预留字符数组参数1接口
  79. char *szReversed2, // 预留字符数组参数2接口
  80. char *szReversed3, // 预留字符数组参数3接口
  81. char *szReversed4, // 预留字符数组参数4接口
  82. char *szReversed5 // 预留字符数组参数5接口
  83. );
  84. protected:
  85. int GetDeviceParam( CCommProcess *pComm,char *IniSendCMD,const int &IniSendlen, char *szCmd);
  86. // 同样GetInfo也放在全局中;
  87. //int GetIniInfo( char *szPath,char *szIniName,char *szCmd,char *IniSendCMD,int &IniSendlen,char *szDataType,int &nIndex,int &nLen);
  88. // 读设备;
  89. public:
  90. int Send_ReadDeviceData(CCommProcess *pComm,const char *IniSendCMD,const int &IniSendlen);
  91. int Recv_ReadDeviceData(CCommProcess *pComm,const char *IniSendCMD,char *szCmd);
  92. int GetSanTak_Q2Msg(const char *IniSendCMD,char *szCmd,char *szMsg,int &nIndex,int &nLen,char *szType);
  93. void SetSanTakQ2Msg( const char *IniSendCMD,char *szCmd, char *pBuffer);
  94. void SimulationCommData();
  95. private:
  96. BOOL m_dwOnlineTick;
  97. BOOL m_devOnline;
  98. HANDLE m_hSemComm;
  99. CRITICAL_SECTION m_csReadMsg;
  100. char m_szQ2Msg[MAX_RECE_MSG];
  101. char m_szWAMsg[MAX_RECE_MSG];
  102. };
  103. #endif