SecUPS.h 6.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. // SecUPS.h: interface for the CSecUPS class.
  2. //
  3. //////////////////////////////////////////////////////////////////////
  4. #if !defined(AFX_SECUPS_H__0C5805B4_8C8C_490B_BB1F_BE48D0AB5E19__INCLUDED_)
  5. #define AFX_SECUPS_H__0C5805B4_8C8C_490B_BB1F_BE48D0AB5E19__INCLUDED_
  6. #if _MSC_VER > 1000
  7. #pragma once
  8. #endif // _MSC_VER > 1000
  9. #include "CommInterface.h"
  10. #include "CommProcess.h"
  11. class CSecUPS : public CCommInterface
  12. {
  13. #define DEBUG_SEC 1 //调试开关
  14. #define INFO_MSG 255 //INFO数据最长长度;
  15. #define SEC_SEND_MSG 32 //发送Buffer的最长长度;
  16. // UPS SEC 设备Dll错误代码定义
  17. enum __ERRO_CODE_DATAMATE3000
  18. {
  19. ERR_CODE_COM_FAULT = 50201 , //SEC设备串口通信故障
  20. ERR_CODE_COM_BUSY , //SEC设备串口通信忙
  21. ERR_CODE_COM_READ_NO_DATA , //SEC设备没有读到数据
  22. ERR_CODE_COM_READ_LEN_OVER , //SEC设备读到数据长度超时限制
  23. ERR_CODE_COM_CHKSUM_LOST , //SEC设备校验失败
  24. EER_CODE_COM_WRITE_DATA , //SEC设备写串口错误
  25. EER_CODE_COM_REGNUM , //SEC设备寄存器数
  26. ERR_CODE_COM_VARLEN , //SEC设备变量长度非法
  27. ERR_CODE_COM_INVALIDRES , //SEC设备无效应答
  28. };
  29. typedef struct __PROTOCOL_STRUCT
  30. {
  31. BYTE SendHead;
  32. BYTE SendType;
  33. BYTE SendLength[3];
  34. BYTE SendData[128];
  35. }POTOCOLPARAM_STRUCT;
  36. public:
  37. CSecUPS(
  38. char szPath[MAX_PATH], // 程序所在路径
  39. char szIniName[MAX_PATH], // 配置文件名称
  40. int nCommPort, // 串行端口
  41. int nAddr, // 设备地址
  42. int nRate, // 波特率
  43. int nDataBit, // 数据位
  44. int nStopBit, // 停止位
  45. int nParity, // 校验位
  46. int nInterval // 时间间隔
  47. );
  48. virtual ~CSecUPS();
  49. public:
  50. void ReturnData(char *szSource, char *szDestion, int nIndex);
  51. int SendReadRequest(
  52. char szPath[MAX_PATH], // 程序所在路径
  53. char szIniName[MAX_PATH], // 配置文件名称
  54. int nCommPort, // 串行端口
  55. int nAddr, // 设备地址
  56. char szCmd[MAX_CMD], // 请求命令
  57. char szRecvMsg[VAR_MSG], // 响应的值
  58. int nReversed1, // 预留整形参数1接口
  59. int nReversed2, // 预留整形参数2接口
  60. int nReversed3, // 预留整形参数3接口
  61. int nReversed4, // 预留整形参数4接口
  62. int nReversed5, // 预留整形参数5接口
  63. float fReversed1, // 预留float参数1接口
  64. float fReversed2, // 预留float参数2接口
  65. float fReversed3, // 预留float参数3接口
  66. char szReversed1[MAX_RESERVED1], // 预留字符数组参数1接口
  67. char szReversed2[MAX_RESERVED2], // 预留字符数组参数2接口
  68. char szReversed3[MAX_RESERVED3], // 预留字符数组参数3接口
  69. char szReversed4[MAX_RESERVED4], // 预留字符数组参数4接口
  70. char szReversed5[MAX_RESERVED5] // 预留字符数组参数5接口
  71. );
  72. // 发送设置设备参数请求
  73. int SendSetReuest(
  74. char szPath[MAX_PATH], // 程序所在路径
  75. char szIniName[MAX_PATH], // 配置文件名称
  76. int nCommPort, // 串行端口
  77. int nAddr, // 设备地址
  78. char szCmd[MAX_CMD], // 请求命令
  79. char szRecvMsg[VAR_MSG], // 响应的值
  80. int nReversed1, // 预留整形参数1接口
  81. int nReversed2, // 预留整形参数2接口
  82. int nReversed3, // 预留整形参数3接口
  83. int nReversed4, // 预留整形参数4接口
  84. int nReversed5, // 预留整形参数5接口
  85. float fReversed1, // 预留float参数1接口
  86. float fReversed2, // 预留float参数2接口
  87. float fReversed3, // 预留float参数3接口
  88. char szReversed1[MAX_RESERVED1], // 预留字符数组参数1接口
  89. char szReversed2[MAX_RESERVED2], // 预留字符数组参数2接口
  90. char szReversed3[MAX_RESERVED3], // 预留字符数组参数3接口
  91. char szReversed4[MAX_RESERVED4], // 预留字符数组参数4接口
  92. char szReversed5[MAX_RESERVED5] // 预留字符数组参数5接口
  93. );
  94. BOOL UpsSECOpenComm(int nCommPort, int nAddr, int nRate, int nDataBit, int nStopBit, int nParity, int nInterval);
  95. protected:
  96. char m_szSEC_ST1Msg[VAR_MSG];//接收到的Buffer的数据;
  97. char m_szSEC_ST2Msg[VAR_MSG];
  98. char m_szSEC_ST3Msg[VAR_MSG];
  99. char m_szSEC_ST4Msg[VAR_MSG];
  100. char m_szSEC_ST5Msg[VAR_MSG];
  101. char m_szSEC_NOMMsg[VAR_MSG];
  102. char m_szSEC_ATRMsg[VAR_MSG];
  103. protected:
  104. int RequestReadStatus(CCommProcess *pComm,
  105. char szSendMsg[SEC_SEND_MSG]);
  106. int ResponseReadStatus(
  107. CCommProcess *pComm,
  108. char szCmd[MAX_CMD],
  109. char szRecvMsg[VAR_MSG],
  110. int &nIndex
  111. );
  112. int RequestWriteStatus( CCommProcess *pComm,char szSendMsg[SEC_SEND_MSG] );
  113. int ResponseWriteStatus( CCommProcess *pComm,char szCmd[MAX_CMD], char szRecvMsg[SEC_SEND_MSG],int &nIndex );
  114. int GetSECFromIni(
  115. char szPath[MAX_PATH], //服务器程序所在目录
  116. char szIniName[MAX_PATH], //配置文件名
  117. char szCmd[MAX_CMD], //命令
  118. char szSendMsg[MAX_CMD], //发送Buffer
  119. int &nIndex
  120. );
  121. int GetSECST1VarMsg(
  122. char szCmd[MAX_CMD], // 命令
  123. char szRecvMsg[VAR_MSG], // 接收Buffer
  124. int &nIndex);
  125. int GetSECST2VarMsg(
  126. char szCmd[MAX_CMD], // 命令
  127. char szRecvMsg[VAR_MSG], // 接收Buffer
  128. int &nIndex);
  129. int GetSECST3VarMsg(
  130. char szCmd[MAX_CMD], // 命令
  131. char szRecvMsg[VAR_MSG], // 接收Buffer
  132. int &nIndex);
  133. int GetSECST4VarMsg(
  134. char szCmd[MAX_CMD], // 命令
  135. char szRecvMsg[VAR_MSG], // 接收Buffer
  136. int &nIndex);
  137. int GetSECST5VarMsg(
  138. char szCmd[MAX_CMD], // 命令
  139. char szRecvMsg[VAR_MSG], // 接收Buffer
  140. int &nIndex);
  141. int GetSECNOMVarMsg(
  142. char szCmd[MAX_CMD], // 命令
  143. char szRecvMsg[VAR_MSG], // 接收Buffer
  144. int &nIndex);
  145. int GetSECATRVarMsg(
  146. char szCmd[MAX_CMD], // 命令
  147. char szRecvMsg[VAR_MSG], // 接收Buffer
  148. int &nIndex );
  149. int GetDeviceParam(
  150. CCommProcess *pComm, //串口对象指针
  151. char szSendMsg[SEC_SEND_MSG], //发送Buffer
  152. char szCmd[MAX_CMD], // 命令
  153. char szRecvMsg[VAR_MSG], // 接收Buffer
  154. int &nIndex);
  155. void SetSECST1VarMsg( char szCmd[MAX_CMD], char *pBuffer);
  156. void SetSECST2VarMsg( char szCmd[MAX_CMD], char *pBuffer);
  157. void SetSECST3VarMsg( char szCmd[MAX_CMD], char *pBuffer);
  158. void SetSECST4VarMsg( char szCmd[MAX_CMD], char *pBuffer);
  159. void SetSECST5VarMsg( char szCmd[MAX_CMD], char *pBuffer);
  160. void SetSECNOMVarMsg( char szCmd[MAX_CMD], char *pBuffer);
  161. void SetSECATRVarMsg( char szCmd[MAX_CMD], char *pBuffer);
  162. void SimulationCommData(void);
  163. private:
  164. HANDLE m_hSemComm;
  165. #if IS_USE_READMSG_CS
  166. CRITICAL_SECTION m_csReadMsg;
  167. #endif
  168. };
  169. #endif // !defined(AFX_SECUPS_H__0C5805B4_8C8C_490B_BB1F_BE48D0AB5E19__INCLUDED_)