DIOS.Dev.Generator.Delta_80KAXB.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285
  1. #pragma once
  2. #include "IODeviceWithSCF.tlh"
  3. #include "IODeviceWithSCF.tli"
  4. #include "CCOS.Dev.IODevice.Detail.hpp"
  5. #include "CCOS.Dev.MSGMould.hpp"
  6. #include "CCOS.Dev.Generator.Mould.hpp"
  7. #include "DAP.BasicMoulds.hpp"
  8. #include "DeliverModule.h"
  9. #include "LogicClient.h"
  10. #ifdef CCOSDEVGENDelta_EXPORTS
  11. #define _CCOSDEVGENDelta_API __declspec(dllexport)
  12. #else
  13. #define _CCOSDEVGENDelta_API __declspec(dllimport)
  14. #endif
  15. enum DELTA_ABNORMAL_LEVEL { //故障等级
  16. REG_ERRO,
  17. REG_WARN
  18. };
  19. enum TransToType
  20. {
  21. tochar = 0,
  22. toint,
  23. tohex
  24. };
  25. struct AECINFORM
  26. {
  27. int Chamber;
  28. int Field;
  29. int Density;
  30. int FilmScreenSpeed;
  31. };
  32. namespace nsSerialGPM = CCOS::Dev::MODLE::SerialGPM;
  33. static const int TIMEOUTVALUE = 100;
  34. static int m_nCountTimes = 0;
  35. // 定义常量数组长度
  36. // 静态缓冲区用于存储不完整指令
  37. static char buffer[1024];
  38. static int bufferLength = 0;
  39. // 记录可能的指令片段状态
  40. static std::queue<uint8_t> partialCommandQueue;
  41. // 记录当前处理位置
  42. static int currentIndex = 0;
  43. //-----------------------------------------------------------------------------
  44. // DeltaDevice
  45. //-----------------------------------------------------------------------------
  46. namespace CCOS::Dev::Detail::Generator
  47. {
  48. namespace nDev = CCOS::Dev;
  49. namespace DevDAP = CCOS::Dev::Detail::DAP;
  50. class _CCOSDEVGENDelta_API DeltaDevice : public IODeviceWithSCF <IODeviceDetail>,public GeneratorMould
  51. {
  52. using super = IODeviceWithSCF <IODeviceDetail>;
  53. using superGen = GeneratorMould;
  54. public:
  55. DeltaDevice(std::shared_ptr <IOEventCenter> center, nsSCF::SCF SCF,string configfile);
  56. ~DeltaDevice ();
  57. bool DecodeFrame(const char* strPackage, int nLength);
  58. void ProcessCommand(const char* strPackage, int Index, int End);
  59. virtual std::string GetGUID() const override;
  60. virtual RET_STATUS IncKV() override;
  61. virtual RET_STATUS DecKV() override;
  62. virtual RET_STATUS SetKV(float value) override;
  63. virtual RET_STATUS IncMA() override;
  64. virtual RET_STATUS DecMA() override;
  65. virtual RET_STATUS SetMA(float value) override;
  66. virtual RET_STATUS IncMS() override;
  67. virtual RET_STATUS DecMS() override;
  68. virtual RET_STATUS SetMS(float value) override;
  69. virtual RET_STATUS IncMAS() override;
  70. virtual RET_STATUS DecMAS() override;
  71. virtual RET_STATUS SetMAS(float value) override;
  72. virtual RET_STATUS SetTechmode(int value) override;
  73. virtual RET_STATUS SetFocus(int value) override;
  74. virtual RET_STATUS SetAECDensity(int value) override;
  75. virtual RET_STATUS SetAECField(int value) override;
  76. virtual RET_STATUS SetAECFilm(int value) override;
  77. virtual RET_STATUS SetWS(const std::string value) override;
  78. virtual RET_STATUS SetAPR(const _tAPRArgs& t) override;
  79. virtual RET_STATUS QueryHE(int& value) override;
  80. virtual RET_STATUS QueryPostKV(float& value) override;
  81. virtual RET_STATUS QueryPostMA(float& value) override;
  82. virtual RET_STATUS QueryPostMS(float& value) override;
  83. virtual RET_STATUS QueryPostMAS(float& value) override;
  84. virtual RET_STATUS SetGenSynState(int value) override;
  85. virtual RET_STATUS SetGenState(int value) override;
  86. virtual RET_STATUS SetExpEnable() override;
  87. virtual RET_STATUS SetExpDisable()override;
  88. virtual RET_STATUS Reset()override;
  89. virtual RET_STATUS SetExpMode(std::string value) override;
  90. virtual RET_STATUS SetFrameRate(FLOAT frameRate) override;
  91. virtual RET_STATUS SetFLFMode(std::string value) override;
  92. virtual RET_STATUS SetEXAMMode(std::string value) override;
  93. virtual RET_STATUS ActiveSyncMode(_tSyncModeArgs value) override;
  94. static DeltaDevice* g_GenDevice;
  95. //串口处理层
  96. static nsSerialGPM::CDeliverModule m_tDelivermodule;
  97. int m_nCMDType_ACK{ 0 };
  98. int m_nCMDType_WaitTime{ 0 };
  99. int m_nCMDType_WaitACK{ 0 };
  100. int m_nCMDType_WaitSELF{ 0 };
  101. static void __stdcall ProcessClientData(const char* pData, unsigned long DataLength, void* lparam);
  102. static void __stdcall WriteLog(const char* pData, nsSerialGPM::LOG_V2_LEVEL level);
  103. //RET_STATUS HWSendACKCMD(string strCommand, int headLengh = 1);
  104. //RET_STATUS HWSendWaittimeCMD(string strCommand, int headLengh = 1);
  105. RET_STATUS HWSendWaitACKCMD(string strCommand, int headLengh = 1);
  106. bool LoadConfig(string configfile);
  107. int GetGenState();
  108. private:
  109. void Register();
  110. RET_STATUS RefreshData();
  111. RET_STATUS HWSend(const char * strCommand, int lengh, int nTimeOut = TIMEOUTVALUE);
  112. void FireNotify(std::string key, std::string context);
  113. void FireErrorMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报错误消息
  114. void FireWarnMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报告警消息
  115. bool GetConfData();
  116. _tSyncModeArgs m_cfgCurrentWSSYN; //当前选中的工作位和对应的同步模式
  117. _tAPRArgs m_tAPRdata; //保存服务传入的参数
  118. ResDataObject m_GenConfig; //driver's config file
  119. std::unique_ptr<DevDAP::DOSEMould> m_DAP; //DAP值
  120. std::unique_ptr<nsDetail::MSGUnit> m_MSGUnit; //错误消息处理对象
  121. string m_ErrorCode; //错误码,防止重复发送
  122. bool m_ExpPreFlagStatus{ false }; //发生器返回的是否允许prepare
  123. bool m_XRayOnFlagStatus{ false }; //发生器返回的X-RAY ON
  124. bool m_SysLimitFlagStatus{ false }; //发生器返回的SYSTEM LIMITS
  125. bool m_InterlockFlagStatus{ false }; //发生器返回的INTERLOCK
  126. bool m_TubeFlagStatus{ false }; //发生器返回的TUBE
  127. bool m_KVHoldFlagStatus{ false }; //发生器返回的KV HOLD
  128. bool m_ServiceFlagStatus{ false }; //发生器返回的SERVICE
  129. bool m_FluLevelFlagStatus{ false }; //发生器返回的FLUORO LEVEL
  130. bool m_ExamProFlagStatus{ false }; //发生器返回的EXAM PROCESS COMPLETED
  131. bool m_ExamSwitchFlagStatus{ false }; //发生器返回的EXPOSURE SWITCH PRESSED
  132. bool m_XRDisableFlagStatus{ false }; //发生器返回的XR DISABLE
  133. bool m_ABSFlagStatus{ false }; //发生器返回的FLUORO LOCK
  134. bool m_AECFlagStatus{ false }; //发生器返回的RAD LOCK
  135. //lsy
  136. bool ChangeGenParam(int kv, float fma, float fms, float fmas);
  137. bool SetRADKV_MA_MS(int kv, float ma, float ms);
  138. bool SetRADKV_MAS(int kv, float mas);
  139. bool SetAECKV_MA_MS(int kv, float ma, float ms);
  140. int FormatCommand(char* buf, int len);
  141. //int GetFacValue(vector<int> Index, int& value);
  142. int GetFacFloatValue(vector<float> Index, float& value);
  143. string m_strCommand;
  144. string uint8ArrayToHexStr(const UINT8* array, size_t length);
  145. string m_strKV;
  146. vector<int> m_vecKV;
  147. string m_strMAS;
  148. vector<float> m_vecMAS;
  149. string m_strMA;
  150. vector<float> m_vecMA;
  151. string m_strMS;
  152. vector<float> m_vecMS;
  153. int m_nTubeMaSFMaxValue{ 160 };
  154. int m_nTubeMaBFMinValue{ 180 };
  155. bool m_nTableUsePanelAEC{ false };
  156. bool m_nWallUsePanelAEC{ false };
  157. bool m_nFreeUsePanelAEC{ false };
  158. bool m_nTableUsePanelDDR{ false };
  159. bool m_nWallUsePanelDDR{ false };
  160. bool m_nFreeUsePanelDDR{ false };
  161. bool m_bSendXwindowToDector{ false };
  162. bool SetAECInformation(int chamber, int field, int density, int film);
  163. bool SetRadMode(int radmode, int desmode);
  164. bool SetDAECEnable(int enable);//打开关闭DAEC功能
  165. int m_nChamberIndex{ 1 };
  166. int WSGen2UI(int InputWS);
  167. int m_nAecFiled{2};
  168. int m_nAecDensity{0};
  169. int m_nAecFilm{ 0 };
  170. bool SetDualEnergyCommand(const _tAPRArgs& t);
  171. bool m_bIsDualExp{ false };
  172. int m_nExposureNumber{ 0 };
  173. bool SetAPRForDual(int nWS, int nFO, int nET, int nAECFieldSel, int nAECFilmSel, float fAECDensity, float fKV, float fMA, float fMS, float fMAS);
  174. bool GetLastExpParamenters(void);
  175. std::unordered_map<std::string, std::string> m_ErrorMessages;
  176. std::unordered_map<std::string, std::string> m_WarnMessages;
  177. void RetrieveFirewareVersion();
  178. string AnalysisCommand(int number, const char* chdigital, int type);
  179. LogicClient* m_pDetectorClient;
  180. int m_nDEFrameRate{ 1 };
  181. int m_nCurErrLevel{ 2 };
  182. bool m_bXronMsg{ false };
  183. std::string GetFileVersion(std::string strFilePathName);
  184. std::string GetDynamicLibraryPath();
  185. void SetNoDrMode();
  186. void SetSyncOutMode();
  187. void SeleckDetectorNumber(int detectorID);
  188. //轮询处理
  189. static atomic<int> m_iLoopTime; //循环间隔时间(毫秒)
  190. HANDLE m_hArrayEvent[4];
  191. HANDLE m_hExitEvent{ NULL };
  192. HANDLE m_hHUstatus{ NULL };
  193. HANDLE m_hGENstatus{ NULL };
  194. HANDLE m_hLoopEvent{ NULL };
  195. bool StartHardwareStatusThread();
  196. static DWORD HardwareStatusThread(LPVOID pParam);
  197. HANDLE m_pHardwareStatusThread{ NULL };
  198. void RetrieveHU();
  199. void CheckGeneratorStatus();
  200. bool m_nProcessXrayon{ false };
  201. void RetrieveMaxRating();
  202. int m_nMaxKW{ 0 };
  203. //AEC相关
  204. void UpdataAECInformation(AECINFORM aec);//通过发生器返回的参数更新AEC数据
  205. AECINFORM m_AECinformation;
  206. void RetrieveGeneratroDerating();
  207. string m_strConfigPath{ "" };
  208. //断线重连
  209. bool m_bReconnect{ false };
  210. bool m_bSetAPR{ false };
  211. vector<vector<uint8_t>> parse_packets(const vector<uint8_t>& data);
  212. bool m_bLoadConfigFile{ false };
  213. };
  214. }
  215. //-----------------------------------------------------------------------------
  216. // DeltaDriver
  217. //-----------------------------------------------------------------------------
  218. namespace CCOS::Dev::Detail::Generator
  219. {
  220. class _CCOSDEVGENDelta_API DeltaDriver : public IODriverWithSCF <DriverMould>
  221. {
  222. using super = IODriverWithSCF <DriverMould>;
  223. public:
  224. DeltaDriver ();
  225. virtual ~DeltaDriver ();
  226. public:
  227. //virtual bool DriverEntry (std::string CfgFileName); //设置配制文件路径,对外接口最先调用
  228. virtual void Prepare() override; //在 DriverEntry 之后执行;选择与物理设备通信方式(串口、TCP)
  229. virtual std::string DriverProbe() override; //在 Prepare 之后执行;读取配置文件模块参数,供上层创建驱动work路径
  230. virtual bool DATA_ACTION Connect() override; //在 DriverProbe 之后执行;根据通信方式与物理设备进行连接
  231. virtual auto CreateDevice(int index)->std::unique_ptr <IODevice> override; //在 Connect 之后执行;创建逻辑设备,供上层创建驱动树节点
  232. virtual bool isConnected() const override; //检查驱动与物理设备连接状态
  233. virtual std::string GetResource() override; //获取配置文件的值
  234. virtual std::string DeviceProbe() override; //读取配置文件模块参数,供上层创建设备work路径
  235. virtual void Disconnect() override; //断开驱动与物理设备连接状态
  236. virtual void Dequeue(const char* Packet, DWORD Length) override; //在super::Connect中轮询,调用 DecodeFrame:查找指令操作对照表,通过对应操作更新数据并调用FireNotify上报更新
  237. virtual void FireNotify(int code, std::string key, std::string content) override; //向监听者上报事件
  238. static PACKET_RET callbackPackageProcess(const char* RecData, DWORD nLength, DWORD& PacketLength); //判断从设备读到的数据有没有可用的数据包,有则最终调度到 Dequeue
  239. private:
  240. bool SaveConfigFile(bool bSendNotify);
  241. virtual bool GetDeviceConfig(std::string& Cfg) override;
  242. virtual bool SetDeviceConfig(std::string Cfg) override;
  243. bool GetDeviceConfigValue(ResDataObject config, const char* pInnerKey, int nPathID, string& strValue);
  244. bool SetDeviceConfigValue(ResDataObject& config, const char* pInnerKey, int nPathID, const char* szValue);
  245. ResDataObject m_DeviceConfig;
  246. ResDataObject m_ConfigAll; //存储当前的配置,用于修改配置时写回文件
  247. ResDataObject m_Configurations; //存储当前配置中“CONFIGURATION”节点的内容
  248. bool m_bDemoConnected; // 在 DEMO 模式下, 是否调用过 Connect
  249. //webconfig使用
  250. ResDataObject m_DeviceConfigSend;
  251. string g_strAppPath;
  252. std::unique_ptr <ResDataObject> m_pAttribute;
  253. std::unique_ptr <ResDataObject> m_pDescription;
  254. DeltaDevice* m_pDevice{ nullptr };
  255. };
  256. }