RfFPD.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. #pragma once
  2. // 下列 ifdef 块是创建使从 DLL 导出更简单的
  3. // 宏的标准方法。此 DLL 中的所有文件都是用命令行上定义的 RFFPD_EXPORTS
  4. // 符号编译的。在使用此 DLL 的
  5. // 任何其他项目上不应定义此符号。这样,源文件中包含此文件的任何其他项目都会将
  6. // RFFPD_API 函数视为是从 DLL 导入的,而此 DLL 则将用此宏定义的
  7. // 符号视为是被导出的。
  8. #ifndef RFFPD_EXPORTS
  9. #ifdef _WIN64
  10. #ifdef _DEBUG
  11. #pragma comment(lib, "RfFPDX64D.lib")
  12. #else
  13. #pragma comment(lib, "RfFPDX64.lib")
  14. #endif
  15. #else
  16. #ifdef _DEBUG
  17. #pragma comment(lib, "RfFPDD.lib")
  18. #else
  19. #pragma comment(lib, "RfFPD.lib")
  20. #endif
  21. #endif
  22. #endif
  23. #ifdef RFFPD_EXPORTS
  24. #define RFFPD_API __declspec(dllexport)
  25. #define RFFPD_C_API extern "C" __declspec(dllexport)
  26. #else
  27. #define RFFPD_API __declspec(dllimport)
  28. #define RFFPD_C_API extern "C" __declspec(dllimport)
  29. #endif
  30. #include "DetctorDriver.h"
  31. #include "SeqImages.h"
  32. RFFPD_C_API DriverDPC* GetDriverDPC();
  33. RFFPD_C_API void ReleaseDriverDPC(DriverDPC *p);
  34. class RFFPD_API RfFPDDDPC : public DetctorDriver
  35. {
  36. std::string *m_pWorkpath;
  37. PVOID m_pFPDDevice;
  38. LogicDevice *m_pAcqFPD;
  39. //LogicDevice *m_pCaliFPD;
  40. //LogicDevice *m_pSyncFPD;
  41. // LogicDevice *m_pTemperFPD; //温度单元
  42. HANDLE m_AcqReqEvt;
  43. HANDLE m_StopReqEvt;
  44. HANDLE m_DeviceStopedEvt;
  45. DWORD m_AcqLoopCount;//当前模式下的采集张数
  46. DWORD m_AcquiredCount;//当前模式下的已采集张数
  47. DWORD m_CalibrationRoundCount;
  48. DWORD m_CalibrationExpCount;//当前校正模式下的已采集张数
  49. SeqImages *m_pSeqList;//for multiple acq mode
  50. ResDataObject m_ConfigAll; //addbyys20200618存储所有配置信息
  51. ResDataObject m_Configurations; //addbyys20200618存储配置信息CONFIGURATION部分
  52. bool m_bRadMode; //true:rad模式
  53. bool m_bPreviewEnable;
  54. bool m_bFor750MT;
  55. enum Mode750MT
  56. {
  57. modePreview,
  58. modeFULL,
  59. } m_mode750MT;
  60. DETECTOR_WORK_STATUS m_eWorkStatus; //存储DPC的workstatus,该值自己判断
  61. public:
  62. RfFPDDDPC(void);
  63. virtual ~RfFPDDDPC(void);
  64. virtual bool DriverEntry(ResDataObject &Configuration);
  65. //virtual bool Driver_Probe(ResDataObject &HardwareInfo);
  66. virtual bool SYSTEM_CALL SetDriverWorkPath(const char * PARAM_IN pWorkPath);
  67. virtual PVOID SYSTEM_CALL LoadDriver();//无根节点
  68. virtual void SYSTEM_CALL UnloadDriver();
  69. virtual bool Connect();
  70. virtual void DisConnect();
  71. //给硬件驱动设置Unique工作路径
  72. //如果是同一设备同一连接情况下,硬件多次接入,系统会保证工作路径是一样的.
  73. //连接后,单一硬件相关的数据要保存在此.
  74. virtual bool SYSTEM_CALL SetDeviceWorkPath(const char * PARAM_IN pWorkPath);
  75. //逻辑设备树的加载和卸载
  76. virtual PVOID SYSTEM_CALL LoadLogicDevices();
  77. virtual void SYSTEM_CALL UnloadLogicDevices();
  78. virtual bool Device_Probe(ResDataObject &HardwareInfo);
  79. virtual DWORD SYSTEM_CALL OnNotify(HANDLE evtList[], DWORD count);
  80. //用SetAcqMode()替代以下两个接口
  81. //RET_STATUS DATA_ACTION SetExamInfo(ResDataObject& PARAM_IN pParam);
  82. //virtual RET_STATUS DATA_ACTION SelectExamMode(const char *pExamKey);
  83. RET_STATUS SYSTEM_CALL SetAcqMode(int AcqMode);
  84. bool SYSTEM_CALL Acq_Proc();
  85. //继承类必须实现的功能
  86. RET_STATUS OEM_IF StartAcquisition();
  87. RET_STATUS OEM_IF StopAcquisition();
  88. RET_STATUS OEM_IF StopAcquisition_Inside();
  89. RET_STATUS OEM_IF ActiveCalibration();
  90. RET_STATUS OEM_IF PrepareCalibration();
  91. RET_STATUS OEM_IF StartCalibration();
  92. RET_STATUS OEM_IF PauseCalibration();//internal call
  93. RET_STATUS OEM_IF StopCalibration();
  94. RET_STATUS OEM_IF SetDetectorStatus(DETECTOR_STATUS status);
  95. RET_STATUS SYSTEM_CALL GetDriverDictionary(ResDataObject& PARAM_OUT DriverInfo);
  96. ResDataObject ExamList;
  97. //20200611 ys add 增加配置工具获取、设置配置的功能
  98. ResDataObject* m_pAttribute;
  99. ResDataObject* m_pDescription;
  100. std::string *m_strConfigPath; //配置文件路径
  101. int m_nImgSizeX;
  102. int m_nImgSizeY;
  103. int m_nBits;
  104. int m_nPixelSpacing;
  105. RET_STATUS DATA_ACTION GetDeviceConfig(ResDataObject PARAM_OUT *pDeviceConfig);
  106. RET_STATUS DATA_ACTION SetDeviceConfig(ResDataObject PARAM_IN *DeviceConfig);
  107. bool GetDeviceConfigValue(const char *pInnerKey, int nPathID, string &strValue);
  108. bool SetDeviceConfigValue(const char *pInnerKey, int nPathID, const char *szValue);
  109. //20200611 add end
  110. RET_STATUS DATA_ACTION SetFrameRate(FLOAT frameRate);
  111. RET_STATUS DATA_ACTION SetSyncMode(SYNC_MODE nSyncMode, HARDWARE_TRIGGER_MODE TriggerMode);
  112. RET_STATUS DATA_ACTION SetDemoImage(const char *pPath);
  113. RET_STATUS DATA_ACTION ResetError();
  114. void SendEcomFPDState(int state);
  115. void SendInfoLog(string strLogKey, float fValue);
  116. void SendInfoLog(string strLogKey, int nValue);
  117. void SendInfoLog(string strLogKey, bool bRealSN);
  118. void SendInfoLog(string strLogKey, string strValue = "");
  119. void SendLog(string strLogKey, string strLogLevel, bool bRealSN, string strValue = "");
  120. };