From 9c13bc5af33d28bb217995597f88fe863db42442 Mon Sep 17 00:00:00 2001 From: LYW <leeyeanwoo@diteam.co.kr> Date: 금, 01 4월 2022 10:59:55 +0900 Subject: [PATCH] AOI RawMessnger 동기화 --- DitGlassRawMessenger/DitGlassRawMessenger/GlassRawCPJT.cpp | 391 +++++++++++++++++++++++++++++++++++++++++++------------ 1 files changed, 306 insertions(+), 85 deletions(-) diff --git a/DitGlassRawMessenger/DitGlassRawMessenger/GlassRawCPJT.cpp b/DitGlassRawMessenger/DitGlassRawMessenger/GlassRawCPJT.cpp index 675e17c..fc064a2 100644 --- a/DitGlassRawMessenger/DitGlassRawMessenger/GlassRawCPJT.cpp +++ b/DitGlassRawMessenger/DitGlassRawMessenger/GlassRawCPJT.cpp @@ -30,6 +30,12 @@ #define NETWORK_MURARAW_PATH "\\\\126.100.100.1\\d\\DIT_ResultData\\Mura\\RAW" //0405nwh #define NETWORK_MURA_IMAGE_PATH "\\\\126.100.100.1\\d\\DIT_ResultData\\Mura\\IMG" //0405nwh +//KYH Stack Local 寃쎈줈 異붽� +#define NETWORK_AOISTACKLOCAL_PATH "\\\\126.100.100.1\\d\\DIT_ResultData\\Stack" + /* <LJC 20211122 : #3820 ADD Start> */ +#define NETWORK_AOIRAWMERGELOCAL_PATH "D:\\DIT_ResultData\\RawMerge" + /* <LJC 20211122 : #3820 ADD End> */ + char* g_pCellCode = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"; void _TimeDelay(int delay) @@ -37,9 +43,9 @@ MSG msg; BOOL fRst = FALSE; - clock_t lBlockTime = delay + clock(); + ULONGLONG lBlockTime = delay + GetTickCount64(); - while (lBlockTime > clock()) + while (lBlockTime > GetTickCount64()) { fRst = (BOOL)PeekMessage(&msg, NULL, 0, 0, PM_REMOVE); if (fRst) @@ -70,15 +76,51 @@ BOOL CGlassRawCPJT::SequenceGlassLoading( CgrmGlassRawData* pData ) { - //�뒪�깮湲곕뒫 + SetEnableFtpAck(FALSE); + m_nRawMergeIdx = 0; if(m_StackResult.getStackUse()) { + + CString strStackFileLocalPath; + strStackFileLocalPath.Format("%s\\%s", NETWORK_AOISTACKLOCAL_PATH, pData->GetGlassData()->m_strGlassID); + + CFileFind File; + + if (File.FindFile(strStackFileLocalPath)) + { + File.FindNextFile(); + strStackFileLocalPath = File.GetFilePath(); + DeleteFile(strStackFileLocalPath); + Sleep(10); + } + else + { + AKLOG("Delete Stack File Fail [%s]", strStackFileLocalPath); + } + + //201218 CJH - Stack Download �떆�룄 SendMessageFTPDownloadStack(pData->GetGlassData()); - m_StackResult.StackFileReadStart(pData->GetGlassData()->m_strGlassID); } - + /* <LJC 20211122 : #3820 ADD Start> */ + if (pData->GetGlassData()->m_bRawMergeUse) + { + CString strRawFileLocalPath; + strRawFileLocalPath.Format("%s\\%s", NETWORK_AOIRAWMERGELOCAL_PATH, pData->GetGlassData()->m_strGlassID); + CFileFind File; + if (File.FindFile(strRawFileLocalPath)) + { + File.FindNextFile(); + strRawFileLocalPath = File.GetFilePath(); + DeleteFile(strRawFileLocalPath); + Sleep(10); + } + SetEnableFtpAck(TRUE); + DownLoadMergeFile(pData); + } + /* <LJC 20211122 : #3820 ADD End> */ + /*< KJG 20211024 - #3487 ADD End >*/ return TRUE; } @@ -106,11 +148,14 @@ } strcpy(pData->GetGlassData()->m_strPath, LOCAL_AOIRAWBIN_PATH); + if(!WriteBinFile(pData)) return FALSE; - if (1) ReadMuraFile(pData); + + //if(1) ReadMuraFile(pData); 211012 KJG - QD Macro 媛쒕퀎 �뾽濡쒕뱶 �븯誘�濡� Macro �뜲�씠�꽣 �쟻�젣 �젣嫄� �슂泥� + if (WriteAOIFile(pData) == FALSE) return FALSE; @@ -118,7 +163,60 @@ _TimeDelay(5000); // �씠誘몄� 蹂듭궗 �떆媛� ��湲� //210218 CJH - 寃��궗 醫낅즺�떆 寃곌낵�뙆�씪 諛� CCD Image �뾽濡쒕뱶 SendMessageFTPUploadRaw(pData->GetGlassData()); - SendMessageFTPUploadImage(pData->GetGlassData(), FTPCMD_AOI_IMAGE); + + /* <KYH 211129 : #3806 ADD Start> */ + char pServerPath[256] = {}; + char pServerFile[256] = {}; + + CString strGlassID = pData->GetGlassData()->m_strGlassID; + CString strGlassIDLevel6th = strGlassID.Left(6); + CString strStepID = pData->GetGlassData()->m_strStepID; + CString strProcessID = pData->GetGlassData()->m_strProcessID; + CString strFileName; + + strcpy(pServerFile, "*.*"); + + strFileName.Format("%s", strGlassID); + strFileName.MakeLower(); + + sprintf(pServerFile, "%s", strFileName.GetBuffer(0)); + + strStepID.MakeLower(); + strGlassID.MakeLower(); + strGlassIDLevel6th.MakeLower(); + strProcessID.MakeLower(); + +// if (strGlassID.GetLength() > 6) +// sprintf(pServerPath, "\\%s\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th, strGlassID); +// else + sprintf(pServerPath, "\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th); + /* <KYH 211129 : #3806 ADD End> */ + + + BOOL bIsBDI = strcmp((pData->GetGlassData()->m_strLine), _T("BDI")) == 0 ? TRUE : FALSE; + if (bIsBDI) + { + SendMessageFTPUploadImage(pData->GetGlassData(), FTPCMD_AOI_IMAGE); + + /* <KYH 211129 : #3806 ADD Start> */ + CString strRawFilePathName = NULL; + CString strLine = NULL; + strRawFilePathName += LOCAL_RAWPATH_INFO_INI_PATH; + strRawFilePathName += RAWINFO_FILE_NAME; + FILE* pf = fopen(strRawFilePathName.GetBuffer(0), "w"); + if (pf != NULL) + { + strLine = pServerPath + strFileName; + fprintf(pf, "[RESULT_PATH]\n"); + fprintf(pf, "RAWPATH= X:\%s\n", strLine.GetBuffer(0)); + SetRawFilePath(strLine.GetBuffer(0)); + fprintf(pf, "SUMPATH= \n"); + fprintf(pf, "IMGPATH= Z:\%s\n", strLine.GetBuffer(0)); + fprintf(pf, "DISK=FILESERVER\n"); + fclose(pf); + } + } + /* <KYH 211129 : #3806 ADD End> */ SendMessageFTPUploadImage(pData->GetGlassData(), FTPCMD_MURA_IMAGE);//0405nwh return TRUE; @@ -204,6 +302,8 @@ strcpy(pData->GetGlassData()->m_strPath, LOCAL_AOIRAWBIN_PATH); + pData->GetGlassData()->m_tmReviewLoading = m_tmReviewStart; + return TRUE; } @@ -213,12 +313,13 @@ m_bReviewEndCheck = TRUE; m_tmReviewEnd = m_tmReviewStart = CTime::GetCurrentTime(); m_tmFileCreateTime = CTime::GetCurrentTime(); + pData->GetGlassData()->m_tmReviewEnd = m_tmReviewEnd; //�뿬湲곗뿉�꽌 �씪�씤蹂꾨줈 �뙆�씪紐�, �샊�� Path �쐞移� 寃곗젙�븯硫대맖. AOIServer �샊�� ReviewServer�뿉�꽌 �븞�빐�룄�맖 [源��깭�쁽2019/9/4] pData->GetGlassData()->m_strFileName; strcpy(pData->GetGlassData()->m_strPath, NETWORK_AOIRAWDFS_PATH); - if(1) ReadMuraFile(pData); + //if(1) ReadMuraFile(pData); 211012 KJG - QD Macro 媛쒕퀎 �뾽濡쒕뱶 �븯誘�濡� Macro �뜲�씠�꽣 �쟻�젣 �젣嫄� �슂泥� if(WriteAOIFile(pData) == FALSE) return FALSE; @@ -338,6 +439,7 @@ BOOL CGlassRawCPJT::MakeAOIFile( CgrmGlassRawData* pData ) { + AKLOG("MakeAOIFile Start"); m_nWriteRawDefectIdx = 1; _grmGlassData* pGlass = pData->GetGlassData(); @@ -353,7 +455,7 @@ } strFilePathName.Format("%s\\%s", pGlass->m_strPath, strFileName);//pGlass->m_strFileName); - //strFilePathName.Format("C:\\AOIServer\\NFS\\RAW\\%s", pData->GetGlassData()->m_strFileName); + //strFilePathName.Format("D:\\AOIServer\\NFS\\RAW\\%s", pData->GetGlassData()->m_strFileName); // 湲��씪�뒪 ID留� 議댁옱�븯�뿬 �옱寃��궗 �떆 �뙆�씪 �깮�꽦 �떎�뙣. �궘�젣�븳�떎 DeleteFile(strFilePathName); @@ -381,7 +483,10 @@ ////////////////////////////////////////////////////////////////////////// //GLASSDATA { - makeDataGlass(strLine, pGlass); + /*< KJG 20211229 - #3846 MOD Start >*/ + //makeDataGlass(strLine, pGlass); + makeDataGlass(strLine, pData, pGlass); + /*< KJG 20211229 - #3846 MOD End >*/ fprintf(pf, "%s\n", strLine.GetBuffer(0)); } @@ -427,21 +532,24 @@ { strLine.Empty(); CString strValue; - - strValue = "ITEM PANEL MODULETYPE MODULEID PROCESSID PRODUCTID STEPID PROD_TYPE BATCHID H_PANELID E_PANELID P_PANELID OPERID COMP_COUNT PPID GRADE CODE R_GRADE MAP_IMAGE L_TIME U_TIME S_TIME E_TIME T_DEFECT TR PR TB TW RB RW T_STACK MAX_AVG_GRAY MAX_PORTION OK_CELL RJ_CELL RW_CELL NR_CELL CSTID SLOT_NO JOB_END TD_DEFECT SD_DEFECT PD_DEFECT SP_DEFECT PAD_GATE PAD_DATA M_DEFECT C_DEFECT BR_DEFECT IMG_COUNT RECIPE SHRINK RAW_CUT"; //53ea + /*< KJG 20211229 - #3846 MOD Start >*/ + //strValue = "ITEM PANEL MODULETYPE MODULEID PROCESSID PRODUCTID STEPID PROD_TYPE BATCHID H_PANELID E_PANELID P_PANELID OPERID COMP_COUNT PPID GRADE CODE R_GRADE MAP_IMAGE L_TIME U_TIME S_TIME E_TIME T_DEFECT TR PR NG TB TW RB RW T_STACK NO_DEFECT MAX_AVG_GRAY MAX_PORTION OK_CELL RJ_CELL RW_CELL NR_CELL CSTID SLOT_NO JOB_END TD_DEFECT SD_DEFECT PD_DEFECT SP_DEFECT PAD_GATE PAD_DATA M_DEFECT C_DEFECT LN_DEFECT IMG_COUNT RECIPE SHRINK RAW_CUT CRACK_DEFECT"; + strValue = "ITEM PANEL MODULETYPE MODULEID PROCESSID PRODUCTID STEPID PROD_TYPE BATCHID H_PANELID E_PANELID P_PANELID OPERID COMP_COUNT PPID GRADE CODE R_GRADE MAP_IMAGE L_TIME U_TIME S_TIME E_TIME T_DEFECT TR PR NG TB TW RB RW T_STACK NO_DEFECT MAX_NG MAX_PORTION OK_CELL RJ_CELL RW_CELL NR_CELL CSTID SLOT_NO JOB_END TD_DEFECT SD_DEFECT PD_DEFECT SP_DEFECT PAD_GATE PAD_DATA M_DEFECT C_DEFECT LN_DEFECT IMG_COUNT RECIPE SHRINK RAW_CUT CRACK_DEFECT"; //56ea + /*< KJG 20211229 - #3846 MOD End >*/ strLine += strValue; strLine += "\n"; - strValue = "ITEM SUBPANEL SUBPANELID COORD_X COORD_Y SIZE_X SIZE_Y GATELINE DATALINE GRADE CODE R_GRADE T_DEFECT TD_DEFECT SD_DEFECT PD_DEFECT SP_DEFECT PAD_GATE PAD_DATA M_DEFECT C_DEFECT PRO_IMAGE AVG_GRAY PORTION"; //24ea result 0404nwh �궘�젣 : S_DEFECT CRACK P_SHIFT + strValue = "ITEM SUBPANEL SUBPANELID COORD_X COORD_Y SIZE_X SIZE_Y GATELINE DATALINE GRADE CODE R_GRADE T_DEFECT TD_DEFECT SD_DEFECT PD_DEFECT SP_DEFECT PAD_GATE PAD_DATA M_DEFECT C_DEFECT LN_DEFECT TR PR NG RB RW TB TW T_STACK NO_DEFECT"; //31ea /* <KYH 211129 : #3796 MOD Start> */ strLine += strValue; strLine += "\n"; - //210405 - //ITEM DEFECT ID DEF_NO COORD_X COORD_Y GATELINE DATALINE SIZE_S SIZE_W SIZE_L SIZE_H GRADE CODE STACK_FLAG STACK_COUNT STACK_STEP IMAGE_FILE DSC_CODE VC_CODE DCR_CODE DEFECT_SIZE REPEAT_DEFECT WSI_HEIGHT CS_HEIGHT C_GRADE GRAY_MIN GRAY_MAX GRAY_AVG GRAY_DEF WSI_IMAGE USE_CCDIMAGE SCAN_NUM CAM_POSITION CCD_NO R_GRAY_MIN R_GRAY_MAX R_GRAY_AVG SCAN_AI REVIEW_AI INS_MODE INS_CHANNEL COMPACTNESS THICKNESS MAJOR MINOR WSI_TYPE DEFECT_TYPE SHRINK - strValue = "ITEM DEFECT ID DEF_NO COORD_X COORD_Y GATELINE DATALINE SIZE_S SIZE_W SIZE_L SIZE_H GRADE CODE STACK_FLAG STACK_COUNT STACK_STEP IMAGE_FILE DSC_CODE VC_CODE DCR_CODE DEFECT_SIZE REPEAT_DEFECT WSI_HEIGHT CS_HEIGHT C_GRADE GRAY_MIN GRAY_MAX GRAY_AVG GRAY_DEF WSI_IMAGE USE_CCDIMAGE SCAN_NUM CAM_POSITION CCD_NO R_GRAY_MIN R_GRAY_MAX R_GRAY_AVG R_HEIGHT G_HEIGHT B_HEIGHT INS_CHANNEL COMPACTNESS THICKNESS MAJOR MINOR WSI_TYPE DEFECT_TYPE SHRINK"; //49ea + strValue = "ITEM DEFECT ID DEF_NO COORD_X COORD_Y GATELINE DATALINE SIZE_S SIZE_W SIZE_L SIZE_H GRADE CODE STACK_FLAG STACK_COUNT STACK_STEP IMAGE_FILE LINE_CODE VC_CODE DCR_CODE DEFECT_SIZE REPEAT_DEFECT WSI_HEIGHT CS_HEIGHT C_GRADE GRAY_MIN GRAY_MAX GRAY_AVG GRAY_DEF WSI_IMAGE USE_CCDIMAGE SCAN_NUM CAM_POSITION CCD_NO R_GRAY_MIN R_GRAY_MAX R_GRAY_AVG R_HEIGHT G_HEIGHT B_HEIGHT INS_CHANNEL COMPACTNESS THICKNESS MAJOR MINOR WSI_TYPE DEFECT_TYPE SHRINK CLASS_CODE"; //50ea strLine += strValue; } #define SPRINTRAWSTART char strItemValue[1024];int nItemValueLen, nItemValuePos = 0;memset(strItemValue, ' ', sizeof(char)*1024) #define SPRINTRAW(ITEMSIZE, fmt, ...) nItemValueLen = sprintf(strItemValue+nItemValuePos, fmt,##__VA_ARGS__); strItemValue[nItemValuePos+ nItemValueLen] = ' ';nItemValuePos+=ITEMSIZE+1 #define SPRINTRAWEND strItemValue[nItemValuePos - 1] = 0; strLine = strItemValue -void CGlassRawCPJT::makeDataGlass( CString& strLine, _grmGlassData* pGlassData ) +/*< KJG 20211229 - #3846 MOD Start >*/ +//void CGlassRawCPJT::makeDataGlass( CString& strLine, _grmGlassData* pGlassData ) +void CGlassRawCPJT::makeDataGlass( CString& strLine, CgrmGlassRawData* pData, _grmGlassData* pGlassData ) +/*< KJG 20211229 - #3846 MOD End >*/ { SPRINTRAWSTART; @@ -496,7 +604,7 @@ 46 12 PAD_DATA // PAD Data 遺덈웾 �닔 47 12 M_DEFECT // MASK 遺덈웾 �닔 48 12 C_DEFECT // COMMON 遺덈웾 - 49 12 BR_DEFECT // SCRATCH 遺덈웾 �닔 + 49 12 BR_DEFECT // SCRATCH 遺덈웾 �닔 => LN_DEFECT // �씪�씤�꽦 遺덈웾 �닔 50 12 CRACK // Crack 遺덈웾 �닔 - Image 珥ъ긽 媛��닔 51 12 P_SHIFT // Pattern Shift 遺덈웾 �닔 - �젅�떆�뵾 �씠由� */ @@ -687,29 +795,56 @@ SPRINTRAW(12, "%d", pGlassData->m_nDefectNumJudgeTR); // 26 6 PR // Panel �젙蹂� 03 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumJudgePR); - // 27 6 TB // Panel �젙蹂� 04 + // 27 6 NG // Panel �젙蹂� 04 + SPRINTRAW(12, "%d", pGlassData->m_nDefectNumJudgeNG); /* <KYH 211129 : #3796 ADD Start> */ + // 28 6 TB // Panel �젙蹂� 04 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumTypeTB); - // 28 6 TW // Panel �젙蹂� 05 + // 29 6 TW // Panel �젙蹂� 05 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumTypeTW); - // 29 6 RB // Panel �젙蹂� 06 + // 30 6 RB // Panel �젙蹂� 06 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumTypeRB); - // 30 6 RW // Panel �젙蹂� 07 + // 31 6 RW // Panel �젙蹂� 07 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumTypeRW); - // 31 6 T_STACK // Panel �젙蹂� 08 SD+SP �닔 �엯�젰 + // 32 6 T_STACK // Panel �젙蹂� 08 SD+SP �닔 �엯�젰 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumStackSD + pGlassData->m_nDefectNumStackSP); - //32 6 BMDF // Panel �젙蹂� 09 -> 蹂�寃� MAX_AVG_GRAY 04/12 nwh - SPRINTRAW(12, "%5.4f", pGlassData->m_fMaxAvgGray); - // 33 6 CJ // Panel �젙蹂� 10 -> 蹂�寃� MAX_PORTION 04/12 nwh - SPRINTRAW(12, "%5.6f", pGlassData->m_fMaxPortion); - // 34 6 OK_CELL // OK Cell Count + // 33 6 NO_DEFECT // Panel �젙蹂� 09 + SPRINTRAW(12, "%d", pGlassData->m_nDefectNumJudgeND); /* <KYH 211129 : #3796 ADD Start> */ + //34 6 BMDF // Panel �젙蹂� 10 -> 蹂�寃� MAX_AVG_GRAY 04/12 nwh + /*< KJG 20211229 - #3846 MOD Start >*/ + //if (strlen(pGlassData->m_strMaxAvgGray) == 0) + //{ + // SPRINTRAW(12, "*"); + //} + //else + //{ + // SPRINTRAW(12, "%s", pGlassData->m_strMaxAvgGray); + //} + int nMaxCellNG = 0; + for (int iCell = 0; iCell < pData->GetGlassData()->m_nCellNum; iCell++) + { + _grmCellData* pCell = pData->GetCellData(iCell); + nMaxCellNG = max(nMaxCellNG, pCell->m_nDefectNumJudgeNG); + } + SPRINTRAW(12, "%d", nMaxCellNG); + /*< KJG 20211229 - #3846 MOD End >*/ + // 35 6 CJ // Panel �젙蹂� 11 -> 蹂�寃� MAX_PORTION 04/12 nwh + if (strlen(pGlassData->m_strMaxPortion) == 0) + { + SPRINTRAW(12, "*"); + } + else + { + SPRINTRAW(12, "%s", pGlassData->m_strMaxPortion); + } + // 36 6 OK_CELL // OK Cell Count SPRINTRAW(12, "*"); - // 35 6 RJ_CELL // RJ Cell Count + // 37 6 RJ_CELL // RJ Cell Count SPRINTRAW(12, "*"); - // 36 6 RW_CELL // RW Cell Count + // 38 6 RW_CELL // RW Cell Count SPRINTRAW(12, "*"); - // 37 6 NR_CELL // NR Cell Count + // 39 6 NR_CELL // NR Cell Count SPRINTRAW(12, "*"); - // 38 6 MASK_CELL // MASK Cell Count //201215 CJH - CSTID濡� 蹂�寃� + // 40 6 MASK_CELL // MASK Cell Count //201215 CJH - CSTID濡� 蹂�寃� if (strlen(pGlassData->m_strCSTID) == 0) { SPRINTRAW(12, "*"); @@ -739,8 +874,12 @@ SPRINTRAW(12, "%d", pGlassData->m_nDefectNumTypeMD); // 48 6 C_DEFECT // COMMON 遺덈웾 SPRINTRAW(12, "%d", pGlassData->m_nDefectNumTypeCD); + /*< LHS 20211029 - #3783 MOD Start >*/ // 49 6 S_DEFECT // SCRATCH 遺덈웾 �닔 - SPRINTRAW(12, "*"); + //SPRINTRAW(12, "*"); + // 49 6 LN_DEFECT // Line 遺덈웾 �닔 + SPRINTRAW(12, "%d", pGlassData->m_nDefectNumJudgeLine); + /*< LHS 20211029 - #3783 MOD End >*/ // 50 6 CRACK // Crack 遺덈웾 �닔 //201217 CJH - Image 珥ъ긽 媛쒖닔濡� 蹂�寃� //SPRINTRAW(12, "%d", pGlassData->m_nDefectNumLocCrack); SPRINTRAW(12, "%d", pGlassData->m_nReviewNum); @@ -749,10 +888,17 @@ { SPRINTRAW(16, "*"); } - else + else if(strlen(pGlassData->m_strRecipeName) <= 16) { SPRINTRAW(16, "%s", pGlassData->m_strRecipeName); } + else if (strlen(pGlassData->m_strRecipeName) > 16) + { + CString temp = pGlassData->m_strRecipeName; // �젅�떆�뵾 17�옄由� �꽆�뼱媛�硫� DCOLL 諛쒖깮�쑝濡� �삁�쇅泥섎━ [ 21-06-02 KJG ] + temp = temp.Left(16); + SPRINTRAW(16, "%s", temp.GetBuffer(0)); + } + // 52 12 SHRINK // Server or Frame Shrink �룞�옉 �뿬遺� if (strlen(pGlassData->m_strShrinked) == 0) { @@ -766,6 +912,15 @@ if (pGlassData->m_bRawCutoff) { SPRINTRAW(12, "USE"); + } + else + { + SPRINTRAW(12, "UNUSE"); + } + + if (pGlassData->m_bEdgeCrackUse) + { + SPRINTRAW(12, "%d", pGlassData->m_nDefectNumLocCrack); } else { @@ -801,7 +956,7 @@ 19 12 PAD_DATA // PAD Data Defect Count 20 12 M_DEFECT // MASK Defect Count 21 12 C_DEFECT // COMMON Defect Count - 22 12 S_DEFECT // SCRATCH Defect Count + 22 12 S_DEFECT // SCRATCH Defect Count ==> LN_DEFECT 23 12 CRACK // CRACK Defect Count 24 12 P_SHIFT // Pattern Shift Defect Count */ @@ -874,21 +1029,29 @@ // 21 6 C_DEFECT // COMMON Defect Count SPRINTRAW(12, "%d", pCellData->m_nDefectNumTypeCD); - // 22 6 S_DEFECT -> 22 6 PRO_IMAGE 蹂�寃� nwh0404 - if (strlen(pCellData->m_strProImage)) - { - SPRINTRAW(12, "%s", pCellData->m_strProImage); - } - else - { - SPRINTRAW(12,"*"); - } + /* <KYH 211129 : #3796 MOD Start> */ - // 23 6 CRACK -> 23 6 AVG_GRAY 蹂�寃� - SPRINTRAW(12, "%5.4f", pCellData->m_fAvgGray); - - // 24 6 P_SHIFT ->24 6 PORTION - SPRINTRAW(12, "%5.6f", pCellData->m_fPortion); + // 22 6 PRO_IMAGE -> LN_DEFECT 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumJudgeLine); + // 23 6 AVG_GRAY -> TR 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumJudgeTR); + // 24 6 PORTION -> PR 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumJudgePR); + // 25 6 CORNER_GRAY -> NG 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumJudgeNG); + // 26 6 AVG_AMP -> RB 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumTypeRB); + // 27 6 FFT_VAR -> RW 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumTypeRW); + // 28 6 TB 異붽� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumTypeTB); //KYH TB �뜲�씠�꽣 異붽� + // 29 6 TW 異붽� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumTypeTW); //KYH TW �뜲�씠�꽣 異붽� + // 30 6 FFT_VEH -> T_STACK 蹂�寃� + SPRINTRAW(12, "%d", pCellData->m_nDefectSDCount + pCellData->m_nDefectSPCount); + // 31 6 NO_DEFECT 異붽� + SPRINTRAW(12, "%d", pCellData->m_nDefectNumJudgeND); //KYH ND �뜲�씠�꽣 異붽� + /* <KYH 211129 : #3796 MOD End> */ SPRINTRAWEND; //以묒슂!!! �젮 留덉�留됱뿉 瑗� �엳�뼱�빞�븿!!!(�궘�젣湲덉�) [源��깭�쁽2020/9/23] } @@ -916,7 +1079,7 @@ // 16 2 STACK_COUNT // Count of Defect detected step // 17 60 STACK_STEP // Flow(Step) of defect detection // 18 16 IMAGE_FILE // Image file Name - // 19 12 DSC Code + // 19 12 DSC Code ==> LINE_CODE // 20 12 Image 遺꾨쪟 Code // 21 12 遺덈웾�씠 �쐞移섑븳 Zone No �엯�젰 // 22 12 遺덈웾 �겕湲� (L,H,M,S) @@ -1058,8 +1221,18 @@ { SPRINTRAW(16, "*"); } - // 19 12 DSC_CODE // Common 01 DSC Code + /*< LHS 20211029 - #3783 MOD Start >*/ + // 19 12 DSC_CODE // Common 01 DSC Code ==> LINE_CODE + if (strlen(pDefectData->m_strLNDefectCode)) + { + SPRINTRAW(12, "%s", pDefectData->m_strLNDefectCode); + } + else + { SPRINTRAW(12, "*"); + } + //SPRINTRAW(12, "*"); + /*< LHS 20211029 - #3783 MOD End >*/ // 20 12 VC_CODE // Common 02 Image 遺꾨쪟 Code SPRINTRAW(12, "*"); // 21 12 ZONE_NO // Common 03 遺덈웾�씠 �쐞移섑븳 Zone No �엯�젰 @@ -1073,6 +1246,7 @@ nValue = nValue << 1; } SPRINTRAW(12, "%04X", nValue); + // 22 12 DEFECT_SIZE // Common 04 遺덈웾 �겕湲� (L,H,M,S) if (pDefectData->m_DefectSizeType == SizeType_Small) { @@ -1176,13 +1350,13 @@ SPRINTRAW(12, "*"); } // 32 NO USE -> CCD Image �쑀臾� - if (strlen(pDefectData->m_strAoiImageName)) + if (strrchr(pDefectData->m_strAoiImageName, '*') != NULL || strlen(pDefectData->m_strAoiImageName) < 4) // KYH 210826 CCD �씠誘몄� 臾몄옄�뿴�뿉�꽌 *�씠 �엳�쓣寃쎌슦 X 癒몄��븷寃� { - SPRINTRAW(12, "O"); + SPRINTRAW(12, "X"); } else { - SPRINTRAW(12, "X"); + SPRINTRAW(12, "O"); } // 33 12 CAM_POSITION // Common 15 Scan 踰덊샇 SPRINTRAW(12, "%d", pDefectData->m_nScanIdx); @@ -1292,6 +1466,17 @@ // 49 12 Frame Shrink �젙蹂� 異붽� SPRINTRAW(12, "%d", pDefectData->m_bShrinked); + // 50 12 CLASS_NO // Zone Classification NO + // Zone Data + nValue = 0; + for (int i = 15; i >= 0; i--) + { + if (pDefectData->m_sZoneClassPixelCount[i] > 0) + nValue += 1; + if (i > 0) + nValue = nValue << 1; + } + SPRINTRAW(12, "%04X", nValue); SPRINTRAWEND; //以묒슂!!! �젮 留덉�留됱뿉 瑗� �엳�뼱�빞�븿!!!(�궘�젣湲덉�) [源��깭�쁽2020/9/23] @@ -1445,23 +1630,18 @@ void CGlassRawCPJT::SendMessageFTPDownloadDataFile( _grmGlassData* pGlassData ) { if(pGlassData == NULL) return; - HWND hWnd = ::FindWindow(NULL, "FTPDownloader"); + HWND hWnd = ::FindWindow(NULL, "FTPUploader"); if(hWnd == NULL) return; char strServerFolder[256] = {}; char strServerFile[256] = {}; char strLocalFolder[256] = {}; - char pLocalFile[256] = {}; - - //GetFormatDescription(FTPCMD_DATAFILE, strServerFolder, strServerFile, strLocalFolder, pLocalFile, pGlassData); - { - CString strGlassIDOrg = pGlassData->m_strGlassID; - CString strGlassID = strGlassIDOrg.Left(12); - sprintf(strServerFolder, "%s", pGlassData->m_strCassetteSequenceNo); - sprintf(strServerFile, "%s.dat", strGlassID.GetBuffer(0)); - sprintf(strLocalFolder, "D:\\DIT_ResultData\\DownloadData"); - sprintf(pLocalFile, "%s.dat", strGlassID.GetBuffer(0)); - } + char pLocalFile[256] = {}; + char strRTMSFile[32] = {}; + char strServerRawFileSubPath[256] = {}; + char strServer_SubFileName[256] = {}; + /*< KJG 20211024 - #3487 ADD Start >*/ + GetFormatDescription(FTPCMD_RAWMERGE, strServerFolder, strServerFile, strLocalFolder, pLocalFile, strRTMSFile, strServerRawFileSubPath, strServer_SubFileName, pGlassData); CFTPCopyDataParam upParam; strcpy(upParam.m_strServer_FolderName, strServerFolder); @@ -1474,7 +1654,7 @@ upParam.m_nSendResultCode = FALSE;//m_ctrlResultAck.GetCheck(); upParam.m_nProcessType = CFTPCopyDataParam::FTPProcessType_DownFile; // [C-PRJ] Image Upload Define - KHT (2020/11/19) - upParam.m_nDataType = CFTPCopyDataParam::FTPDataType_Unknown; + upParam.m_nDataType = CFTPCopyDataParam::FTPDataType_Raw; COPYDATASTRUCT cds; cds.dwData = CFTPCopyDataParam::FTPCopyDataCmd_RawDownload; @@ -1485,6 +1665,7 @@ if(SendMessageTimeout(hWnd, WM_COPYDATA, NULL, (LPARAM)&cds, SMTO_NORMAL, 20000, (PDWORD_PTR)(dwReturn)) == FALSE) { } + /*< KJG 20211024 - #3487 ADD End >*/ } void CGlassRawCPJT::SendMessageFTPUploadImage( _grmGlassData* pGlassData, emFTPCommand sort) @@ -1616,7 +1797,7 @@ else sprintf(pServerPath, "\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th); - sprintf(pLocalPath, "%s%s", LOCAL_AOI_IMAGE_PATH, strGlassID.GetBuffer(0)); + sprintf(pLocalPath, "%s%s", NETWORK_AOI_IMAGE_PATH, strGlassID.GetBuffer(0)); strcpy(pServerFile, "*.*"); strcpy(pLocalFile, "*.*"); } @@ -1774,23 +1955,41 @@ sprintf(pLocalFile, "%s", strGlassID.GetBuffer(0)); } break; - - case FTPCMD_MURA_IMAGE: //0404nwh - { // - /*CTime time = m_tmFileCreateTime; - sprintf(pServerPath, "%s\\%04d%02d%02d\\%s\\%s\\%s\\Image", pGlassData->m_strEquipID, time.GetYear(), time.GetMonth(), time.GetDay(), - strGlassIDLevel5th.GetBuffer(0), - strGlassIDLevel8th.GetBuffer(0), - strGlassID.GetBuffer(0)); - - sprintf(pLocalPath, "%s%s", LOCAL_MURA_IMAGE_PATH, strGlassID.GetBuffer(0)); - strcpy(pServerFile, "*.*"); - strcpy(pLocalFile, "*.*");*/ - - if (strGlassID.GetLength() > 6) - sprintf(pServerPath, "\\%s\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th, strGlassID); - else - sprintf(pServerPath, "\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th); + /*< KJG 20211024 - #3487 ADD Start >*/ + case FTPCMD_RAWMERGE: + { + /* <LJC 20211122 : #3820 ADD Start> */ + char cMergeList[10][12]; + CString strMergeList[10] = {}; + for (int i = 0; i < 10; i++) + { + strcpy(cMergeList[i], pGlassData->m_StrMergeList[i]); + strMergeList[i] = cMergeList[i]; + } + sprintf(pServerPath, "\\%s\\%s\\%s", strProcessID, strMergeList[m_nRawMergeIdx],strGlassIDLevel6th.GetBuffer(0)); // �꽌踰� 寃쎈줈 �솗�씤�썑 �닔�젙 kjg + sprintf(pServerFile, "%s",strGlassID); + /* <LJC 20211122 : #3820 ADD End> */ + sprintf(pLocalPath, "%s", m_RawMergeResult.getRawMergeLocalPath()); + sprintf(pLocalFile, "%s", strGlassID.GetBuffer(0)); + } + break; + /*< KJG 20211024 - #3487 ADD End >*/ + case FTPCMD_MURA_IMAGE: //0404nwh + { // + /*CTime time = m_tmFileCreateTime; + sprintf(pServerPath, "%s\\%04d%02d%02d\\%s\\%s\\%s\\Image", pGlassData->m_strEquipID, time.GetYear(), time.GetMonth(), time.GetDay(), + strGlassIDLevel5th.GetBuffer(0), + strGlassIDLevel8th.GetBuffer(0), + strGlassID.GetBuffer(0)); + + sprintf(pLocalPath, "%s%s", LOCAL_MURA_IMAGE_PATH, strGlassID.GetBuffer(0)); + strcpy(pServerFile, "*.*"); + strcpy(pLocalFile, "*.*");*/ + + if (strGlassID.GetLength() > 6) + sprintf(pServerPath, "\\%s\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th, strGlassID); + else + sprintf(pServerPath, "\\%s\\%s\\%s\\", strProcessID, strStepID, strGlassIDLevel6th); sprintf(pLocalPath, "%s%s", LOCAL_MURA_IMAGE_PATH, strGlassID.GetBuffer(0)); strcpy(pServerFile, "*.*"); @@ -1858,6 +2057,10 @@ break; case Judge_PR: sStr.Format("PR"); break; + /* <KYH 220117 : #3796 ADD Start>*/ + case Judge_ND: sStr.Format("ND"); + break; + /* <KYH 220117 : #3796 ADD End>*/ case Judge_PT: sStr.Format("PT"); break; case Judge_Review: sStr.Format("RV"); @@ -1870,6 +2073,10 @@ break; case Judge_Rework: sStr.Format("RW"); break; + /* < KMH 20220311 : #3954 ADD Start > */ + case Judge_LN: sStr.Format("LN"); + break; + /* < KMH 20220311 : #3954 ADD End > */ case Judge_Unknown: sStr.Format("OK");//sStr.Format("Unknown"); //Unknown�룄 �씪�떒 OK break; default: sStr.Format("OK");//sStr.Format("Ets"); @@ -1902,6 +2109,20 @@ } return sStr; } +/* <LJC 20211122 : #3820 ADD Start> */ +void CGlassRawCPJT::DownLoadMergeFile(CgrmGlassRawData * pData) +{ + SendMessageFTPDownloadDataFile(pData->GetGlassData()); + m_nRawMergeIdx++; + return; +} + +void CGlassRawCPJT::SearchFIle(CgrmGlassRawData * pData) +{ + m_RawMergeResult.ProcessRawMergeFileReadStart(pData->GetGlassData()->m_strGlassID); +} +/* <LJC 20211122 : #3820 ADD End> */ + CString CGlassRawCPJT::GetWsiDefectType(int nType) { -- Gitblit v1.9.3