AbstractSeq.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. // 下列 ifdef 块是创建使从 DLL 导出更简单的
  2. // 宏的标准方法。此 DLL 中的所有文件都是用命令行上定义的 WHEELDPC_EXPORTS
  3. // 符号编译的。在使用此 DLL 的
  4. // 任何其他项目上不应定义此符号。这样,源文件中包含此文件的任何其他项目都会将
  5. // SYNCFPDDPC_API 函数视为是从 DLL 导入的,而此 DLL 则将用此宏定义的
  6. // 符号视为是被导出的。
  7. #ifndef ABSTRACTSEQ_EXPORTS
  8. #ifdef _WIN64
  9. #ifdef _DEBUG
  10. #pragma comment(lib, "AbstractSeqX64D.lib")
  11. #else
  12. #pragma comment(lib, "AbstractSeqX64.lib")
  13. #endif
  14. #else
  15. #ifdef _DEBUG
  16. #pragma comment(lib, "AbstractSeqD.lib")
  17. #else
  18. #pragma comment(lib, "AbstractSeq.lib")
  19. #endif
  20. #endif
  21. #endif
  22. #ifdef ABSTRACTSEQ_EXPORTS
  23. #define ABSTRACTSEQ_API __declspec(dllexport)
  24. #else
  25. #define ABSTRACTSEQ_API __declspec(dllimport)
  26. #endif
  27. #include "LogicDevice.h"
  28. #include "CommonLogicClient.h"
  29. #include "diosthread.h"
  30. #include "DIOSLogicDeviceStructure.h"
  31. #include <map>
  32. class ABSTRACTSEQ_API AbstractSeq : public LogicDevice
  33. {
  34. public:
  35. AbstractSeq(void);
  36. virtual ~AbstractSeq(void);
  37. void *m_pData;
  38. void *m_pNotify;
  39. BaseJsonDataObject<int>* m_nXWindowTime;
  40. //get device type
  41. virtual bool SYSTEM_CALL GetDeviceType(GUID &DevType);
  42. //get device resource
  43. virtual RET_STATUS SYSTEM_CALL GetDeviceResource(ResDataObject PARAM_OUT *pDeviceResource);
  44. //ResourceCommand Request In and Response Out
  45. virtual RET_STATUS SYSTEM_CALL Request(ResDataObject PARAM_IN *pRequest, ResDataObject PARAM_OUT *pResponse);
  46. //notify to lower layer
  47. virtual RET_STATUS SYSTEM_CALL CmdToLogicDev(ResDataObject PARAM_IN *pCmd);
  48. //errors,warnings
  49. void SetErrorInfo(int errCode, char *pErrInfo);
  50. void SetWarningInfo(int warningCode, char *pWarningInfo);
  51. protected:
  52. SM_STATUS m_SMState;
  53. bool m_bExposureSuccess;
  54. bool m_bSwitchStatus;
  55. //map<CommonLogicClient*, bool > m_mapError;
  56. public:
  57. int WaitforNotify(HANDLE exit);
  58. void InitState( map<CommonLogicClient*, int> &objSM);
  59. bool StateAction(char*,map<CommonLogicClient*, int>& objSM);
  60. bool StateGuard(char*,map<CommonLogicClient*, int> &objSM);
  61. bool StateNotify(char* strState, bool bResult);
  62. private:
  63. bool ProcessHandSwitch(CommonLogicClient* pULDObj, bool bHSWStatus);
  64. public:
  65. //fpd actions
  66. virtual RET_STATUS OpenLogicDevice();
  67. virtual RET_STATUS CloseLogicDevice();
  68. virtual RET_STATUS AddLogicDevice(string path);
  69. virtual RET_STATUS DelLogicDevice(string path);
  70. virtual RET_STATUS SetApplicationMode(ResDataObject nApplicationMode); //RAD FLU
  71. virtual RET_STATUS SetExamInfo(ResDataObject nExamMode);
  72. virtual RET_STATUS GetSEQResource(ResDataObject PARAM_OUT *pDeviceResource);
  73. virtual RET_STATUS SeqPrep();
  74. virtual RET_STATUS SeqReady();
  75. virtual RET_STATUS FramePrep();
  76. virtual RET_STATUS ExpEnableAction();
  77. virtual RET_STATUS ExpEnableResult(CommonLogicClient* objSM, RES_SM SMResult);
  78. virtual RET_STATUS FrameReady();
  79. virtual RET_STATUS FrameReadyResult(CommonLogicClient* objSM, RES_SM bResult);
  80. virtual RET_STATUS FrameStart();
  81. virtual RET_STATUS FrameStartResult(CommonLogicClient* objSM, RES_SM SMResult);
  82. virtual RET_STATUS FrameIn();
  83. virtual RET_STATUS FrameInComplete(CommonLogicClient* objSM, RES_SM SMResult);
  84. virtual RET_STATUS FramePost();
  85. //virtual RET_STATUS FramePostResult();
  86. virtual RET_STATUS FrameEnd();
  87. virtual RET_STATUS FrameEndResult();
  88. virtual RET_STATUS FrameError();
  89. virtual RET_STATUS SeqPost();
  90. virtual RET_STATUS SeqPostResult();
  91. //we need check each action resource is Support or not
  92. //return yes or no inside of OEM module
  93. virtual RET_STATUS Support_SetSyncMode();
  94. virtual RET_STATUS Support_SetXWindowTime();
  95. virtual RET_STATUS Support_SetApplicationMode();
  96. virtual RET_STATUS Support_SetExamInfo();
  97. virtual RET_STATUS Support_GetSEQResource();
  98. virtual RET_STATUS Support_SeqPrep();
  99. virtual RET_STATUS Support_SeqReady();
  100. virtual RET_STATUS Support_FramePrep();
  101. virtual RET_STATUS Support_ExpEnable();
  102. virtual RET_STATUS Support_FrameReady();
  103. virtual RET_STATUS Support_FrameStart();
  104. virtual RET_STATUS Support_XWindowOn();
  105. virtual RET_STATUS Support_FrameIn();
  106. virtual RET_STATUS Support_FrameInComplete();
  107. virtual RET_STATUS Support_FramePost();
  108. virtual RET_STATUS Support_FrameEnd();
  109. virtual RET_STATUS Support_FrameError();
  110. virtual RET_STATUS Support_SeqPost();
  111. };
  112. class NotifyThread :public Thread_Base
  113. {
  114. public:
  115. NotifyThread();
  116. ~NotifyThread();
  117. NotifyThread(class AbstractSeq *pAbstractSeq);
  118. //HANDLE m_ExitFlag = CreateEvent(NULL, FALSE, FALSE, NULL);
  119. protected:
  120. bool Exec(void);
  121. AbstractSeq * m_pAbstractSeq;
  122. };