CBondHead.h 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255
  1. #pragma once
  2. #include "CModule.h"
  3. #include "CNozzleTable.h"
  4. #include "CBondMatrix.h"
  5. #include "CForceControl.h"
  6. #include "CRCalib.h"
  7. #include "CLookUpCalib.h"
  8. #include "CTransferTable.h"
  9. #include "CXYCalib.h"
  10. #include "TipMatrix.h"
  11. class __declspec(dllexport) CBondHead :
  12. public CModule
  13. {
  14. public:
  15. CBondHead(MODULE_LIST eModuleType);
  16. ~CBondHead();
  17. virtual LONG AllocateAxis(vector<CAxis*> vecAxis);
  18. virtual LONG AllocateIo(vector<CIO*> vecIo);
  19. void SetXAxis(CAxis* axis) { m_pXAxis = axis; }
  20. CAxis* GetXAxis() { return m_pXAxis; }
  21. void SetYAxis(CAxis* axis) { m_pYAxis = axis; }
  22. CAxis* GetYAxis() { return m_pYAxis; }
  23. void SetZAxis(CAxis* axis) { m_pZAxis = axis; }
  24. CAxis* GetZAxis() { return m_pZAxis; }
  25. //void SetForceZAxis(CAxis* axis) { m_pForcerZ = axis; }
  26. //CAxis* GetForceZAxis() { return m_pForcerZ; }
  27. void SetRAxis(CAxis* axis) { m_pRAxis = axis; }
  28. CAxis* GetRAxis() { return m_pRAxis; }
  29. void SetCoord(CCoord* pCrd) { m_pCoord_XY = pCrd; }
  30. CCoord* GetCoord() { return m_pCoord_XY; }
  31. void SetVacDO(CIO* out) { m_pBDVacGpo = out; }
  32. void SetFlowDo(CIO* out) { m_pBDFlowGpo = out; }
  33. void SetVacDi(CIO* input) { m_pBDVacGpi = input; }
  34. void SetFlowDi(CIO* input) { m_pBDFlowGpi = input; }
  35. void SetNozzleTable(CNozzleTable* nozzleTable) { m_pNozzleTable = nozzleTable; }
  36. void SetLookUpCamera(CCameraBase* camera) { m_pLookUpCamera = camera; }
  37. void SetWaferTransferTable(CTransferTable* tt) { m_pWaferTransferTable = tt; }
  38. void SetWaffleTransferTable(CTransferTable* tt) { m_pWaffleTransferTable = tt; }
  39. //void SetForceControl(CForceControl* force) { m_pForceControl = force; }
  40. CForceControl* GetForceControl() { return m_pForceControl; }
  41. CXYCalib* GetLookUpCameraCalib() { return m_pLookUpXYCalib; }
  42. CRCalib* GetHeadRCalib() { return m_pRCalib; }
  43. bool GetIsLocationAll() { return m_bIsLocationAll; }
  44. virtual void SetHighCamera(CCameraBase* camera) {}
  45. virtual void SetLowCamera(CCameraBase* camera) { m_pLowCamera = camera; }
  46. virtual CXYCalib* GetLowCameraCalib() { return m_pLowXYCalib; }
  47. virtual CXYCalib* GetHighCameraCalib() { return nullptr; }
  48. virtual CCTDCalib* GetLowCTDCalib() { return m_pLowCTDCalib; }
  49. virtual LONG ToHome();
  50. virtual LONG ToSafePosition();
  51. LONG XYMove(double x, double y, bool bSync = true);
  52. LONG XYMoveTo(double x,double y, bool bSync = true);
  53. LONG XYZMoveTo(double x, double y,double z);
  54. LONG XYZRMoveTo(double x, double y, double z,double r);
  55. LONG MoveToPreBondPoint();
  56. LONG MoveToNextBondPoint();
  57. virtual void SetPickHTestIndex(int index) = 0;
  58. virtual void SetBondHTestIndex(int index) = 0;
  59. virtual LONG PickHightTest();//调用之前先SetIndex
  60. virtual LONG AllBondHighTest() = 0;
  61. virtual LONG BondHighTest();
  62. virtual LONG VacuumOn(long lDelay); //真空开,真空延时,ms
  63. virtual LONG VacuumOff(long lDelay); //真空关,吹汽延时,ms
  64. virtual LONG StrongOn(); //强吹开
  65. virtual LONG StrongOff(); //强吹关
  66. virtual LONG UltraOn() { return OK; }; //超声开
  67. virtual LONG UltraOff() { return OK; }; //超声关
  68. virtual LONG ChangeNozzle(int nozzleIndex);
  69. virtual LONG UnLoadNozzle();
  70. virtual LONG LoadNozzle(int nozzleIndex);
  71. virtual LONG CheckDieExistStatus(bool& bExist);
  72. virtual LONG MoveLowCameraToNozzle();
  73. virtual LONG MoveNozzleToLowCamera();
  74. //吸嘴取晶
  75. virtual LONG MoveToPickGrabPos(bool waitDone = true);
  76. virtual LONG PickGrab(int index, X_Y_ANGLE_STRUCT& result);//中转台拍照,返回拍照结果,拍照结果仅用于拾取偏移,不存储
  77. //virtual LONG MoveToPickPos();//移动到拾取位,未拍照
  78. virtual LONG PickDie(int index);//拍照,取晶,并上行到上视拍照位,主要用于自动流程
  79. virtual LONG PickDieDown(int index, X_Y_ANGLE_STRUCT result);//传入拍照结果进行拾取补偿偏移
  80. virtual LONG PickUpToGrabPos();
  81. virtual LONG PickDieUp(bool waitDone = true);//上行到安全位置
  82. //上视拍照
  83. virtual LONG XYZToLookUpGrabPos();
  84. virtual LONG LookUpGrab(int index,X_Y_ANGLE_STRUCT& result);//移动到上视拍照位,拍照结果放到结构体中
  85. LONG MoveToLookUpAndGrab(int index, X_Y_ANGLE_STRUCT& result);
  86. //吸嘴固晶
  87. virtual LONG PlaceDie(int index, X_Y_ANGLE_STRUCT lookUpOffsetPixel) = 0;
  88. virtual LONG HeadMoveToBondPos(int index, bool bGrab = true, X_Y_ANGLE_STRUCT lookUpOffsetPixel = {0,0,0});//移动到拾取位
  89. virtual LONG CameraMoveToBondPos(int index, bool bGrab = true, X_Y_ANGLE_STRUCT lookUpOffsetPixel = { 0,0,0 });//移动到拾取位
  90. virtual LONG MoveToBondGrabPos(int index);
  91. virtual LONG BondGrab(int index, X_Y_ANGLE_STRUCT& result); //返回的拍照结果为物理单位
  92. virtual LONG ToBondPos_AddOffset(int index, X_Y_ANGLE_STRUCT bondOffset, X_Y_ANGLE_STRUCT lookUpOffset,bool bIsHard = true, bool waitDone = true);//传入物理位置
  93. virtual LONG BondDieDown(int index) = 0;//传入物理位置
  94. virtual LONG BondDieUp(bool waitDone = true);
  95. virtual LONG FindForce(double force); //寻压,寻找力控轴反馈位置
  96. virtual LONG UpdateForce(double dForce); //切换力的大小
  97. virtual LONG GetCurForceCurrentPercent(short& current);
  98. virtual LONG GetCurForce(double& force);
  99. virtual LONG Sync();
  100. //virtual LONG PickHightTest();
  101. //virtual LONG BondHighTest();
  102. //标定
  103. //virtual LONG HighCameraCTDCalib() { return OK; }
  104. virtual LONG LowCameraPosCalib();
  105. virtual LONG LowCTDNozzlePosCalib();
  106. virtual LONG CalLowCTDResult();
  107. virtual LONG HighCameraPosCalib() { return OK; };
  108. virtual LONG HighCTDNozzlePosCalib() { return OK; };
  109. virtual LONG CalHighCTDResult() { return OK; };
  110. virtual LONG NozzleRotCenterCalib();
  111. virtual LONG LowCameraXYCalib();
  112. virtual LONG HighCameraXYCalib() { return OK; };
  113. virtual LONG LookUpCameraXYCalib();
  114. //创建流程模板
  115. virtual LONG CreatePickTemp(int dieIndex);
  116. virtual LONG CreateLookUpTemp(int dieIndex);
  117. virtual LONG CreateBondTemp(int dieIndex);
  118. //力控标定
  119. virtual LONG SpringForceCalib();
  120. virtual LONG CurrentForceCalib();
  121. //创建标定模板
  122. virtual LONG CreateLowCameraCalibTemp();
  123. virtual LONG CreateHighCameraCalibTemp();
  124. virtual LONG CreateLookUpCameraCalibTemp();
  125. virtual LONG CreateRCalibTemp();
  126. virtual LONG CreateCTDLookUpCameraTemp();
  127. virtual LONG CreateCTDLowCameraTemp();
  128. virtual LONG CreateHighCameraCTDTemp();
  129. virtual LONG CreateCTDTipTemp();
  130. //相机吸嘴位置切换
  131. virtual LONG LowCameraToHead();
  132. virtual LONG HeadToLowCamera();
  133. virtual LONG HighCameraToHead();
  134. virtual LONG HeadToHighCamera();
  135. //力控测试
  136. virtual LONG ForceTest();
  137. //创建流程模板
  138. //virtual LONG CreatePickTemp();
  139. //virtual LONG CreateLookUpTemp();
  140. //virtual LONG CreateBondTemp();
  141. protected:
  142. BOND_PARAM m_stBondParam;
  143. CBondMatrix* m_pBondMatrix = nullptr;
  144. CForceControl* m_pForceControl = nullptr;
  145. CTransferTable* m_pWaferTransferTable = nullptr;
  146. CTransferTable* m_pWaffleTransferTable = nullptr;
  147. CNozzleTable* m_pNozzleTable = nullptr;
  148. CCameraBase* m_pLowCamera = nullptr;
  149. CAxis* m_pXAxis = nullptr;
  150. CAxis* m_pYAxis = nullptr;
  151. CAxis* m_pZAxis = nullptr;
  152. CAxis* m_pRAxis = nullptr;
  153. //CAxis* m_pForcerZ = nullptr;
  154. CIO* m_pForcerDo = nullptr;
  155. CIO* m_pForcerAO = nullptr;
  156. CIO* m_pBDVacGpo = nullptr;
  157. CIO* m_pBDFlowGpo = nullptr;
  158. CIO* m_pBDVacGpi = nullptr;
  159. CIO* m_pBDFlowGpi = nullptr;
  160. CIO* m_pForceScale = nullptr;
  161. CCoord* m_pCoord_XY = nullptr;
  162. CCameraBase* m_pLookUpCamera = nullptr;
  163. CXYCalib* m_pLookUpXYCalib = nullptr;//上视相机XY标定
  164. CXYCalib* m_pLowXYCalib = nullptr;
  165. CRCalib* m_pRCalib = nullptr;
  166. CCTDCalib* m_pLowCTDCalib = nullptr;
  167. CPRStrategy* m_pPR = nullptr;
  168. TipMatrix* m_pTipMatrix = nullptr;
  169. //位置参数
  170. double m_dSafePosX = 0;//安全位置
  171. double m_dSafePosY = 0;
  172. double m_dSafePosZ = 0;
  173. double m_dInitPosR = 0;
  174. double m_dPickGrabPosX = 0; //取晶位置
  175. double m_dPickGrabPosY = 0;
  176. double m_dPickGrabPosZ = 0; //拾取拍照位
  177. double m_dLookUpGrabPosX = 0;
  178. double m_dLookUpGrabPosY = 0;
  179. double m_dLookUpGrabPosZ = 0;
  180. double m_dPreChangeNozzleDisY = 0;//预更换吸嘴偏差位置
  181. double m_dNozzlePosZ = 0; //吸嘴架位置Z
  182. //统计参数
  183. int m_nTipUsedNum = 0;
  184. int m_nTipUsedMaxNum = 0;
  185. int m_nCurNozzleIndex = 0; //当前吸嘴在吸嘴架上的编号
  186. //int nCurrBondHeadIdByTable; //当前使用的吸嘴在吸嘴台上编号
  187. //XY_DOUBLE_STRUCT stCalibTableBondPosition; //校准台固晶位置
  188. //double m_dPressDistance = 0; //压合距离,修改为反馈位置
  189. double m_dPickVel = 0; //慢速
  190. double m_dSearchForce = 0;
  191. double m_dHoldForce = 0; //保持力
  192. double m_dPickSearchPosZ = 0;//拾取高度测试搜索位置
  193. double m_dBondSearchPosZ = 0;//固晶高度测试搜索位置
  194. //double m_dNozzlePosY = 0;//吸嘴架位置Y
  195. double m_dNozzleTableOriginPosX = 0;
  196. double m_dNozzleTableOriginPosY = 0;
  197. int m_nPickHTestDieIndex = 1;
  198. int m_nBondHTestDieIndex = 1;
  199. bool m_bIsLocationAll = false; //用于固晶时补偿可选全部拍照补偿或者每个PCB只拍一次
  200. double m_dGivenForceZPos = 0; //拾取放置芯片时力控轴的反馈位置
  201. double m_dBondGrabPosZ = 0; //bondGrabPosZ
  202. bool m_bAngleOffsetEnabled = false;
  203. };