DIOS.Dev.Generator.PSG_RF.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. #pragma once
  2. #include <atomic>
  3. #include "IODeviceWithSCF.tlh"
  4. #include "IODeviceWithSCF.tli"
  5. #include "CCOS.Dev.IODevice.Detail.hpp"
  6. #include "CCOS.Dev.MSGMould.hpp"
  7. #include "CCOS.Dev.Generator.Mould.hpp"
  8. //#include "DAP.BasicMoulds.hpp"
  9. #include "DeliverModule.h"
  10. #include "GENErrorWarningProcess.h"
  11. #ifdef CCOSDEVGENPSGRF_EXPORTS
  12. #define _CCOSDEVGENPSGRF_API __declspec(dllexport)
  13. #else
  14. #define _CCOSDEVGENPSGRF_API __declspec(dllimport)
  15. #endif
  16. enum PSG_RF_REGULATION_LEVEL { //故障等级
  17. REG_ERRO,
  18. REG_WARN
  19. };
  20. enum PSG_RF_CHARGE_STATE { //电池状态
  21. POWER_LOW,
  22. POWER_NOR
  23. };
  24. #define PSGRF_Com_ReSendLen 32
  25. namespace nsSerialGPM = CCOS::Dev::MODLE::SerialGPM;
  26. namespace CCOS::Dev::Detail::Generator
  27. {
  28. using cbFun = std::function <void(char*, int)>;
  29. static const int TIMEOUTVALUE = 100;
  30. //-----------------------------------------------------------------------------
  31. // PSGRFDevice
  32. //-----------------------------------------------------------------------------
  33. class _CCOSDEVGENPSGRF_API PSGRFDevice : public IODeviceWithSCF <IODeviceDetail>,public GeneratorMould
  34. {
  35. using super = IODeviceWithSCF <IODeviceDetail>;
  36. using superGen = GeneratorMould;
  37. public:
  38. PSGRFDevice (std::shared_ptr <IOEventCenter> center, nsSCF::SCF SCF, string configfile);
  39. ~PSGRFDevice ();
  40. //发生器支持的通用命令
  41. virtual std::string GetGUID() const override;
  42. virtual RET_STATUS IncKV() override;
  43. virtual RET_STATUS DecKV() override;
  44. virtual RET_STATUS SetKV(float value) override;
  45. virtual RET_STATUS IncMA() override;
  46. virtual RET_STATUS DecMA() override;
  47. virtual RET_STATUS SetMA(float value) override;
  48. virtual RET_STATUS IncMS() override;
  49. virtual RET_STATUS DecMS() override;
  50. virtual RET_STATUS SetMS(float value) override;
  51. virtual RET_STATUS IncMAS() override;
  52. virtual RET_STATUS DecMAS() override;
  53. virtual RET_STATUS SetMAS(float value) override;
  54. virtual RET_STATUS SetTechmode(int value) override;
  55. virtual RET_STATUS SetEXAMMode(std::string value) override;
  56. virtual RET_STATUS SetFocus(int value) override;
  57. virtual RET_STATUS SetAPR(const _tAPRArgs& t) override;
  58. virtual RET_STATUS QueryHE(int& value) override;
  59. virtual RET_STATUS QueryPostKV(float& value) override;
  60. virtual RET_STATUS QueryPostMA(float& value) override;
  61. virtual RET_STATUS QueryPostMS(float& value) override;
  62. virtual RET_STATUS QueryPostMAS(float& value) override;
  63. virtual RET_STATUS SetExpEnable() override;
  64. virtual RET_STATUS SetExpDisable()override;
  65. virtual RET_STATUS Reset()override;
  66. virtual RET_STATUS ActiveSyncMode(_tSyncModeArgs value) override;
  67. RET_STATUS RefreshData();
  68. RET_STATUS SetRPS(int rps);//设置连续点片帧率,暂不使用
  69. std::string GetDynamicLibraryPath();
  70. /********************透视命令****************************/
  71. virtual RET_STATUS SetAPF(const _tAPFArgs& t) override;
  72. virtual RET_STATUS IncFluKV() override;
  73. virtual RET_STATUS DecFluKV() override;
  74. virtual RET_STATUS SetFluKV(float value) override;
  75. virtual RET_STATUS IncFluMA() override;
  76. virtual RET_STATUS DecFluMA() override;
  77. virtual RET_STATUS SetFluMA(float value) override;
  78. virtual RET_STATUS INCPPS() override;
  79. virtual RET_STATUS DECPPS() override;
  80. virtual RET_STATUS SetPPS(float value) override;
  81. virtual RET_STATUS SetABSMode(int nMode) override;
  82. virtual RET_STATUS SetABSCurve(int curveNum) override;
  83. virtual RET_STATUS IncABSCurve() override;
  84. virtual RET_STATUS DecABSCurve() override;
  85. virtual RET_STATUS GetABSCurve();
  86. virtual float GetFluIntTimer() override;
  87. virtual float GetFluAccTimer() override;
  88. virtual RET_STATUS ResetFluTimer(int ntype) override;
  89. virtual RET_STATUS SetFluPre(int value) override;
  90. virtual RET_STATUS SetFluEXP(int value) override;
  91. virtual RET_STATUS SetFluMode(std::string value);
  92. virtual RET_STATUS SetFluDoseLever(int value) override;
  93. virtual RET_STATUS SetPluseWidth(float fplusewidth) override;
  94. virtual RET_STATUS SetAECDensity(int value) override;
  95. virtual RET_STATUS SetAECField(int value) override;
  96. virtual RET_STATUS SetAECFilm(int value) override;
  97. virtual RET_STATUS SetWS(const std::string value) override;
  98. virtual RET_STATUS SetGenSynState(int value) override;
  99. virtual RET_STATUS SetGenState(int value) override;
  100. virtual RET_STATUS SetExpMode(std::string value) override;
  101. virtual RET_STATUS SetFrameRate(FLOAT frameRate) override;
  102. virtual RET_STATUS SetFLFMode(std::string value) override;
  103. virtual RET_STATUS SetFLLever(FLOAT value);
  104. virtual RET_STATUS SimulateError(std::string Error)override;
  105. bool EnableBucky(int nbucky);
  106. bool ECHO(void);
  107. bool SetABSModeNative(int nMode);
  108. bool SetFKM(float fKV, float fMA);
  109. RET_STATUS Clear_DAP();
  110. RET_STATUS GetValue_DAP(float& value);
  111. RET_STATUS StartMove();
  112. RET_STATUS EndMove();
  113. int GetGenState();
  114. int LoadConfig(string configfile);
  115. //V3新方法
  116. virtual void SubscribeSelf(ccos_mqtt_connection* conn) override;
  117. RET_STATUS SetVibrationGrid(int value);
  118. RET_STATUS GetVibrationGridMS(int &value);
  119. void SetSmartAEC(int value); //智能AEC
  120. void ReqExpandedHSSStatus(); //请求转子转速
  121. bool ReConnect(); //重连
  122. int GridMSMargin(); //返回震动栅MS的余量
  123. bool CalculateAppropriateMA(float& inoutMAS, float& inoutMA, float& inoutMS); //计算震动栅模式下恰当的MA
  124. void ReSendFailedAction(string &cmdNum); //重发失败后返回消息
  125. void UpdateLimits(const std::string& key, float& currentValue, float defaultValue);
  126. void UpdateLimitsInt(const std::string& key, int& currentValue, int defaultValue);
  127. public:
  128. std::unique_ptr <DeviceErrorHandler> m_DeviceErrorHandler;
  129. ResDataObject m_GenConfig; //driver's config file.
  130. std::mutex sendMutex; // 互斥锁
  131. //线程变量互斥锁
  132. //atomic<int> m_iReSendCMD; //初始命令重发次数
  133. static atomic<int> m_iLoopTime; //循环间隔时间(毫秒)
  134. atomic<int> m_iCompPostMAS; //计算PostMAS条件统计
  135. atomic<int> m_iHeartBeats; //心跳统计
  136. atomic<bool> m_bConnectFlag; //连接标记
  137. bool m_bAECCtlSignal; //在曝光设置更新期间,AEC控制信号必须处于低状态
  138. atomic<bool> m_iVibrationGridState; //震动栅模式(0,1)
  139. int m_iGridMSRadMargin; //震动栅ms手动曝光误差(500-2000ms)
  140. int m_iGridMSAECMargin; //震动栅ms自动曝光误差(500-2000ms)
  141. static atomic<bool> m_bExtraFlag; //使用标记
  142. bool m_bExpEnable; //曝光使能
  143. bool m_bGenBusy;
  144. bool m_bReturnFlag;
  145. float m_fPreMA;
  146. float m_fPreMS;
  147. float m_fPreMAS;
  148. int m_nPreET;
  149. int m_nAECMode;//0 fix 1 mas 2 ms
  150. bool m_bSaveMSMA;//根据用途来看,其实是表示 是否处于setapr期间
  151. float m_PrefMS;
  152. float m_fMsLimit;
  153. bool m_bInExpState; //用来表示是否处于曝光状态,因为处于exp状态时,仅有几组指令可以发。
  154. int m_nCtlMode;
  155. bool m_bCheckATUStatus;//
  156. bool m_bDAPEnable;
  157. bool m_bUseCECmd;
  158. bool m_bIsConfigLoaded;
  159. float m_fPFLimitMaxMA;
  160. float m_fPFLimitMaxKV;
  161. float m_fPFLimitMinMA;
  162. float m_fPFLimitMinKV;
  163. float m_fHLFLimitMaxMA;
  164. float m_fHLFLimitMaxKV;
  165. float m_fHLFLimitMinMA;
  166. float m_fHLFLimitMinKV;
  167. int m_nReturnTime;
  168. vector<string> m_localWarnlist;
  169. int m_bLargeFocusEnable;
  170. //串口处理层
  171. static nsSerialGPM::CDeliverModule m_tDelivermodule;
  172. int m_nCMDType_WaitTime{ 0 };
  173. int m_nCMDType_HB{ 0 };
  174. int m_nCMDType_WaitACK{ 0 };
  175. static void __stdcall ProcessClientData(const char* pData, unsigned long DataLength, void* lparam);
  176. static void __stdcall WriteLog(const char* pData, nsSerialGPM::LOG_V2_LEVEL level);
  177. RET_STATUS HWSendWaittimeCMD(char* strCommand, int lengh, int headLengh = 3);
  178. RET_STATUS HWSendHBCMD(char* strCommand, int lengh, int headLengh = 3);
  179. RET_STATUS HWSendWaitACKCMD(char* strCommand, int lengh, int headLengh = 3);
  180. private:
  181. //std::unique_ptr<DevDAP::DOSEMould> m_DAP; //暂不使用
  182. std::unique_ptr<nsDetail::MSGUnit> m_MSGUnit; //处理消息上报对象指针
  183. HANDLE m_pHardwareStatusThread; //轮询线程句柄
  184. HANDLE m_pTrueParameterThread;
  185. HANDLE m_pHardwareRsSendThread; //重发线程句柄
  186. HANDLE m_hGenPostEvent;
  187. atomic<bool> m_bInvalidKVMASSetupFlag; //写入到设备的曝光设置无效
  188. atomic<bool> m_bFaultList[18]; //记录 主机请求固件报告故障命令 返回的故障记录
  189. atomic<bool> m_bCMD68Flag; //防止 命令31之后主机请求68命令返回真,再查一次68返回又为假
  190. int m_iMaxPower; //最大功率:kV*mA
  191. int MaxHeatContent; //最阳极热容积:kV*mAs
  192. bool m_bMAS_MA_AEC;
  193. enum MyEnum
  194. {
  195. EXPOSURE_SOFTWARE_HARDWARE, //0
  196. EXPOSURE_NOSYNBOX_DIRCETCONNECT_DETECTOR_GEN, //1
  197. EXPOSURE_SOFTWARE_NOSYNBOX //2
  198. };
  199. private:
  200. RET_STATUS HWSend(const char* strCommand, int lengh, bool reSend = false, int nTimeOut = TIMEOUTVALUE); //指令发送接口
  201. void OnCallBack(); //处理指令回调函数
  202. void Register(); //注册对外提供的属性、方法
  203. bool StartHardwareStatusThread(); //启动轮询线程
  204. bool StartTrueParameterThread(); //启动轮询线程
  205. static DWORD HardwareStatusThread(LPVOID pParam); //定时查询状态信息
  206. static DWORD TrueParameterThread(LPVOID pParam); //定时查询状态信息
  207. static DWORD HardwareReSendThread(LPVOID pParam); //指令重发
  208. void FireNotify(std::string key, int context);//向上层上报消息
  209. void FireNotify(std::string key, float context);
  210. void FireNotify(std::string key, std::string context);
  211. void FireErrorMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报错误消息
  212. void FireWarnMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报告警消息
  213. };
  214. }
  215. //-----------------------------------------------------------------------------
  216. // PSGRFDriver
  217. //-----------------------------------------------------------------------------
  218. namespace CCOS::Dev::Detail::Generator
  219. {
  220. class _CCOSDEVGENPSGRF_API PSGRFDriver : public IODriverWithSCF <DriverMould>
  221. {
  222. using super = IODriverWithSCF <DriverMould>;
  223. public:
  224. PSGRFDriver ();
  225. virtual ~PSGRFDriver ();
  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. bool ReConnection(nsSCF::SCF& DevSCF);
  231. virtual bool DATA_ACTION Connect () override; //在 DriverProbe 之后执行;根据通信方式与物理设备进行连接
  232. virtual auto CreateDevice(int index)->std::unique_ptr <IODevice> override; //在 Connect 之后执行;创建逻辑设备,供上层创建驱动树节点
  233. virtual bool isConnected() const override; //检查驱动与物理设备连接状态
  234. virtual std::string GetResource() override; //获取配置文件的值
  235. virtual std::string DeviceProbe() override; //读取配置文件模块参数,供上层创建设备work路径
  236. virtual void Disconnect() override; //断开驱动与物理设备连接状态
  237. virtual void Dequeue (const char * Packet, DWORD Length) override; //在super::Connect中轮询,调用 DecodeFrame:查找指令操作对照表,通过对应操作更新数据并调用FireNotify上报更新
  238. virtual void FireNotify (int code, std::string key, std::string content) override; //向监听者上报事件
  239. static PACKET_RET callbackPackageProcess(const char* RecData, DWORD nLength, DWORD& PacketLength); //判断从设备读到的数据有没有可用的数据包,有则最终调度到 Dequeue
  240. private:
  241. bool SaveConfigFile(bool bSendNotify);
  242. virtual bool GetDeviceConfig(std::string& Cfg) override;
  243. virtual bool SetDeviceConfig(std::string Cfg) override;
  244. bool GetDeviceConfigValue(ResDataObject config, const char* pInnerKey, int nPathID, string& strValue);
  245. bool SetDeviceConfigValue(ResDataObject& config, const char* pInnerKey, int nPathID, const char* szValue);
  246. ResDataObject m_DeviceConfig;
  247. ResDataObject m_ConfigAll; //存储当前的配置,用于修改配置时写回文件
  248. ResDataObject m_Configurations; //存储当前配置中“CONFIGURATION”节点的内容
  249. static bool m_bHasValidConnection;
  250. //webconfig使用
  251. ResDataObject m_DeviceConfigSend;
  252. string g_strAppPath;
  253. std::unique_ptr <ResDataObject> m_pAttribute;
  254. std::unique_ptr <ResDataObject> m_pDescription;
  255. PSGRFDevice* m_pDevice{ nullptr };
  256. };
  257. }