DIOS.Dev.Generator.SimensRF80.h 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. #pragma once
  2. #include "IODeviceWithSCF.tlh"
  3. #include "IODeviceWithSCF.tli"
  4. #include "CCOS.Dev.Generator.Mould.hpp"
  5. #include "CCOS.Dev.MSGMould.hpp"
  6. #include "Define_Simens_RF80.h"
  7. #include "DeliverModule.h"
  8. #define Ccos_V3 1
  9. #if Ccos_V3
  10. #include "LogicClient.h"
  11. #endif // Ccos_V3
  12. #ifdef CCOSDEVGENSDC_EXPORTS
  13. #define _CCOSDEVGENSDC_API __declspec(dllexport)
  14. #else
  15. #define _CCOSDEVGENSDC_API __declspec(dllimport)
  16. #endif
  17. namespace nsSerialGPM = CCOS::Dev::MODLE::SerialGPM;
  18. //-----------------------------------------------------------------------------
  19. // GenDevice
  20. //-----------------------------------------------------------------------------
  21. namespace CCOS::Dev::Detail::Generator
  22. {
  23. //指令函数对照表
  24. typedef map<cfgWorkStationKey, cfgWorkStationData> WSMap;
  25. using cbFun = std::function <void(vector <string>& paramList)>;
  26. struct tFrameMapItem
  27. {
  28. cbFun m_fFun; //处理函数
  29. tFrameMapItem();
  30. tFrameMapItem(cbFun f);
  31. tFrameMapItem& operator =(const tFrameMapItem& value);
  32. };
  33. //最后一次设置模式
  34. enum RF80_TechMode {
  35. RF80Tech_RAD,//点片
  36. RF80Tech_FLU,//透视
  37. RF80Tech_FLU_MAX
  38. };
  39. //最后一次设置参数
  40. struct tLastParamItem
  41. {
  42. string strCMDID;
  43. char strParamCMD[GEN_CF80_SEND_LEN_max]{ 0 }; //最后一次参数
  44. tLastParamItem(){}
  45. tLastParamItem(const string CMDid, const char* data)
  46. {
  47. strCMDID = CMDid;
  48. strncpy(strParamCMD, data, GEN_CF80_SEND_LEN_max-1);
  49. }
  50. void SetData(string CMDid, const char* data)
  51. {
  52. strCMDID = CMDid;
  53. strncpy(strParamCMD, data, GEN_CF80_SEND_LEN_max - 1);
  54. }
  55. };
  56. namespace nDev = CCOS::Dev;
  57. class _CCOSDEVGENSDC_API RF80Device : public IODeviceWithSCF <IODeviceDetail>,public GeneratorMould
  58. {
  59. using super = IODeviceWithSCF <IODeviceDetail>;
  60. using superGen = GeneratorMould;
  61. public:
  62. RF80Device(std::shared_ptr <IOEventCenter> center, nsSCF::SCF SCF,std::string configPath);
  63. ~RF80Device ();
  64. //设备方法
  65. virtual std::string GetGUID() const override;//提供GUID
  66. virtual RET_STATUS SetGenState(int value) override;//设置发生器设备状态
  67. virtual RET_STATUS SetGenSynState(int value) override;//设置发生器曝光状态
  68. virtual RET_STATUS Reset()override; //重置发生器错误
  69. virtual RET_STATUS SetWS(const std::string value) override;//设置工作位
  70. virtual RET_STATUS SetExpEnable() override;//曝光使能
  71. virtual RET_STATUS SetExpDisable()override;
  72. virtual RET_STATUS ActiveSyncMode(_tSyncModeArgs value) override;
  73. RET_STATUS Clear_DAP();
  74. RET_STATUS GetValue_DAP(float& value);
  75. //点片
  76. virtual RET_STATUS IncKV() override;//点片KV调节
  77. virtual RET_STATUS DecKV() override;
  78. virtual RET_STATUS SetKV(float value) override;
  79. virtual RET_STATUS IncMA() override;//点片MA调节
  80. virtual RET_STATUS DecMA() override;
  81. virtual RET_STATUS SetMA(float value) override;
  82. virtual RET_STATUS IncMS() override;//点片MS调节
  83. virtual RET_STATUS DecMS() override;
  84. virtual RET_STATUS SetMS(float value) override;
  85. virtual RET_STATUS IncMAS() override;//点片MAS调节
  86. virtual RET_STATUS DecMAS() override;
  87. virtual RET_STATUS SetMAS(float value) override;
  88. virtual RET_STATUS SetFocus(int value) override;//设置焦点
  89. virtual RET_STATUS SetTechmode(int value) override;//设置技术模式:1point,2point,3point
  90. virtual RET_STATUS SetAECDensity(int value) override;//设置AEC浓度
  91. virtual RET_STATUS SetAECField(int value) override;//设置AEC取样区域
  92. virtual RET_STATUS SetAECFilm(int value) override;//设置AEC胶片
  93. virtual RET_STATUS SetAPR(const _tAPRArgs& t) override;//设置点片参数
  94. virtual RET_STATUS SetAPRArray(vector<_tAPRArgs>& APRarray) override;//一次性设置序列点片参数
  95. virtual RET_STATUS SetFrameRate(FLOAT frameRate) override;//设置序列点片帧率
  96. virtual RET_STATUS QueryHE(int& value) override;//查询设备温度
  97. virtual RET_STATUS QueryPostKV(float& value) override;//查询曝光后的真实参数
  98. virtual RET_STATUS QueryPostMA(float& value) override;
  99. virtual RET_STATUS QueryPostMS(float& value) override;
  100. virtual RET_STATUS QueryPostMAS(float& value) override;
  101. virtual RET_STATUS SetExpMode(std::string value) override;//设置曝光模式:单帧、序列、双能
  102. virtual RET_STATUS SetEXAMMode(std::string value) override;//设置检测模式:手动、自动
  103. //透视
  104. virtual RET_STATUS IncFluKV() override; //透视KV调节
  105. virtual RET_STATUS DecFluKV() override;
  106. virtual RET_STATUS SetFluKV(float value) override;
  107. virtual RET_STATUS IncFluMA() override; //透视MA调节
  108. virtual RET_STATUS DecFluMA() override;
  109. virtual RET_STATUS SetFluMA(float value) override;
  110. virtual RET_STATUS IncFluMS() override; //透视MS调节
  111. virtual RET_STATUS DecFluMS() override;
  112. virtual RET_STATUS SetFluMS(float value) override;
  113. virtual RET_STATUS SetPPS(float frameRate) override; //脉冲透视帧率调节
  114. virtual RET_STATUS INCPPS() override;
  115. virtual RET_STATUS DECPPS() override;
  116. virtual RET_STATUS SetPluseWidth(float fplusewidth) override; //设置脉宽
  117. virtual RET_STATUS SetABSMode(int nMode) override; //设置自动亮度调节(ABS)模式
  118. virtual RET_STATUS SetABSCurve(int curveNum) override; //ABS曲线调节
  119. virtual RET_STATUS IncABSCurve() override;
  120. virtual RET_STATUS DecABSCurve() override;
  121. virtual RET_STATUS SetABSValue(float fABSValue) override;
  122. virtual RET_STATUS SetABSTargetEXI(float fEXIValue) override;
  123. virtual RET_STATUS SetAPF(const _tAPFArgs& t) override; //一次性设置透视参数
  124. virtual float GetFluIntTimer() override; //获取透视周期时间
  125. virtual float GetFluAccTimer() override; //获取透视曝光累计时间
  126. virtual RET_STATUS ResetFluTimer(int ntype) override; //清空透视曝光累计时间
  127. virtual RET_STATUS SetFluPre(int bPrepare) override; //设置透视预备阶段使能
  128. virtual RET_STATUS SetFluEXP(int bPrepare) override; //设置透视曝光阶段使能
  129. virtual RET_STATUS SetFLFMode(std::string value) override; //设置透视模式
  130. virtual RET_STATUS SetFluMAG(int nsize) override; //设置MG:0 to 3 - sets Mag size, ASCII character for 255 - Mag selection disabled
  131. virtual RET_STATUS DisableMAG() override;
  132. virtual RET_STATUS SetFluDoseLever(int nlever) override; //设置透视剂量等级( 0,1,2 )
  133. virtual RET_STATUS SetHalfDose(int nlever) override; //设置透视半价剂量
  134. virtual RET_STATUS TransferRadCurve(int ncurve) override; //点片KV跟随透视,0-3 Set curve 0:disable
  135. //指令消息收发
  136. void FireNotify(std::string key, const int context); //向上层上报整型消息
  137. void FireNotify(std::string key, const float context); //向上层上报浮点型消息
  138. void FireNotify(std::string key, const std::string context); //向上层上报字符串型消息
  139. void FireErrorMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报错误消息
  140. void FireWarnMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报告警消息
  141. //循环线程
  142. HANDLE m_pHardwareStatusThread{ NULL };
  143. bool StartHardwareStatusThread();
  144. static DWORD HardwareStatusThread(LPVOID pParam);
  145. //串口处理层
  146. static nsSerialGPM::CDeliverModule m_tDelivermodule;
  147. int m_nCMDType_FirstSend{ 0 };
  148. int m_nCMDType_WaitTime{ 0 };
  149. int m_nCMDType_WaitSelf{ 0 };
  150. static void __stdcall ProcessClientData(const char* pData, unsigned long DataLength, void* lparam);
  151. static void __stdcall WriteLog(const char* pData, nsSerialGPM::LOG_V2_LEVEL level);
  152. RET_STATUS HWSendFirst(char* strCommand, int lengh, stru_EDS_Status& state, int headLengh = 4);
  153. RET_STATUS HWSendWaittimeCMD(char* strCommand, int lengh, stru_EDS_Status& state, int headLengh = 4);
  154. RET_STATUS HWSendWaitSelfCMD(char* strCommand, int lengh, stru_EDS_Status& state, int headLengh = 4);
  155. //V3新方法
  156. virtual void SubscribeSelf(ccos_mqtt_connection* conn) override;
  157. protected:
  158. void Register();
  159. int GetConfData();
  160. bool OnCallBack();
  161. //RF80特有
  162. void GetState(); //获取当前设备状态
  163. void SetVersion(int ver); //获取设备固件版本
  164. bool FormatCMD(char* pCmd, int& nSize); //指令格式化
  165. void DetectorReady(); //just for Edx, can be sent before EXP but after SXP10
  166. void SetLastParambeforeEXP(RF80_TechMode lastTech, string CMDid, const char* CMDdata); //手闸、脚闸踩下后,X19信号到达前操作
  167. void SetRadStatus(int PreContact, int MainContact); //设置点片曝光状态
  168. void SetFluStatus(int PreContact, int MainContact); //设置透视曝光状态
  169. void SetSynBoxSwitchStatus(bool flag); //设置同步盒手闸、脚闸状态
  170. //参数发送逻辑
  171. bool SetAPRLocal(int nWS, int nET, int nFO, int nKV, float fMA, float fMS, float fMAS, int nAECFieldSel, int nAECFilmSel, int nAECDensity); //点片参数统一发送接口
  172. bool SetAPFLocal(int nWS, int nFluType, int nABSMode, int nDoseLevel, int nFKVP, float fFMA, float fPPS); //透视参数统一发送接口
  173. bool SetPlusFlouroParameter(int curve, int abs, float kv, float ma, float fps); //PF参数处理
  174. bool SetContinulFlourParameter(int curve, int abs); //CF参数处理
  175. bool SetManualFlourParameter(int kv, float ma); //手动透视参数处理
  176. RET_STATUS ProcessMsg(char* strCMD, int nCMDLengh, stru_EDS_Status& state); //统一发送接口
  177. RET_STATUS HWSend(char* strCMD, int nCMDLengh); //串口处理层回调发送接口
  178. //参数处理
  179. void Search3PointRange(float kv, float mas, int focus); //查询3点参数范围
  180. void Search2PointRange(float kv, int focus); //查询2点参数范围
  181. bool CheckRadLimitValue(int techMode, int focus, float kv, float& mas, float& ma); //根据mode不同,查询参数的极限值
  182. bool CheckFluFPSMaxKW(float kv, float ma); //检查当前帧率下功率
  183. int TurnAECFieldSel(bool isToGen, const int value); //AECField参数转化
  184. int TurnAECFilmSel(bool isToGen, int value); //AECFilm参数转化
  185. private:
  186. std::unique_ptr<nsDetail::MSGUnit> m_MSGUnit; //错误消息处理对象
  187. //控制、状态指示
  188. int m_nVersion{ 1 }; //当前硬件版本
  189. cfgWorkStationKey m_strCurrentWSName; //当前工作位名称
  190. _tAPRArgs m_APRParam; //记录APR参数用于SetExpMode时使用
  191. _tAPFArgs m_APFParam; //记录APF参数用于SetFLFMode时使用
  192. stru_EDS_Status m_GenStatus; //当前发生器状态
  193. string m_XrayReady{ "00" }; //是否允许出线: 00 不允许, 10 二档按下, 01 出线ready, 11 二档按下且出线ready
  194. string m_ExpReady{ "00" }; //是否允许曝光: 00 不允许曝光, 10 允许点片曝光, 01 允许透视曝光, 11 允许点片透视曝光
  195. int m_RadLimitFlag{ false }; //修改完KV、Focus后需查询MA、MAS上下限
  196. HANDLE m_hRadLimitMASEvent{ NULL }; //查询当前KV、Focus下MAS上限
  197. HANDLE m_hRadLimitMAEvent{ NULL }; //查询当前KV、Focus下MA上限
  198. HANDLE m_hExitEvent{ NULL }; //退出事件
  199. HANDLE m_hLoopEvent{ NULL }; //轮询使能事件
  200. HANDLE m_hArrayEvent[2]; //轮询线程等待事件数组
  201. vector<_tAPRArgs> m_APRarray; //多组APR参数
  202. int m_RadMode{ 0 }; //点片模式:1序列,0单帧
  203. //设备间通信
  204. LogicClient* m_pGenClient; //订阅调用端
  205. string m_SignalArray; //SynBox信号数组
  206. bool m_bNeedSendToSynBox{ false }; //是否向同步盒调用方法
  207. //配制文件
  208. string m_strConfigPath; //generator confile.
  209. ResDataObject m_GenConfig; //driver's config file.
  210. ResDataObject m_ResParametersList; //参数取值集合
  211. WSMap m_arrWSMap; //工作位标记码查找表
  212. int m_nSYNMode{ 2 }; //同步模式:1.硬同步,2软同步
  213. std::map<float, int> m_mapFPSMaxKW; //透视最大功率表
  214. string m_bIsSendSXPByRxpFlag{ "10" }; //是否由RXP发送SXP
  215. string m_bIsSendSFLByRxpFlag{ "0" }; //是否由RXP发送SFL
  216. bool m_bIsSendSCUFPDReady{ false }; //是否发送RDR
  217. RF80_TechMode m_LastTechMode{ RF80Tech_FLU_MAX }; //记录最后一次发生器所处Tech模式
  218. tLastParamItem m_LastParamArry[RF80Tech_FLU_MAX]; //最后一组参数
  219. int m_iLoopTime{ 0 }; //循环间隔时间(毫秒)
  220. //从配置读取指令参数
  221. int m_nCfgTubeLoad{ 80 };
  222. int m_nCfdCurrentRed{ 100 };
  223. int m_nCfdSwitch{ 0 };
  224. int m_nCfdDose{ 2500 };
  225. int m_nCfdMaxTime{ 2300 };
  226. int m_nCfdDoseRate{ 5000 };
  227. int m_nCfdPFMS{ 30 };
  228. int m_nCfdPFMSMax{ 30 };
  229. //RED下参数上下限
  230. float m_fCurMinMA{ 0 };
  231. float m_fCurMaxMA{ 0 };
  232. float m_fCurMinMS{ 0 };
  233. float m_fCurMaxMS{ 0 };
  234. float m_fCurMinMAS{ 0 };
  235. float m_fCurMaxMAS{ 0 };
  236. };
  237. }
  238. //-----------------------------------------------------------------------------
  239. // GenDriver
  240. //-----------------------------------------------------------------------------
  241. namespace CCOS::Dev::Detail::Generator
  242. {
  243. class _CCOSDEVGENSDC_API RF80Driver : public IODriverWithSCF <DriverMould>
  244. {
  245. using super = IODriverWithSCF <DriverMould>;
  246. public:
  247. RF80Driver ();
  248. virtual ~RF80Driver ();
  249. public:
  250. virtual void Prepare () override;
  251. virtual bool DATA_ACTION Connect () override;
  252. virtual void Disconnect() override;
  253. virtual bool isConnected() const override;
  254. virtual void Dequeue (const char * Packet, DWORD Length) override;
  255. virtual void FireNotify (int code, std::string key, std::string content) override;
  256. virtual auto CreateDevice (int index)->std::unique_ptr <IODevice> override;
  257. virtual std::string DriverProbe () override;
  258. virtual std::string GetResource () override;
  259. virtual std::string DeviceProbe () override;
  260. virtual bool GetDeviceConfig(std::string& Cfg) override;
  261. virtual bool SetDeviceConfig(std::string Cfg) override;
  262. private:
  263. static PACKET_RET callbackPackageProcess (const char* RecData, DWORD nLength, DWORD& PacketLength);
  264. ResDataObject m_DeviceConfigSend;
  265. ResDataObject m_DeviceConfig;
  266. string g_strAppPath;
  267. ResDataObject m_ConfigAll; //存储当前的配置,用于修改配置时写回文件
  268. ResDataObject m_Configurations; //存储当前配置中“CONFIGURATION”节点的内容
  269. std::unique_ptr <ResDataObject> m_pAttribute;
  270. std::unique_ptr <ResDataObject> m_pDescription;
  271. bool SaveConfigFile(bool bSendNotify);
  272. bool GetDeviceConfigValue(ResDataObject config, const char* pInnerKey, int nPathID, string& strValue);
  273. bool SetDeviceConfigValue(ResDataObject& config, const char* pInnerKey, int nPathID, const char* szValue);
  274. };
  275. }