From 3ce48f6dbeb537e252edb0d62c88a28796e36674 Mon Sep 17 00:00:00 2001
From: SWK <sungwk82@diteam.co.kr>
Date: 월, 26 12월 2022 15:04:42 +0900
Subject: [PATCH] ongoing60 #4403 CF AOI Review TACT 지연 개선 1. 신호 출력 방식 재개선  - 유지 시간이 없는 신호는 바로 출력 진행하도록 변경 2. 불필요 Delay 제거 및 시퀀스 변경  - 얼라인 측정 종료 처리 간 제어 신호 먼저 출력 후 카메라 Stop으로 변경  - 물류 정보 읽기 처리 후 1000ms Delay 삭제  - 얼라인 측정 시작(카메라 Live Start) 후 Delay 300ms -> 100ms(이미지 들어오는 시간 확보 필요)  - ReadRawFile 처리 시작 전 500ms Delay 삭제  - Path Scheduling 완료 후 Review Ready 신호 출력 전 1000ms Delay 삭제 3. 버그 수정  - 이미지 저장 경로 생성 간 예외 처리 부분 버그 수정 4. 로그 시간 출력 불합리 개선  - 로그 시간이 파일 출력 시점으로 작성되어 로그 스래드 지연 시 시간이 맞지 않는 불합리 있음  - 로그 시간은 로그 발생 시점에 시간 저장, 해당 시간 이용하여 파일에 기록하도록 변경

---
 ReviewSystem/ReviewSystem/CameraControlAlign.cpp |  181 +++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 172 insertions(+), 9 deletions(-)

diff --git a/ReviewSystem/ReviewSystem/CameraControlAlign.cpp b/ReviewSystem/ReviewSystem/CameraControlAlign.cpp
index 39f2d4e..c9a8055 100644
--- a/ReviewSystem/ReviewSystem/CameraControlAlign.cpp
+++ b/ReviewSystem/ReviewSystem/CameraControlAlign.cpp
@@ -5,7 +5,8 @@
 #include "CHReviewSetting/SystemInfo.h"
 #include "CHReviewRecipe/RsRcpAlignInfo.h"
 
-#define ALIGN_TEMPLATE_PATH _T("C:\\DIT_Review\\Recipe\\AlignImage\\")
+#define ALIGN_TEMPLATE_PATH _T("D:\\DIT_Review\\Recipe\\AlignImage\\")
+//#define ALIGN_TEMPLATE_PATH _T("C:\\DIT_Review\\Recipe\\AlignImage\\") //210805
 
 using namespace CHImageControls;
 
@@ -18,6 +19,8 @@
 	m_pVectorAlignLightControl = NULL;
 	m_nViewMode = 0;
 	m_strSaveImageBasePath = _T("");
+	m_strSaveImageOKPath = _T("");
+	m_strSaveImageNGPath = _T("");
 
 	m_nAlignType = FALSE;
 
@@ -92,6 +95,7 @@
 	m_nAlignType = nAlignType;
 }
 
+//#3357 KYH Align Image 珥덇린�솕 ADD START
 void CCameraControlAlign::SetAlignClearImage()//210330 kyh Align �씠誘몄� 珥덇린�솕
 {
 	//m_vecCameraImage[0]->GetImageData(View_Camera)->ClearImage(0); 
@@ -106,6 +110,7 @@
 			m_vecCameraImage[i]->ClearImage(View_Matching);
 	}
 }
+//#3357 KYH Align Image 珥덇린�솕 ADD END
 
 void CCameraControlAlign::DisconnectCamera()
 {
@@ -264,21 +269,37 @@
 
 	CString strFilename = _T("");
 	CCHImageData tempImage;
+	/*< LYW 20211012 - #3671 ADD Start >*/
+	CCHImageData assistanttempImage;
+	/*< LYW 20211012 - #3671 ADD End >*/
 	for (int i=0; i<2; i++)
 	{
 		if(m_vecCameraImage.size() <= i) continue;
 		(m_vecCameraImage[i]->GetImageData(View_Template))->ReleaseImage();
+		/*< LYW 20211012 - #3671 ADD Start >*/
+		(m_vecCameraImage[i]->GetImageData(View_AssistantTemplate))->ReleaseImage();
+		/*< LYW 20211012 - #3671 ADD End >*/
 
 		// load
 		CString strFilename = ALIGN_IMAGE_PATH;
+		/*< LYW 20211012 - #3671 ADD Start >*/
+		CString strAssistantFilename = ALIGN_IMAGE_PATH;
+		/*< LYW 20211012 - #3671 ADD End >*/
 
 		if (i==0)
 		{
 			strFilename += _T("\\") + m_AlignRecipe.strFirstImageFile;
+			/*< LYW 20211012 - #3671 ADD Start >*/
+			strAssistantFilename += _T("\\") + m_AlignRecipe.strFirstAssistantImageFile;
+			/*< LYW 20211012 - #3671 ADD End >*/
+
 		}
 		else if (i==1)
 		{
 			strFilename += _T("\\") + m_AlignRecipe.strSecondImageFile;
+			/*< LYW 20211012 - #3671 ADD Start >*/
+			strAssistantFilename += _T("\\") + m_AlignRecipe.strSecondAssistantImageFile;
+			/*< LYW 20211012 - #3671 ADD End >*/
 		}
 
 		//strFilename += m_AlignRecipe.strTemplateName[i];
@@ -289,7 +310,18 @@
 			continue;
 		}
 
+		/*< LYW 20211012 - #3671 ADD Start >*/
+		if (assistanttempImage.LoadImage(strAssistantFilename) == FALSE)
+		{
+			bAllLoad = bAllLoad && FALSE;
+			continue;
+		}
+		/*< LYW 20211012 - #3671 ADD End >*/
+
 		bAllLoad = bAllLoad && tempImage.GetBandImage(BandTypeGray, m_vecCameraImage[i]->GetImageData(View_Template));
+		/*< LYW 20211012 - #3671 ADD Start >*/
+		bAllLoad = bAllLoad && assistanttempImage.GetBandImage(BandTypeGray, m_vecCameraImage[i]->GetImageData(View_AssistantTemplate));
+		/*< LYW 20211012 - #3671 ADD End >*/
 	}
 
 	return bAllLoad;
@@ -412,6 +444,16 @@
 void CCameraControlAlign::SetSaveImageBasePath(CString strPath)
 {
 	m_strSaveImageBasePath = strPath;
+}
+
+void CCameraControlAlign::SetSaveImageOKPath(CString strPath)
+{
+	m_strSaveImageOKPath = strPath;
+}
+
+void CCameraControlAlign::SetSaveImageNGPath(CString strPath)
+{
+	m_strSaveImageNGPath = strPath;
 }
 
 CCameraControl* CCameraControlAlign::GetCameraControl(int nCameraIndex)
@@ -558,7 +600,11 @@
 	CCameraImageData* pCameraImage = m_vecCameraImage[nCameraIdx];
 	CAlignFinder* pAlignFinder = m_vecAlignFinder[nCameraIdx];
 
-	if (pCameraImage==NULL || pAlignFinder==NULL) return FALSE;
+	/*< LYW 20211014 - #index MOD Start >*/
+	if (pCameraImage == NULL || pAlignFinder == NULL || m_pACC2P == NULL) return FALSE;
+	/*< LYW 20211014 - #index MOD End >*/
+	/*< Origin Code >*/
+	//if (pCameraImage == NULL || pAlignFinder == NULL) return FALSE;
 
 	// set find param;
 	SAlignFindParam findParam;
@@ -571,6 +617,8 @@
 	findParam.nEdgeThreshold		= m_AlignRecipe.nEdgeThreshold;
 	findParam.nMergeRange			= m_AlignRecipe.nMergeRange;
 	findParam.dEdgeRate				= m_AlignRecipe.dEdgeRate;
+	findParam.dMatchingPixelStandard = _tcstod(m_AlignRecipe.strMatchingPixelStandard,NULL);
+	findParam.dMatchingAlarmCondition = _tcstod(m_AlignRecipe.strMatchingAlarmCondition, NULL);
 //	findParam.m_nAlignMarkPos		= m_AlignRecipe.nAlignMarkPosition;
 
 
@@ -594,10 +642,26 @@
 		wcstombs_s(&CharactersConverted,CDitGlassRawClient::GetInstance()->GetGlassData()->m_strAlignMarkSecond, uploadAlignimage, _TRUNCATE);
 	}*/
 	// find process
-
-
-	// find process	 諛붿뒳�윭 移대찓�씪媛� 3梨꾨꼸吏쒕━�씪�꽌 �떆���뒪 �룎�븣�뒗 1梨꾨꼸濡� 諛붽퓭�꽌 �룘 ksm
 	CCHImageData camImage;
+
+	//#3671 TEST CODE Start
+// 	CCHImageData TestImage;
+// 
+// 	(m_vecCameraImage[nCameraIdx]->GetImageData(View_Camera))->ReleaseImage();
+// 	CString strFilename = ALIGN_IMAGE_PATH;
+// 	if (nCameraIdx == 0)
+// 	{
+// 		strFilename += _T("\\Test1.BMP");
+// 	}
+// 	else
+// 	{
+// 		strFilename += _T("\\Test2.BMP");
+// 	}
+// 	TestImage.LoadImage(strFilename);
+// 	TestImage.GetBandImage(BandTypeGray, m_vecCameraImage[nCameraIdx]->GetImageData(View_Camera));
+// 	(m_vecCameraImage[nCameraIdx]->GetImageData(View_Camera))->GetBandImage(BandTypeGray, &camImage);
+	//#3671 TEST CODE End
+// find process	 諛붿뒳�윭 移대찓�씪媛� 3梨꾨꼸吏쒕━�씪�꽌 �떆���뒪 �룎�븣�뒗 1梨꾨꼸濡� 諛붽퓭�꽌 �룘 ksm
 	if ((pCameraImage->GetImageData(View_Camera))->GetChannels() > 1)
 		(pCameraImage->GetImageData(View_Camera))->GetBandImage(BandTypeGray, &camImage);
 	else
@@ -605,21 +669,92 @@
 
 	
 	//SAlignFindResult findResult = pAlignFinder->FindAlign(pCameraImage->GetImageData(View_Matching), findParam, pCameraImage->GetImageData(View_Template));
+	//Main Align Matching
 	SAlignFindResult findResult = pAlignFinder->FindAlign(&camImage, findParam, pCameraImage->GetImageData(View_Template));
+	g_pLog->DisplayMessage(_T("Main TempleteMatching Result : %d Cam ResultCode = %d, PixelX = %d, PixelY = %d, MatchingRate = %.3lf"), nCameraIdx, findResult.nResultCode, int(findResult.dPosX + 0.5), int(findResult.dPosY + 0.5), findResult.dMatchValue);
 
-	// result process
+	//Main Align Matching result process
 	if (findResult.nResultCode==AlignMatch_Success)
 	{
+		/*< LYW 20211015 - #3671 ADD Start >*/
+		m_pACC2P->IACC2P_SetAccumaulate(0);
+		/*< LYW 20211015 - #3671 ADD End >*/
+		g_pLog->DisplayMessage(_T("Main TempleteMatching Success! Accumaulate = %d"), m_pACC2P->IACC2P_GetAccumaulate());
 		m_AlignResult.nFindAlign[nCameraIdx] = 1;
 		m_AlignResult.dFindPixelX[nCameraIdx] = int(findResult.dPosX + 0.5);
 		m_AlignResult.dFindPixelY[nCameraIdx] = int(findResult.dPosY + 0.5);
 		m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue;
 	}
+	/*< LYW 20211013 - #3671 ADD Start >*/
+
 	else
 	{
-		m_AlignResult.nFindAlign[nCameraIdx] = 0;
-		m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue;
+		//Assistant Align Matching
+		SAlignFindResult findAssistantResult = pAlignFinder->FindAlign(&camImage, findParam, pCameraImage->GetImageData(View_AssistantTemplate));
+		g_pLog->DisplayMessage(_T("Assistant TempleteMatching Result : %d Cam ResultCode = %d, PixelX = %d, PixelY = %d, MatchingRate = %.3lf"), nCameraIdx, findAssistantResult.nResultCode, int(findAssistantResult.dPosX + 0.5), int(findAssistantResult.dPosY + 0.5), findAssistantResult.dMatchValue);
+		//Assistant Align Matching result process
+		if (findAssistantResult.nResultCode == AlignMatch_Success)
+		{
+			/*< LYW 20211015 - #3671 ADD Start >*/
+			m_pACC2P->IACC2P_SetAccumaulate(0);
+			/*< LYW 20211015 - #3671 ADD End >*/
+			g_pLog->DisplayMessage(_T("Assistant TempleteMatching Success! Accumaulate = %d"),m_pACC2P->IACC2P_GetAccumaulate());
+			m_AlignResult.nFindAlign[nCameraIdx] = 1;
+			m_AlignResult.dFindPixelX[nCameraIdx] = int(findAssistantResult.dPosX + 0.5);
+			m_AlignResult.dFindPixelY[nCameraIdx] = int(findAssistantResult.dPosY + 0.5);
+			m_AlignResult.dFindScore[nCameraIdx] = findAssistantResult.dMatchValue;
+		}
+
+		else 
+		{
+			//Main, Assistant Find Pos Compare
+			int dffmain2assistanstX = int(findResult.dPosX) - int(findAssistantResult.dPosX);
+			int dffmain2assistanstY = int(findResult.dPosY) - int(findAssistantResult.dPosY);
+			g_pLog->DisplayMessage(_T("Main, Assistant TempleteMatching All Low Score! differenceX = %d, differenceY = %d"), dffmain2assistanstX, dffmain2assistanstY);
+
+			if (abs(dffmain2assistanstX) <= findParam.dMatchingPixelStandard && abs(dffmain2assistanstY) <= findParam.dMatchingPixelStandard && findResult.dMatchValue != 0.0 && findAssistantResult.dMatchValue != 0.0)
+			{
+				//Main, Assistant Find Pos Compare Result Success Process
+				m_AlignResult.nFindAlign[nCameraIdx] = 1;
+				/*< LYW 20211015 - #3671 MOD Start >*/
+				m_AlignResult.dFindPixelX[nCameraIdx] = int((findResult.dPosX + findAssistantResult.dPosX) / 2 + 0.5);
+				m_AlignResult.dFindPixelY[nCameraIdx] = int((findResult.dPosY + findAssistantResult.dPosY) / 2 + 0.5);
+				/*< LYW 20211015 - #3671 MOD End >*/
+				/*< Origin Code >*/
+				//m_AlignResult.dFindPixelX[nCameraIdx] = int(findResult.dPosX + 0.5);
+				//m_AlignResult.dFindPixelY[nCameraIdx] = int(findResult.dPosY + 0.5);
+				m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue;
+				m_pACC2P->IACC2P_SetAccumaulate(m_pACC2P->IACC2P_GetAccumaulate() + 1);
+				g_pLog->DisplayMessage(_T("Main, Assistant Templete Find Same Point! Align Success! Accumaulate = %d"), m_pACC2P->IACC2P_GetAccumaulate());
+			}
+
+			else
+			{
+				//Main, Assistant Find Pos Compare Result Fail Process
+				g_pLog->DisplayMessage(_T("Main Assistant Templete Don`t Find Same Point! Align Fail!"));
+				m_AlignResult.nFindAlign[nCameraIdx] = 0;
+				m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue;
+			}
+
+			if (m_pACC2P->IACC2P_GetAccumaulate() >= findParam.dMatchingAlarmCondition)
+			{
+				//Main, Assistant Find Pos Alarm Process
+				m_AlignResult.nFindAlign[nCameraIdx] = 0;
+				m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue;
+				m_pACC2P->IACC2P_SetAccumaulate(0);
+				g_pLog->DisplayMessage(_T("Low Matching, But Align Same Point, Count is more Than MatchingAlarmCondition , Accumaulate = %d Reset"), m_pACC2P->IACC2P_GetAccumaulate());
+			}
+		}
 	}
+	/*< LYW 20211013 - #3671 ADD End >*/
+
+	/*< LYW 20211013 - #3671 Delete Start >*/
+// 	else
+// 	{
+// 		m_AlignResult.nFindAlign[nCameraIdx] = 0;
+// 		m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue;
+// 	}
+	/*< LYW 20211013 - #3671 Delete End >*/
 	
 	// save threshold image
 	strPath.Format(_T("%s\\Cam%02d_AlignTH_%04d%02d%02d%02d%02d%02d.jpg"), m_strSaveImageBasePath, nCameraIdx, 
@@ -631,7 +766,8 @@
 		time.GetYear(), time.GetMonth(), time.GetDay(), time.GetHour(), time.GetMinute(), time.GetSecond());
 	pAlignFinder->SaveResultImage(strPath);
 
-	Sleep(10);
+	//< SWK 20221226 - #4403 DEL >
+//	Sleep(10);
 	if (nCameraIdx == 0)
 	{
 		m_AlignResult.strAlignFirest = strPath;
@@ -641,6 +777,33 @@
 		m_AlignResult.strAlignSecond = strPath;
 	}
 
+	if (m_AlignResult.nFindAlign[nCameraIdx] == 1)
+	{
+		CreateDirectory(m_strSaveImageOKPath, NULL);
+		// save threshold image
+		strPath.Format(_T("%s\\Cam%02d_Align_OK_TH_%04d%02d%02d%02d%02d%02d.jpg"), m_strSaveImageOKPath, nCameraIdx,
+			time.GetYear(), time.GetMonth(), time.GetDay(), time.GetHour(), time.GetMinute(), time.GetSecond());
+		pAlignFinder->SaveThresholdImage(strPath);
+
+		// save Result Image 20210208 �뼹�씪�씤 寃곌낵 ���옣
+		strPath.Format(_T("%s\\Cam%02d_AlignResultOK_%04d%02d%02d%02d%02d%02d.jpg"), m_strSaveImageOKPath, nCameraIdx,
+			time.GetYear(), time.GetMonth(), time.GetDay(), time.GetHour(), time.GetMinute(), time.GetSecond());
+		pAlignFinder->SaveResultImage(strPath);
+	}
+
+	else
+	{
+		CreateDirectory(m_strSaveImageNGPath, NULL);
+		// save threshold image
+		strPath.Format(_T("%s\\Cam%02d_Align_NG_TH_%04d%02d%02d%02d%02d%02d.jpg"), m_strSaveImageNGPath, nCameraIdx,
+			time.GetYear(), time.GetMonth(), time.GetDay(), time.GetHour(), time.GetMinute(), time.GetSecond());
+		pAlignFinder->SaveThresholdImage(strPath);
+
+		// save Result Image 20210208 �뼹�씪�씤 寃곌낵 ���옣
+		strPath.Format(_T("%s\\Cam%02d_AlignResultNG_%04d%02d%02d%02d%02d%02d.jpg"), m_strSaveImageNGPath, nCameraIdx,
+			time.GetYear(), time.GetMonth(), time.GetDay(), time.GetHour(), time.GetMinute(), time.GetSecond());
+		pAlignFinder->SaveResultImage(strPath);
+	}
 
 	// update matching image
 	pAlignFinder->GetBlobImage(pCameraImage->GetImageData(View_Matching));

--
Gitblit v1.9.3