CCOS.Dev.Generator.Demo.hpp 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. #pragma once
  2. #include <string>
  3. #include "CCOS.Dev.IODevice.Detail.hpp"
  4. #include "CCOS.Dev.Generator.Mould.hpp"
  5. #include "CcosThread.h"
  6. //#include "IODeviceWithSCF.tlh"
  7. #include "DAP.BasicMoulds.hpp"
  8. #include "CCOS.Dev.MSGMould.hpp"
  9. #include <deque>
  10. #include <atomic>
  11. #include "OEM.Collimator.h"
  12. #include "OEM.Mechanical.h"
  13. #define _CCOSDEVGENERATORDEMO_API
  14. namespace CCOS::Dev::Detail::Generator
  15. {
  16. enum Demo_REGULATION_LEVEL { //故障等级
  17. REG_ERRO,
  18. REG_WARN
  19. };
  20. //-----------------------------------------------------------------------------
  21. // GENDeviceMould
  22. //-----------------------------------------------------------------------------
  23. namespace nDev = CCOS::Dev;
  24. class _CCOSDEVGENERATORDEMO_API DemoDevice : public IODeviceDetail, public GeneratorMould
  25. {
  26. using super = IODeviceDetail;
  27. using superGen = GeneratorMould;
  28. public:
  29. DemoDevice(std::shared_ptr <IOEventCenter> center, string configfile = "");
  30. ~DemoDevice();
  31. private:
  32. void OnRegister();
  33. public:
  34. //设备方法
  35. virtual std::string GetGUID() const override;
  36. virtual RET_STATUS SetWS(const std::string value) override;
  37. virtual RET_STATUS SetGenSynState(int value) override;
  38. virtual RET_STATUS SetGenState(int value) override;
  39. virtual RET_STATUS SetExpEnable() override;
  40. virtual RET_STATUS SetExpDisable()override;
  41. virtual RET_STATUS PrepareAcquisition()override;
  42. virtual RET_STATUS Reset()override;
  43. virtual RET_STATUS SetExpMode(std::string value) override;
  44. virtual RET_STATUS QueryHE(int& value) override;
  45. virtual RET_STATUS SetEXAMMode(std::string value) override;
  46. virtual RET_STATUS ActiveSyncMode(_tSyncModeArgs value) override;
  47. RET_STATUS StartMove();
  48. RET_STATUS EndMove();
  49. RET_STATUS DirectlyNotify(string& value);
  50. RET_STATUS DirectlyCMD(string& value);
  51. //点片
  52. virtual RET_STATUS IncKV() override;
  53. virtual RET_STATUS DecKV() override;
  54. virtual RET_STATUS SetKV(float value) override;
  55. virtual RET_STATUS IncKVL() override;//add by wxx for task226
  56. virtual RET_STATUS DecKVL() override;
  57. virtual RET_STATUS IncMA() override;
  58. virtual RET_STATUS DecMA() override;
  59. virtual RET_STATUS SetMA(float value) override;
  60. virtual RET_STATUS IncMS() override;
  61. virtual RET_STATUS DecMS() override;
  62. virtual RET_STATUS SetMS(float value) override;
  63. virtual RET_STATUS IncMAS() override;
  64. virtual RET_STATUS DecMAS() override;
  65. virtual RET_STATUS SetMAS(float value) override;
  66. virtual RET_STATUS IncMASL() override;//add by wxx for task226
  67. virtual RET_STATUS DecMASL() override;
  68. void ComputeMAS(); //fix bug5297 by wxx
  69. virtual RET_STATUS SetTechmode(int value) override;
  70. virtual RET_STATUS SetFocus(int value) override;
  71. virtual RET_STATUS SetAPR(const _tAPRArgs& t) override;
  72. virtual RET_STATUS SetAPRArray(vector<_tAPRArgs>& APRarray) override;
  73. virtual RET_STATUS SetAECDensity(int value) override;
  74. virtual RET_STATUS IncAECDensity() override;
  75. virtual RET_STATUS DecAECDensity() override;
  76. virtual RET_STATUS SetAECField(int value) override;
  77. virtual RET_STATUS SetAECFilm(int value) override;
  78. virtual RET_STATUS QueryPostKV(float& value) override;
  79. virtual RET_STATUS QueryPostMA(float& value) override;
  80. virtual RET_STATUS QueryPostMS(float& value) override;
  81. virtual RET_STATUS QueryPostMAS(float& value) override;
  82. virtual RET_STATUS SetFrameRate(float frameRate) override;
  83. //透视
  84. virtual RET_STATUS IncFluKV() override; //透视KV调节
  85. virtual RET_STATUS DecFluKV() override;
  86. virtual RET_STATUS SetFluKV(float value) override;
  87. virtual RET_STATUS IncFluMA() override; //透视MA调节
  88. virtual RET_STATUS DecFluMA() override;
  89. virtual RET_STATUS SetFluMA(float value) override;
  90. virtual RET_STATUS IncFluMS() override; //透视MS调节
  91. virtual RET_STATUS DecFluMS() override;
  92. virtual RET_STATUS SetFluMS(float value) override;
  93. virtual RET_STATUS SetPPS(float frameRate) override; //脉冲透视帧率调节
  94. virtual RET_STATUS INCPPS() override;
  95. virtual RET_STATUS DECPPS() override;
  96. virtual RET_STATUS SetPluseWidth(float fplusewidth) override; //设置脉宽
  97. virtual RET_STATUS SetABSMode(int nMode) override; //设置自动亮度调节(ABS)模式
  98. virtual RET_STATUS SetABSCurve(int curveNum) override; //ABS曲线调节
  99. virtual RET_STATUS IncABSCurve() override;
  100. virtual RET_STATUS DecABSCurve() override;
  101. virtual RET_STATUS SetABSValue(float fABSValue) override;
  102. virtual RET_STATUS SetABSTargetEXI(float fEXIValue) override;
  103. virtual RET_STATUS SetAPF(const _tAPFArgs& t) override; //一次性设置透视参数
  104. virtual float GetFluIntTimer() override; //获取透视周期时间
  105. virtual float GetFluAccTimer() override; //获取透视曝光累计时间
  106. virtual RET_STATUS ResetFluTimer(int ntype) override; //清空透视曝光累计时间
  107. virtual RET_STATUS SetFluPre(int bPrepare) override; //设置透视预备阶段使能
  108. virtual RET_STATUS SetFluEXP(int bPrepare) override; //设置透视曝光阶段使能
  109. virtual RET_STATUS SetFLFMode(std::string value) override; //设置透视模式
  110. virtual RET_STATUS SetFluMAG(int nsize) override; //设置MG:0 to 3 - sets Mag size, ASCII character for 255 - Mag selection disabled
  111. virtual RET_STATUS DisableMAG() override;
  112. virtual RET_STATUS SetFluDoseLever(int nlever) override; //设置透视剂量等级( 0,1,2 )
  113. virtual RET_STATUS SetHalfDose(int nlever) override; //设置透视半价剂量
  114. virtual RET_STATUS TransferRadCurve(int ncurve) override; //点片KV跟随透视,0-3 Set curve 0:disable
  115. //为了将gen和其他设备关联,能相互调用接口
  116. static std::unique_ptr<OemCollimator> m_pCollDev; //遮光器逻辑实体指针
  117. static std::unique_ptr<OemMechanical> m_pMechDev; //机架逻辑实体指针
  118. RET_STATUS SetCollimatorDev(OemCollimator* dev);
  119. RET_STATUS SetMechDev(OemMechanical* dev);
  120. RET_STATUS SetCollimatorSize(int xsize, int ysize);
  121. RET_STATUS SetCollimatorLight(unsigned short pParams);
  122. RET_STATUS SetAutoTracking(int nAutoTracking);
  123. RET_STATUS SetFilter(int nFilterType);
  124. RET_STATUS SetGrid(int nGridType);
  125. RET_STATUS GetTomoResults(ResDataObject& resultAngle, ResDataObject& resultHeight);
  126. ResDataObject m_GenConfig; //发生器配置
  127. atomic<int> m_iAutoExpFlag; //自动曝光流程
  128. int m_iStateChangeInterval; //状态切换间隔
  129. int m_iAutoExpActWaitTime; //曝光动作等待时间
  130. bool m_bIsDemo; //是否是Demo环境(即参数是否可调)
  131. ResDataObject m_resultAngle; //?
  132. protected:
  133. int GetConfData();
  134. std::vector <float> m_MA_List; //MA取值集合
  135. std::vector <float> m_MS_List; //MS取值集合
  136. std::vector <float> m_MAS_List; //MAS取值集合
  137. vector<_tAPRArgs> m_APRarray; //APR数组,用于拼接
  138. private:
  139. std::mutex m_MSGLock; //消息上报锁
  140. void FireErrorMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报错误消息
  141. void FireWarnMessage(const bool Act, const int Code, const char* ResInfo = ""); //上报告警消息
  142. void FireNotify(std::string key, int context);
  143. void FireNotify(std::string key, float context);
  144. void FireNotify(std::string key, std::string context);
  145. bool StartHardwareStatusThread();
  146. static void* HardwareStatusThread(void* pParam);
  147. pthread_t m_pHardwareStatusThread;
  148. std::unique_ptr<nsDetail::MSGUnit> m_MSGUnit; //处理消息上报对象指针
  149. cfgWorkStationKey m_strCurrentWSName; //当前工作位名称
  150. map<cfgWorkStationKey, cfgWorkStationData> m_arrWSMap; //工作位标记码查找表
  151. #ifdef DEMO_SELF
  152. #endif
  153. };
  154. }
  155. //-----------------------------------------------------------------------------
  156. // DEMODriver
  157. //-----------------------------------------------------------------------------
  158. namespace CCOS::Dev::Detail::Generator
  159. {
  160. class _CCOSDEVGENERATORDEMO_API DemoDriver : public DriverMould
  161. {
  162. //using super = IODriverWithSCF <DriverMould>;
  163. ResDataObject m_GenConfig;
  164. public:
  165. DemoDriver();
  166. virtual ~DemoDriver();
  167. public:
  168. virtual void Prepare() override;
  169. virtual bool Connect() override;
  170. virtual void Disconnect() override;
  171. virtual bool isConnected() const override;
  172. void Dequeue(const char* Packet, DWORD Length) ;
  173. void FireNotify(int code, std::string key, std::string content) ;
  174. virtual auto CreateDevice(int index)->std::unique_ptr <IODevice> override;
  175. virtual std::string DriverProbe() override;
  176. virtual std::string GetResource() override;
  177. virtual std::string DeviceProbe() override;
  178. virtual bool GetDeviceConfig(std::string& Cfg) override;
  179. virtual bool SetDeviceConfig(std::string Cfg) override;
  180. private:
  181. static int callbackPackageProcess(const char* RecData, DWORD nLength, DWORD& PacketLength);
  182. bool m_bDemoMode;
  183. bool m_bDemoConnected; // 在 DEMO 模式下, 调用过 Connect 吗?
  184. DemoDevice* m_pDriGenDev;// = nullptr;
  185. OemCollimator* m_pDriCollDev;// = nullptr;
  186. OemMechanical* m_pDriMechDev;// = nullptr;
  187. bool m_bDemoInitDataFlag; //是否存在初始化数据
  188. ResDataObject m_InitDataFile;
  189. //为了webconfig
  190. ResDataObject m_DeviceConfigSend;
  191. ResDataObject m_DeviceConfig;
  192. string g_strAppPath;
  193. ResDataObject m_ConfigAll; //存储当前的配置,用于修改配置时写回文件
  194. ResDataObject m_Configurations; //存储当前配置中“CONFIGURATION”节点的内容
  195. std::unique_ptr <ResDataObject> m_pAttribute;
  196. std::unique_ptr <ResDataObject> m_pDescription;
  197. bool SaveConfigFile(bool bSendNotify);
  198. bool GetDeviceConfigValue(ResDataObject config, const char* pInnerKey, int nPathID, string& strValue);
  199. bool SetDeviceConfigValue(ResDataObject& config, const char* pInnerKey, int nPathID, const char* szValue);
  200. };
  201. }