From 26e2541b87ca76e16cf69399eb9a3cce62d2e864 Mon Sep 17 00:00:00 2001 From: LYW <leeyeanwoo@diteam.co.kr> Date: 목, 14 10월 2021 17:58:19 +0900 Subject: [PATCH] Ongoing80 #3671 CF AOI Review 전설비 Align Matching 방법 개선 --- ReviewSystem/ReviewSystem/CameraControlAlign.cpp | 25 ++++++++++++++++++++----- 1 files changed, 20 insertions(+), 5 deletions(-) diff --git a/ReviewSystem/ReviewSystem/CameraControlAlign.cpp b/ReviewSystem/ReviewSystem/CameraControlAlign.cpp index 898b8f7..c75bc2a 100644 --- a/ReviewSystem/ReviewSystem/CameraControlAlign.cpp +++ b/ReviewSystem/ReviewSystem/CameraControlAlign.cpp @@ -588,7 +588,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; @@ -601,6 +605,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; @@ -633,11 +639,11 @@ // CString strFilename = ALIGN_IMAGE_PATH; // if (nCameraIdx == 0) // { -// strFilename += _T("\\Test3.BMP"); +// strFilename += _T("\\Test1.BMP"); // } // else // { -// strFilename += _T("\\Test4.BMP"); +// strFilename += _T("\\Test2.BMP"); // } // TestImage.LoadImage(strFilename); // TestImage.GetBandImage(BandTypeGray, m_vecCameraImage[nCameraIdx]->GetImageData(View_Camera)); @@ -684,13 +690,14 @@ 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) <= 10 && abs(dffmain2assistanstY) <= 10 && findResult.dMatchValue != 0.0) + if (abs(dffmain2assistanstX) <= findParam.dMatchingPixelStandard && abs(dffmain2assistanstY) <= findParam.dMatchingPixelStandard && findResult.dMatchValue != 0.0) { - g_pLog->DisplayMessage(_T("Main Assistant Templete Find Same Point! Align Success!")); 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; + 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 @@ -699,6 +706,14 @@ m_AlignResult.nFindAlign[nCameraIdx] = 0; m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue; } + + if (m_pACC2P->IACC2P_GetAccumaulate() > findParam.dMatchingAlarmCondition) + { + 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 >*/ -- Gitblit v1.9.3