CBondHead.h 9.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313
  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. virtual void SetHighCamera(CCameraBase* camera) {}
  40. virtual void SetLowCamera(CCameraBase* camera) { m_pLowCamera = camera; }
  41. virtual CXYCalib* GetLowCameraCalib() { return m_pLowXYCalib; }
  42. virtual CXYCalib* GetHighCameraCalib() { return nullptr; }
  43. virtual CCTDCalib* GetLowCTDCalib() { return m_pLowCTDCalib; }
  44. //void SetForceControl(CForceControl* force) { m_pForceControl = force; }
  45. CForceControl* GetForceControl() { return m_pForceControl; }
  46. CXYCalib* GetLookUpCameraCalib() { return m_pLookUpXYCalib; }
  47. CRCalib* GetHeadRCalib() { return m_pRCalib; }
  48. bool GetIsLocationAll() { return m_bIsLocationAll; }
  49. virtual LONG ToHome();
  50. virtual LONG ToSafePosition();
  51. virtual LONG GetParam();
  52. LONG XYMove(double x, double y, bool bSync = true);
  53. LONG XYMoveTo(double x,double y, bool bSync = true);
  54. LONG XYZMoveTo(double x, double y,double z);
  55. LONG XYZRMoveTo(double x, double y, double z,double r);
  56. #pragma region 自动流程
  57. virtual LONG MoveToPickGrabPos(bool waitDone = true);
  58. virtual LONG PickDie(int index);//拍照,取晶,并上行到上视拍照位,主要用于自动流程
  59. virtual LONG XYZToLookUpGrabPos(); //注意Z轴 去安全位置
  60. virtual LONG LookUpGrab(int index, X_Y_ANGLE_STRUCT& result);//移动到上视拍照位,拍照结果放到结构体中
  61. virtual LONG MoveToBondGrabPos(int index, XY_DOUBLE_STRUCT grabPosOffset = { 0,0 });
  62. virtual LONG BondGrab(int index, X_Y_ANGLE_STRUCT& result); //返回的拍照结果为物理单位
  63. virtual LONG PcbAln(); //Pcb对点
  64. virtual LONG ToBondPos_AddOffset(int index, X_Y_ANGLE_STRUCT bondOffset, X_Y_ANGLE_STRUCT lookUpOffset, bool waitDone = true);//传入物理位置
  65. virtual LONG BondDieDown(int index) = 0;//传入物理位置
  66. virtual LONG BondDieUp(bool waitDone = true);
  67. #pragma endregion
  68. #pragma region 手动流程
  69. int GetCurBondDieIndex() { return m_nCurBondDieIndex; }
  70. virtual LONG PlaceDie(int index, X_Y_ANGLE_STRUCT lookUpOffsetPixel) = 0;
  71. virtual LONG HeadMoveToBondPos(int index, bool bGrab = true, X_Y_ANGLE_STRUCT lookUpOffsetPixel = { 0,0,0 });//移动到拾取位,带补偿
  72. virtual LONG CameraMoveToBondPos(int index, bool bGrab = true);
  73. virtual LONG ToBondGrabPos_AddOffset(int index, X_Y_ANGLE_STRUCT bondOffset, bool waitDone = true);
  74. #pragma endregion
  75. LONG MoveToPreBondGrabPoint();
  76. LONG MoveToNextBondGrabPoint();
  77. virtual LONG VacuumOn(long lDelay); //真空开,真空延时,ms
  78. virtual LONG VacuumOff(long lDelay); //真空关,吹汽延时,ms
  79. virtual LONG StrongOn(); //强吹开
  80. virtual LONG StrongOff(); //强吹关
  81. virtual LONG UltraOn() { return OK; }; //超声开
  82. virtual LONG UltraOff() { return OK; }; //超声关
  83. virtual LONG ChangeNozzle(int nozzleIndex);
  84. virtual LONG UnLoadNozzle();
  85. virtual LONG LoadNozzle(int nozzleIndex);
  86. virtual LONG CheckDieExistStatus(bool& bExist);
  87. virtual LONG MoveLowCameraToNozzle();
  88. virtual LONG MoveNozzleToLowCamera();
  89. //吸嘴取晶
  90. virtual LONG PickGrab(int index, X_Y_ANGLE_STRUCT& result);//中转台拍照,返回拍照结果,拍照结果仅用于拾取偏移,不存储
  91. virtual LONG PickDieDown(int index, X_Y_ANGLE_STRUCT result);//传入拍照结果进行拾取补偿偏移
  92. virtual LONG PickUpToGrabPos();
  93. virtual LONG PickDieUp(bool waitDone = true);//上行到安全位置
  94. //上视拍照
  95. LONG MoveToLookUpAndGrab(int index, X_Y_ANGLE_STRUCT& result);
  96. //吸嘴固晶
  97. //virtual LONG CameraMoveToBondPos(int index, bool bGrab = true, X_Y_ANGLE_STRUCT lookUpOffsetPixel = { 0,0,0 });//移动到拾取位,带补偿,可用于观察补偿值是否正确
  98. //virtual LONG ToBondGrabPos_AddOffset(int index, X_Y_ANGLE_STRUCT bondOffset, X_Y_ANGLE_STRUCT lookUpOffset, bool waitDone = true);//传入物理位置
  99. virtual LONG BondCheck(int index) { return OK; };
  100. virtual LONG FindForce(double force); //寻压,寻找力控轴反馈位置
  101. virtual LONG UpdateForce(double dForce); //切换力的大小
  102. virtual LONG GetCurForceCurrentPercent(short& current);
  103. virtual LONG GetCurForce(double& force);
  104. virtual LONG Sync();
  105. //virtual LONG PickHightTest();
  106. //virtual LONG BondHighTest();
  107. //标定
  108. //virtual LONG HighCameraCTDCalib() { return OK; }
  109. virtual LONG LowCameraPosCalib();
  110. virtual LONG LowCTDNozzlePosCalib();
  111. virtual LONG CalLowCTDResult();
  112. virtual LONG HighCameraPosCalib() { return OK; };
  113. virtual LONG HighCTDNozzlePosCalib() { return OK; };
  114. virtual LONG CalHighCTDResult() { return OK; };
  115. virtual LONG NozzleRotCenterCalib();
  116. virtual LONG LowCameraXYCalib();
  117. virtual LONG HighCameraXYCalib() { return OK; };
  118. virtual LONG LookUpCameraXYCalib();
  119. //创建模板
  120. virtual LONG CreateLowCameraTemp(UINT &iTemplateId);
  121. virtual LONG CreateHighCameraTemp(UINT& iTemplateId);
  122. virtual LONG CreateLookUpCameraTemp(UINT& iTemplateId);
  123. //创建流程模板
  124. virtual LONG CreateBondMatrixTemplate(BOND_MATRIX_TEMPLATE_TYPE eType, UINT iBondInfoId);
  125. virtual LONG CreatePrStrategy(vector<UINT> vecTemplateId);
  126. //力控标定
  127. virtual LONG SpringForceCalib();
  128. virtual LONG CurrentForceCalib();
  129. //创建标定模板
  130. virtual LONG CreateLowCameraCalibTemp();
  131. virtual LONG CreateHighCameraCalibTemp();
  132. virtual LONG CreateLookUpCameraCalibTemp();
  133. virtual LONG CreateRCalibTemp();
  134. virtual LONG CreateCTDLookUpCameraTemp();
  135. virtual LONG CreateCTDLowCameraTemp();
  136. virtual LONG CreateHighCameraCTDTemp();
  137. virtual LONG CreateCTDTipTemp();
  138. //相机吸嘴位置切换
  139. virtual LONG LowCameraToHead();
  140. virtual LONG HeadToLowCamera();
  141. virtual LONG HighCameraToHead();
  142. virtual LONG HeadToHighCamera();
  143. //力控测试
  144. virtual LONG ForceTest();
  145. //高度测试
  146. virtual void SetPickHTestIndex(int index);
  147. virtual void SetBondHTestIndex(int index);
  148. virtual LONG PickHightTest();//调用之前先SetIndex
  149. virtual LONG AllBondHighTest() = 0;
  150. virtual LONG BondHighTest();
  151. virtual LONG NozzleHighTest(int nozzleIndex);//index 比较难传?
  152. //创建流程模板
  153. //virtual LONG CreatePickTemp();
  154. //virtual LONG CreateLookUpTemp();
  155. //virtual LONG CreateBondTemp();
  156. //界面测试
  157. void ViewTest()
  158. {
  159. m_dSafePosZ++;
  160. m_pModuleConfigDB->SetConfigParam(ULTRAHEAD_TABLE_NAME ,*GetConfigVector());
  161. }
  162. protected:
  163. BOND_PARAM m_stBondParam;
  164. CBondMatrix* m_pBondMatrix = nullptr;
  165. CForceControl* m_pForceControl = nullptr;
  166. CTransferTable* m_pWaferTransferTable = nullptr;
  167. CTransferTable* m_pWaffleTransferTable = nullptr;
  168. CNozzleTable* m_pNozzleTable = nullptr;
  169. CCameraBase* m_pLowCamera = nullptr;
  170. CAxis* m_pXAxis = nullptr;
  171. CAxis* m_pYAxis = nullptr;
  172. CAxis* m_pZAxis = nullptr;
  173. CAxis* m_pRAxis = nullptr;
  174. //CAxis* m_pForcerZ = nullptr;
  175. CIO* m_pForcerDo = nullptr;
  176. CIO* m_pForcerAO = nullptr;
  177. CIO* m_pBDVacGpo = nullptr;
  178. CIO* m_pBDFlowGpo = nullptr;
  179. CIO* m_pBDVacGpi = nullptr;
  180. CIO* m_pBDFlowGpi = nullptr;
  181. CIO* m_pForceScale = nullptr;
  182. CCoord* m_pCoord_XY = nullptr;
  183. CCameraBase* m_pLookUpCamera = nullptr;
  184. CXYCalib* m_pLookUpXYCalib = nullptr;//上视相机XY标定
  185. CXYCalib* m_pLowXYCalib = nullptr;
  186. CRCalib* m_pRCalib = nullptr;
  187. CCTDCalib* m_pLowCTDCalib = nullptr;
  188. CPRStrategy* m_pPR = nullptr;
  189. TipMatrix* m_pTipMatrix = nullptr;
  190. //位置参数
  191. double m_dSafePosX = 0;//安全位置
  192. double m_dSafePosY = 0;
  193. double m_dSafePosZ = 0;
  194. double m_dInitPosR = 0;
  195. double m_dPickGrabPosX = 0; //取晶位置
  196. double m_dPickGrabPosY = 0;
  197. double m_dPickGrabPosZ = 0; //拾取拍照位
  198. double m_dLookUpGrabPosX = 0;
  199. double m_dLookUpGrabPosY = 0;
  200. double m_dLookUpGrabPosZ = 0;
  201. //double m_dBond
  202. double m_dBondGrabPosZ = 0; //bondGrabPosZ
  203. double m_dPreChangeNozzleDisY = 0;//预更换吸嘴偏差位置
  204. double m_dNozzlePosZ = 0; //吸嘴架位置Z
  205. //统计参数
  206. int m_nTipUsedNum = 0;
  207. int m_nTipUsedMaxNum = 0;
  208. int m_nCurNozzleIndex = 0; //当前吸嘴在吸嘴架上的编号
  209. //int nCurrBondHeadIdByTable; //当前使用的吸嘴在吸嘴台上编号
  210. //XY_DOUBLE_STRUCT stCalibTableBondPosition; //校准台固晶位置
  211. //double m_dPressDistance = 0; //压合距离,修改为反馈位置
  212. double m_dPickVel = 0; //慢速
  213. double m_dSearchForce = 0;
  214. double m_dHoldForce = 0; //保持力
  215. double m_dPickSearchPosZ = 0;//拾取高度测试搜索位置
  216. double m_dBondSearchPosZ = 0;//固晶高度测试搜索位置
  217. //double m_dNozzlePosY = 0;//吸嘴架位置Y
  218. double m_dNozzleTableOriginPosX = 0;
  219. double m_dNozzleTableOriginPosY = 0;
  220. int m_nPickHTestDieIndex = 1;
  221. int m_nBondHTestDieIndex = 1;
  222. bool m_bIsLocationAll = false; //用于固晶时补偿可选全部拍照补偿或者每个PCB只拍一次
  223. double m_dGivenForceZPos = 0; //拾取放置芯片时力控轴的反馈位置
  224. bool m_bAngleOffsetEnabled = false;
  225. double m_dNozzleHTestX = 0;
  226. double m_dNozzleHTestY = 0;
  227. double m_dNozzleHTestSearchPosZ = 0;
  228. //测高
  229. int m_nPickHNozzleIndex = 0;
  230. int m_nBondHNozzleIndex = 0;
  231. double m_dPickContactPosZ = 0; //拾取测高高度
  232. double m_dBondContactPosZ = 0; //固晶测高高度
  233. int m_nCurBondDieIndex = 0;
  234. };