DIOS.Dev.Generator.IMD.h 7.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  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 "LogicClient.h"
  10. //#include "DeliverModule.h"
  11. #ifdef CCOSDEVGENIMD_EXPORTS
  12. #define _CCOSDEVGENIMD_API __declspec(dllexport)
  13. #else
  14. #define _CCOSDEVGENIMD_API __declspec(dllimport)
  15. #endif
  16. typedef struct tagGenAPFParam
  17. {
  18. int nWorkStation;
  19. int nFluType;
  20. int nABSMode;
  21. int nDoseLevel;
  22. int nFKVP;
  23. float fFMA;
  24. float fPPS;
  25. float fFMS;//Plus length
  26. tagGenAPFParam& operator=(const tagGenAPFParam& visit)
  27. {
  28. nWorkStation = visit.nWorkStation;
  29. nFluType = visit.nFluType;
  30. nABSMode = visit.nABSMode;
  31. nDoseLevel = visit.nDoseLevel;
  32. nFKVP = visit.nFKVP;
  33. fFMA = visit.fFMA;
  34. fPPS = visit.fPPS;
  35. fFMS = visit.fFMS;
  36. return *this;
  37. }
  38. }ECOM_GEN_APF_PARAMS;
  39. namespace CCOS::Dev::Detail::Generator
  40. {
  41. static const int TIMEOUTVALUE = 10;
  42. //-----------------------------------------------------------------------------
  43. // IMDDevice
  44. //-----------------------------------------------------------------------------
  45. namespace nDev = CCOS::Dev;
  46. namespace DevDAP = CCOS::Dev::Detail::DAP;
  47. class _CCOSDEVGENIMD_API IMDDevice : public IODeviceWithSCF <IODeviceDetail>,public GeneratorMould
  48. {
  49. using super = IODeviceWithSCF <IODeviceDetail>;
  50. using superGen = GeneratorMould;
  51. public:
  52. IMDDevice (std::shared_ptr <IOEventCenter> center, nsSCF::SCF SCF);
  53. IMDDevice(std::shared_ptr <IOEventCenter> center, nsSCF::SCF SCF,string configfile);
  54. ~IMDDevice ();
  55. void SubscribeSelf(ccos_mqtt_connection* conn) override;
  56. bool LoadConfig(string configfile);
  57. virtual std::string GetGUID() const override;
  58. private:
  59. RET_STATUS HWSend (char * strCommand, int nTimeOut = TIMEOUTVALUE);
  60. void OnCallBack ();
  61. std::unique_ptr<DevDAP::DOSEMould> m_DAP;
  62. std::unique_ptr<nsDetail::MSGUnit> m_MSGUnit;
  63. bool StartHardwareStatusThread();
  64. static DWORD HardwareStatusThread(LPVOID pParam);
  65. HANDLE m_pHardwareStatusThread;
  66. string m_strCurrentSMState{""};
  67. bool m_bLoadConfigFile{ false };
  68. private:
  69. void Register();
  70. public:
  71. virtual RET_STATUS IncKV() override;
  72. virtual RET_STATUS DecKV() override;
  73. virtual RET_STATUS SetKV(float value) override;
  74. virtual RET_STATUS IncMA() override;
  75. virtual RET_STATUS DecMA() override;
  76. virtual RET_STATUS SetMA(float value) override;
  77. virtual RET_STATUS IncMS() override;
  78. virtual RET_STATUS DecMS() override;
  79. virtual RET_STATUS SetMS(float value) override;
  80. virtual RET_STATUS IncMAS() override;
  81. virtual RET_STATUS DecMAS() override;
  82. virtual RET_STATUS SetMAS(float value) override;
  83. virtual RET_STATUS SetTechmode(int value) override;
  84. virtual RET_STATUS SetFocus(int value) override;
  85. virtual RET_STATUS SetAECDensity(int value) override;
  86. virtual RET_STATUS SetAECField(int value) override;
  87. virtual RET_STATUS SetAECFilm(int value) override;
  88. virtual RET_STATUS SetWS(const std::string value) override;
  89. virtual RET_STATUS SetAPR(const _tAPRArgs& t) override;
  90. virtual RET_STATUS QueryHE(int& value) override;
  91. virtual RET_STATUS QueryPostKV(float& value) override;
  92. virtual RET_STATUS QueryPostMA(float& value) override;
  93. virtual RET_STATUS QueryPostMS(float& value) override;
  94. virtual RET_STATUS QueryPostMAS(float& value) override;
  95. virtual RET_STATUS SetGenSynState(int value) override;
  96. virtual RET_STATUS SetGenState(int value) override;
  97. virtual RET_STATUS SetExpEnable() override;
  98. virtual RET_STATUS SetExpDisable()override;
  99. virtual RET_STATUS Reset()override;
  100. virtual RET_STATUS SetExpMode(std::string value) override;
  101. virtual RET_STATUS SetFrameRate(FLOAT frameRate) override;
  102. virtual RET_STATUS SetEXAMMode(std::string value) override;
  103. RET_STATUS Clear_DAP();
  104. RET_STATUS GetValue_DAP(float& value);
  105. void StartMove();
  106. void EndMove();
  107. int GetGenState();
  108. //LSY add
  109. bool GetFLIntTimer();
  110. //透视
  111. virtual RET_STATUS IncFluKV() override; //透视KV调节
  112. virtual RET_STATUS DecFluKV() override;
  113. virtual RET_STATUS SetFluKV(float value) override;
  114. virtual RET_STATUS IncFluMA() override; //透视MA调节
  115. virtual RET_STATUS DecFluMA() override;
  116. virtual RET_STATUS SetFluMA(float value) override;
  117. virtual RET_STATUS IncFluMS() override; //透视MS调节
  118. virtual RET_STATUS DecFluMS() override;
  119. virtual RET_STATUS SetFluMS(float value) override;
  120. virtual RET_STATUS SetPPS(float frameRate) override; //脉冲透视帧率调节
  121. virtual RET_STATUS INCPPS() override;
  122. virtual RET_STATUS DECPPS() override;
  123. virtual RET_STATUS SetPluseWidth(float fplusewidth) override; //设置脉宽
  124. virtual RET_STATUS SetABSMode(int nMode) override; //设置自动亮度调节(ABS)模式
  125. virtual RET_STATUS SetABSCurve(int curveNum) override; //ABS曲线调节
  126. virtual RET_STATUS IncABSCurve() override;
  127. virtual RET_STATUS DecABSCurve() override;
  128. virtual RET_STATUS SetABSValue(float fABSValue) override;
  129. virtual RET_STATUS SetABSTargetEXI(float fEXIValue) override;
  130. virtual RET_STATUS SetAPF(const _tAPFArgs& t) override; //一次性设置透视参数
  131. virtual float GetFluIntTimer() override; //获取透视周期时间
  132. virtual float GetFluAccTimer() override; //获取透视曝光累计时间
  133. virtual RET_STATUS ResetFluTimer(int ntype) override; //清空透视曝光累计时间
  134. virtual RET_STATUS SetFluPre(int bPrepare) override; //设置透视预备阶段使能
  135. virtual RET_STATUS SetFluEXP(int bPrepare) override; //设置透视曝光阶段使能
  136. virtual RET_STATUS SetFLFMode(std::string value) override; //设置透视模式
  137. virtual RET_STATUS SetFluMAG(int nsize) override; //设置MG:0 to 3 - sets Mag size, ASCII character for 255 - Mag selection disabled
  138. virtual RET_STATUS DisableMAG() override;
  139. virtual RET_STATUS SetFluDoseLever(int nlever) override; //设置透视剂量等级( 0,1,2 )
  140. virtual RET_STATUS SetHalfDose(int nlever) override; //设置透视半价剂量
  141. virtual RET_STATUS TransferRadCurve(int ncurve) override; //点片KV跟随透视,0-3 Set curve 0:disable
  142. virtual RET_STATUS SetGenCurrentSMState(std::string value);
  143. protected:
  144. RET_STATUS RefreshData ();
  145. RET_STATUS SetRPS(int rps);//设置连续点片帧率
  146. private:
  147. void FireNotify (std::string key, std::string context);
  148. HANDLE m_hGenPostEvent; //暂时不使用了.
  149. _tAPRArgs m_t; //保存服务传入的参数
  150. string m_strConfigPath; //imd generator confile.
  151. ResDataObject m_GenConfig; //driver's config file.
  152. ECOM_GEN_APF_PARAMS m_stParamsAPF;
  153. LogicClient* m_pSubSystemClient;
  154. std::string GetDynamicLibraryPath();
  155. std::string GetFileVersion(std::string strFilePathName);
  156. bool m_bXrayonProcess{ false };
  157. };
  158. }
  159. //-----------------------------------------------------------------------------
  160. // IMDDriver
  161. //-----------------------------------------------------------------------------
  162. namespace CCOS::Dev::Detail::Generator
  163. {
  164. class _CCOSDEVGENIMD_API IMDDriver : public IODriverWithSCF <DriverMould>
  165. {
  166. using super = IODriverWithSCF <DriverMould>;
  167. public:
  168. IMDDriver ();
  169. virtual ~IMDDriver ();
  170. public:
  171. virtual void Prepare () override;
  172. virtual bool DATA_ACTION Connect () override;
  173. virtual void Disconnect() override;
  174. virtual bool isConnected() const override;
  175. virtual void Dequeue (const char * Packet, DWORD Length) override;
  176. virtual void FireNotify (int code, std::string key, std::string content) override;
  177. virtual auto CreateDevice (int index)->std::unique_ptr <IODevice> override;
  178. virtual std::string DriverProbe () override;
  179. virtual std::string GetResource () override;
  180. virtual std::string DeviceProbe () override;
  181. private:
  182. static PACKET_RET callbackPackageProcess (const char* RecData, DWORD nLength, DWORD& PacketLength);
  183. IMDDevice* m_pDevice{ nullptr };
  184. };
  185. }