From e8ba1e78e72f3f7ec2841f55fd90253b4dc414df Mon Sep 17 00:00:00 2001 From: LYW <leeyeanwoo@diteam.co.kr> Date: 목, 14 10월 2021 14:15:04 +0900 Subject: [PATCH] Ongoing60 #3671 CF AOI Review 전설비 Align Matching 방법 개선 --- ReviewSystem/ReviewSystem/CameraControlAlign.cpp | 97 ++++++++++++++++++++++++++++++++++++++++++++++-- 1 files changed, 92 insertions(+), 5 deletions(-) diff --git a/ReviewSystem/ReviewSystem/CameraControlAlign.cpp b/ReviewSystem/ReviewSystem/CameraControlAlign.cpp index aafd737..898b8f7 100644 --- a/ReviewSystem/ReviewSystem/CameraControlAlign.cpp +++ b/ReviewSystem/ReviewSystem/CameraControlAlign.cpp @@ -267,21 +267,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]; @@ -292,7 +308,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; @@ -597,10 +624,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("\\Test3.BMP"); +// } +// else +// { +// strFilename += _T("\\Test4.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 @@ -609,20 +652,64 @@ //SAlignFindResult findResult = pAlignFinder->FindAlign(pCameraImage->GetImageData(View_Matching), findParam, pCameraImage->GetImageData(View_Template)); 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 if (findResult.nResultCode==AlignMatch_Success) { + g_pLog->DisplayMessage(_T("Main TempleteMatching 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; } + /*< LYW 20211013 - #3671 ADD Start >*/ + else { - m_AlignResult.nFindAlign[nCameraIdx] = 0; - m_AlignResult.dFindScore[nCameraIdx] = findResult.dMatchValue; + 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); + if (findAssistantResult.nResultCode == AlignMatch_Success) + { + g_pLog->DisplayMessage(_T("Assistant TempleteMatching Success!")); + 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 + { + 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) <= 10 && abs(dffmain2assistanstY) <= 10 && 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; + } + + else + { + 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; + } + } } + /*< 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, -- Gitblit v1.9.3