CBondHead.h 9.6 KB

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