Daikin.h 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. #ifndef _AC_DAKIN_HAED
  2. #define _AC_DAKIN_HAED
  3. /*************************************************
  4. /* Copyright (C), 2010-2012,StoneU. Co., Ltd.
  5. /* File name: Daikin.h
  6. /* Author: Zero.t
  7. /* Version: Ver1.0.0.1
  8. /* Date: 2012-10-19
  9. /* Description: 大金空调 社外版 首次使用:肯特;
  10. /* Others: 电信615+独有版485串口只接1个P板时,地址4无效.地址1~3可以任意使用,
  11. 但,必须对应P板上的接线ID;
  12. /* Function List: ###
  13. /* History:
  14. 1.Date: ###
  15. Author: ###
  16. Modification: ###
  17. /* 测试通过,OK;
  18. *************************************************/
  19. #pragma once
  20. #include "CommInterface.h"
  21. class CDaiKin: public CCommInterface
  22. {
  23. #define DEBUG_DAIKIN 1
  24. #define DAIKIN_SEND_MSG 40
  25. #define SEND_INFO 20
  26. #define DK_TYPE_LENGTH 10
  27. #define CID2_LENGTH 3
  28. #define DAIKIN_RECEIVE_MSG 256
  29. enum __ERRO_CODE_
  30. {
  31. ERR_CODE_COM_FAULT = 50201 , //设备串口通信故障;
  32. ERR_CODE_COM_BUSY , //设备串口通信忙;
  33. ERR_CODE_COM_READ_NO_DATA , //设备没有读到数据;
  34. ERR_CODE_COM_READ_LEN_OVER , //设备读到数据长度超时限制;
  35. ERR_CODE_COM_LRC_LOST , //设备lrc校验失败;
  36. EER_CODE_COM_WRITE_DATA , //设备写串口错误;
  37. EER_CODE_COM_REGNUM , //设备寄存器数;
  38. ERR_CODE_COM_VARLEN , //设备变量长度非法;
  39. ERR_CODE_COM_INVALIDRES , //设备无效应答;
  40. ERR_CODE_RTN_CHKSUM
  41. };
  42. enum _ERRO_CODE_RTN
  43. {
  44. ERR_CODE_RTN_NATURAL = 0x00, // 正常;
  45. ERR_CODE_RTN_VER_ERROR, // VER错误;
  46. ERR_CODE_RTN_CHKSUM_ERROR, // CHECKSUM错;
  47. ERR_CODE_RTN_LCHKSUM_ERROR, // LCHECKSUM;
  48. ERR_CODE_RTN_CID_ERROR, // CID2无效;
  49. ERR_CODE_RTN_COMMAND_FORMAT, // 命令格式错;
  50. ERR_CODE_RTN_INVALID_DATA, // 无效数据;
  51. ERR_CODE_RTN_INVALID_LIMIT =0x10, // 无效权限;
  52. ERR_CODE_RTN_OPERATE_FAIL, // 操作失败;
  53. ERR_CODE_RTN_EQUIT_FAIL, // 设备故障;
  54. //ERR_CODE_RTN_KEEP, // 保留;
  55. //ERR_CODE_RTN_WATCH, // 监控;
  56. //ERR_CODE_RTN_ELECTICAL_SOURCE // 电源;
  57. };
  58. public:
  59. BOOL DaiKinOpenComm(int nCommPort, int nAddr, int nRate, int nDataBit, int nStopBit, int nParity, int nInterval);
  60. CDaiKin(char *szPath,char *szIniName,int nCommPort,int nAddr,int nRate,int nDataBit,int nStopBit,int nParity,int nInterval);
  61. virtual ~CDaiKin();
  62. // 发送读取设备参数请求
  63. int SendReadRequest(
  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. // 发送设置设备参数请求
  85. int SendSetReuest(
  86. char *szPath, // 程序所在路径
  87. char *szIniName, // 配置文件名称
  88. int nCommPort, // 串行端口
  89. int nAddr, // 设备地址
  90. char *szCmd, // 请求命令
  91. char *szSetMsg, // 设置的值
  92. int nReversed1, // 预留整形参数1接口
  93. int nReversed2, // 预留整形参数2接口
  94. int nReversed3, // 预留整形参数3接口
  95. int nReversed4, // 预留整形参数4接口
  96. int nReversed5, // 预留整形参数5接口
  97. float fReversed1, // 预留float参数1接口
  98. float fReversed2, // 预留float参数2接口
  99. float fReversed3, // 预留float参数3接口
  100. char *szReversed1, // 预留字符数组参数1接口
  101. char *szReversed2, // 预留字符数组参数2接口
  102. char *szReversed3, // 预留字符数组参数3接口
  103. char *szReversed4, // 预留字符数组参数4接口
  104. char *szReversed5 // 预留字符数组参数5接口
  105. );
  106. private:
  107. int GetIniInfo( char *szPath,char *szIniName,char *szCmd,char *IniSendCMD,int &IniSendlen,char *szDataType,int &nIndex,int &nLen, int &iSBit, int &iEBit);
  108. int GetDeviceParam( int nAddr,CCommProcess *pComm,char *szCmd,char *IniSendCMD, const int &IniSendlen);
  109. int Send_ReadDeviceData(int nAddr,CCommProcess *pComm,char *szCmd, const char *IniSendCMD,const int &IniSendlen);
  110. int Recv_ReadDeviceData(int nAddr,CCommProcess *pComm,char *szCmd);
  111. int SetDeviceParam( int nAddr,CCommProcess *pComm,char *szCmd,char *szSetMsg,char *szRecvMsg,char *IniSendCMD, const int &IniSendlen);
  112. int Send_WriteDeviceData(int naddr, CCommProcess *pComm, char *szCmd, char *szSetMsg, char *IniSendCMD, const int &IniSendlen );
  113. int Recv_WriteDeviceData(int nAddr, CCommProcess *pComm, char *szCmd, char *szRecvMsg );
  114. int GetDaiKin_400VarMsg( int nAddr,char *szCmd,char *szMsg,int &nIndex,int &nLen,char *szType,int startBit,int endBit );
  115. WORD RtnCheck(char Msg[VAR_MSG]);
  116. void lowcase2uppcase(BYTE &btSrc);
  117. void SimulationCommData(int nAddr);
  118. void BitDataProcess(const BYTE &bySour, char *szRecv, int &StaBit, int &EndBit);
  119. void GetCheckSum(char *pBuf, char chDest[5], int len);
  120. protected:
  121. private:
  122. HANDLE m_hSemComm;
  123. #if IS_USE_READMSG_CS
  124. CRITICAL_SECTION m_csReadMsg;
  125. #endif
  126. char m_szDaKin_400Msg[MAX_ADDR][DAIKIN_RECEIVE_MSG];
  127. BOOL m_dwOnlineTick[MAX_ADDR];
  128. BOOL m_devOnline[MAX_ADDR];
  129. };
  130. #endif