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. 로그 시간 출력 불합리 개선 - 로그 시간이 파일 출력 시점으로 작성되어 로그 스래드 지연 시 시간이 맞지 않는 불합리 있음 - 로그 시간은 로그 발생 시점에 시간 저장, 해당 시간 이용하여 파일에 기록하도록 변경 --- ReviewHistory/ReveiwHistory/GlassRawCEC.cpp | 96 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 96 insertions(+), 0 deletions(-) diff --git a/ReviewHistory/ReveiwHistory/GlassRawCEC.cpp b/ReviewHistory/ReveiwHistory/GlassRawCEC.cpp new file mode 100644 index 0000000..f51188a --- /dev/null +++ b/ReviewHistory/ReveiwHistory/GlassRawCEC.cpp @@ -0,0 +1,96 @@ +#include "StdAfx.h" +#include "GlassRawCEC.h" +#include "akLoggerExt.h" + +CGlassRawCEC::CGlassRawCEC(void) +{ +} + +CGlassRawCEC::~CGlassRawCEC(void) +{ +} + +BOOL CGlassRawCEC::SequenceGlassLoading( CgrmGlassRawData* pData ) +{ + //나중에 스택파일 읽기 처리도 여기서 하게 하면 좋을듯 [김태현 2018/11/14] + return TRUE; +} + +BOOL CGlassRawCEC::SequenceInspectEnd( CgrmGlassRawData* pData ) +{ + WriteAOIFile(pData); + + return TRUE; +} + +BOOL CGlassRawCEC::SequenceReviewStart( CgrmGlassRawData* pData ) +{ + return TRUE; +} + +BOOL CGlassRawCEC::SequenceReviewEnd( CgrmGlassRawData* pData ) +{ + WriteAOIFile(pData); + + return TRUE; +} + + +BOOL CGlassRawCEC::WriteAOIFile( CgrmGlassRawData* pData ) +{ + BOOL bResult = TRUE; + + + bResult &= MakeAOIFile(pData); + bResult &= MakeAnaFile(pData); + + AKLOG("WriteAOIFile Complete"); + return TRUE; +} + +BOOL CGlassRawCEC::MakeAOIFile( CgrmGlassRawData* pData ) +{ + CString strFilePathName; + strFilePathName.Format("%s\\%s", pData->GetGlassData()->m_strPath, pData->GetGlassData()->m_strFileName); + + FILE* pf = fopen(strFilePathName.GetBuffer(0), "w"); + if(pf == NULL) return FALSE; + + for(int iCell = 0; iCell < pData->GetGlassData()->m_nCellNum; iCell++) + { + _grmCellData* pCell = pData->GetCellData(iCell); + + fprintCell(pf, pCell); + } + + fprintf(pf, "<HEAD DEFECE> sdlkfjlsd sdlkflsdkjf sdlkfjslkdjf sldkfjsdf\n"); + for(int iDefect = 0; iDefect < pData->GetGlassData()->m_nDefectNum; iDefect++) + { + _grmDefectData* pDefect = pData->GetDefectData(iDefect); + + fprintDefect(pf, pDefect); + } + + AKLOG("MakeAOIFile Complete"); + fclose(pf); + return TRUE; +} + +BOOL CGlassRawCEC::MakeAnaFile( CgrmGlassRawData* pData ) +{ + CString strFilePathName; + strFilePathName.Format("%s\\%sana", pData->GetGlassData()->m_strPath, pData->GetGlassData()->m_strFileName); + + AKLOG("MakeAnaFile Complete"); + return TRUE; +} + +void CGlassRawCEC::fprintDefect( FILE* pf, _grmDefectData* pData ) +{ + //defect pos + fprintf(pf, "%d ", pData->m_nUMCenterAlignX); //defect pos + + fprintf(pf, "%d ", pData->m_nUMCenterAlignX); + + fprintf(pf, "\n"); +} -- Gitblit v1.9.3