UPSLan.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. /*************************************************
  2. /* Copyright (C), 2010-2013,StoneU. Co., Ltd.
  3. /* File name: UPSLan.h
  4. /* Author: Zero.t
  5. /* Version: Ver1.0.0.1
  6. /* Date: 2013-01-26
  7. /* Description: 冠军 Monitor UPS Lan;本类首次使用在项目[贵州铂安科技\贵阳武警支队];
  8. /* Others: UPS协议类,不做控制设备操作;
  9. /* Function List: ###
  10. /* History:
  11. 1.Date: 2012.10.26
  12. Author: Zero.t
  13. Modification: 简化了部分内容;
  14. /* 测试通过否: OK
  15. *************************************************/
  16. #ifndef RS232MODEL_UPSLAN_H
  17. #define RS232MODEL_UPSLAN_H
  18. #pragma once
  19. #include "CommInterface.h"
  20. class RS232Model_UPSLan:public CCommInterface
  21. {
  22. #define DEBGU_RS232MODEL_UPSLAN 1 // 模拟测试控制开关;
  23. public:
  24. RS232Model_UPSLan(char *szPath,char *szIniName,int nCommPort,int nAddr,int nRate,int nDataBit,int nStopBit,int nParity,int nInterval);
  25. ~RS232Model_UPSLan(void);
  26. BOOL RS232ModelOpenComm(int nCommPort, int nAddr, int nRate, int nDataBit, int nStopBit, int nParity, int nInterval);
  27. // 发送读请求;
  28. int SendReadRequest(
  29. char *szPath, // 程序所在路径
  30. char *szIniName, // 配置文件名称
  31. int nCommPort, // 串行端口
  32. int nAddr, // 设备地址
  33. char *szCmd, // 请求命令
  34. char *szMsg, // 响应的值
  35. int nReversed1, // 预留整形参数1接口
  36. int nReversed2, // 预留整形参数2接口
  37. int nReversed3, // 预留整形参数3接口
  38. int nReversed4, // 预留整形参数4接口
  39. int nReversed5, // 预留整形参数5接口
  40. float fReversed1, // 预留float参数1接口
  41. float fReversed2, // 预留float参数2接口
  42. float fReversed3, // 预留float参数3接口
  43. char *szReversed1, // 预留字符数组参数1接口
  44. char *szReversed2, // 预留字符数组参数2接口
  45. char *szReversed3, // 预留字符数组参数3接口
  46. char *szReversed4, // 预留字符数组参数4接口
  47. char *szReversed5 // 预留字符数组参数5接口
  48. );
  49. // 发送写设置;
  50. int SendSetReuest(
  51. char *szPath, // 程序所在路径
  52. char *szIniName, // 配置文件名称
  53. int nCommPort, // 串行端口
  54. int nAddr, // 设备地址
  55. char *szCmd, // 请求命令
  56. char *szMsg, // 响应的值
  57. int nReversed1, // 预留整形参数1接口
  58. int nReversed2, // 预留整形参数2接口
  59. int nReversed3, // 预留整形参数3接口
  60. int nReversed4, // 预留整形参数4接口
  61. int nReversed5, // 预留整形参数5接口
  62. float fReversed1, // 预留float参数1接口
  63. float fReversed2, // 预留float参数2接口
  64. float fReversed3, // 预留float参数3接口
  65. char *szReversed1, // 预留字符数组参数1接口
  66. char *szReversed2, // 预留字符数组参数2接口
  67. char *szReversed3, // 预留字符数组参数3接口
  68. char *szReversed4, // 预留字符数组参数4接口
  69. char *szReversed5 // 预留字符数组参数5接口
  70. );
  71. protected:
  72. // 读设备;
  73. int GetDeviceParam( CCommProcess *pComm,char *IniSendCMD,const int &nIniSendlen, char *szCmd);
  74. int Send_ReadDeviceData(CCommProcess *pComm,const char *szIniSendCMD,const int &nIniSendlen);
  75. int Recv_ReadDeviceData(CCommProcess *pComm,const char *szIniSendCMD,char *szCmd);
  76. // 写设备;
  77. // nothing..
  78. // 数据处理;
  79. int GetRS232Model_RSMsg(const char *szIniSendCMD,char *szCmd,char *szMsg,int &nIndex,int &nLen,char *szType);
  80. int GetRS232Model_RDMsg(const char *szIniSendCMD,char *szCmd,char *szMsg,int &nIndex,int &nLen,char *szType);
  81. void SetRS232Model_RSMsg( const char *szIniSendCMD,char *szCmd, char *pBuffer);
  82. void SetRS232Model_RDMsg( const char *szIniSendCMD,char *szCmd, char *pBuffer);
  83. void SimulationCommData();
  84. private:
  85. BOOL m_dwOnlineTick;
  86. BOOL m_devOnline;
  87. HANDLE m_hSemComm;
  88. CRITICAL_SECTION m_csReadMsg;
  89. char m_szRS232_RSMsg[MAX_RECE_MSG];
  90. char m_szRS232_RDMsg[MAX_RECE_MSG];
  91. };
  92. #endif