TomoMotionModel.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. #pragma once
  2. #include "IMotionModel.h"
  3. namespace DIOS::Dev::Detail::MachineryECOM
  4. {
  5. const int TOMO_HEIGHT_SLICE_MAX = 256;
  6. class TomoMotionStageArgs;
  7. class ITubeAngleController;
  8. class ITubeHeightController;
  9. class ISensorADController;
  10. class ISensorEncoderController;
  11. class IExposureController;
  12. class IOutputController;
  13. class TomoMotionModel : public IMotionModel
  14. {
  15. public:
  16. TomoMotionModel();
  17. ~TomoMotionModel();
  18. public:
  19. virtual void ChangeStage(const std::string &stageName) override;
  20. virtual std::string GetStageName() override;
  21. virtual IMotionStageArgs *GetStageArgs() override;
  22. public:
  23. virtual void Initialize(IMachineryManager *machineryManager, IPositionManager *coordinates) override;
  24. virtual void LoadMachineryParams(ResDataObject &params) override;
  25. virtual void LoadModelParams(ResDataObject &params) override;
  26. virtual void SetTechnicalParams(ResDataObject &params) override;
  27. virtual void OnFeedbackMotionParams(ResDataObject &params) override;
  28. virtual BOOL GetMotionParams(ResDataObject &params) override;
  29. virtual void SwitchScanningComponents(int nSwitch) override;
  30. virtual void SwitchWorkstation(string ws) override;
  31. private:
  32. void OnMotionStage(const std::string &stageName);
  33. void MotionStageClearParams();
  34. void MotionStageCalculateParams();
  35. void MotionStageSetTomoMotionSlice();
  36. void MotionStageMovetoEndPos();
  37. void MotionStageMovetoStartPos();
  38. void MotionStageErrorStop();
  39. void MotionStageErrorRecover();
  40. void MotionStageCenterAdjust();
  41. void AlignTubeHeightToDetector();
  42. void RotateTubeToHorizontal();
  43. void StopMotion();
  44. void MoveTubeHeightToTomoStartPosiotn();
  45. void RotateTubeAngleToTomoStartPostion();
  46. BOOL GetTomoRotateDirection();
  47. int JudgeDirectionInTubeHeightAxis(float current,float target);
  48. int JudgeDirectionInTubeAngleAxis(float current,float target);
  49. void MoveTubeHeight(int direction,float offset,float spd = 0.0f);
  50. void RotateTubeAngle(int direction, float offset);
  51. void UpdateDigitalTwinTomoSliceParams();
  52. void FixHeightStartPosition(float speed);
  53. void OnMotionStageMove2SID(string ws);
  54. int JudgeDirectionInTubeHorizontalAxis(float current, float target);
  55. void MoveTubeHorizontal(int direction, float offset, float spd = 0.0f);
  56. void DoMotionStageSetTomoMotionSlice(ISensorEncoderController* pEncoder, string encoderControllerName);
  57. void DoMotionStageMovetoEndPosHeight();
  58. void DoMotionStageMovetoEndPosHorizontal();
  59. void DoMotionStageMovetoStartPosHeight();
  60. void DoMotionStageMovetoStartPosHorizontal();
  61. void MoveTubeHorizontalToTomoStartPosiotn();
  62. private:
  63. std::string m_StageName;
  64. TomoMotionStageArgs *m_stageArgs;
  65. IPositionManager *m_coordinates;
  66. IMachineryManager *m_machineryManager;
  67. ITubeAngleController *m_motorTubeAngle;
  68. ITubeHeightController *m_motorTubeHeight;
  69. ISensorADController *m_adDetectorHeight;
  70. ISensorEncoderController *m_encoderTubeAngle;
  71. ISensorEncoderController *m_encoderTubeHeight;
  72. IExposureController *m_exposure;
  73. ITubeHeightController* m_motorTubeHorizontal;
  74. ISensorADController* m_adTubeHorizontal;
  75. ISensorEncoderController* m_encoderTubeHorizontal;
  76. IOutputController* m_tubeLineMotionSwitch;
  77. float *m_heightSlices;
  78. int *m_anglePeriods;
  79. int *m_angleSteps;
  80. float m_warmAngle;
  81. float m_anglePerSlice;
  82. int m_angleSliceCount;
  83. int m_heightSliceCount;
  84. float m_heightStartPosition;
  85. float m_angleStartPosition;
  86. float m_fps;
  87. ResDataObject m_MachineryParams;
  88. ResDataObject m_ModelParams;
  89. ResDataObject m_TechnicalParams;
  90. std::vector<int> m_FeedbackTubeHeightEncoders;
  91. std::vector<int> m_FeedbackTubeAngleEncoders;
  92. };
  93. }