From 08215fc9a36a1648e1a5040ffe5696b96483c3b9 Mon Sep 17 00:00:00 2001 From: LYW <leeyeanwoo@diteam.co.kr> Date: 월, 01 11월 2021 14:39:43 +0900 Subject: [PATCH] Ongoing90 #3684 CF AOI Review 전설비 Review History Defect이미지 클릭시 Offset 자동 계산 기능 추가 --- ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp | 129 ++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 127 insertions(+), 2 deletions(-) diff --git a/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp b/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp index 0f820c7..400bc82 100644 --- a/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp +++ b/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp @@ -60,6 +60,7 @@ , m_dEditOffsetX(0) , m_dEditOffsetY(0) , m_strGantryIdx(_T("")) + , m_TextLastSaveOffsetTime(_T("")) { m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME); @@ -83,6 +84,11 @@ m_dCurDefectIdx = 0; m_dCurDefectID = 0; /*< LYW 20211018 - #3684 ADD End >*/ + /*< LYW 20211029 - #3684 ADD Start >*/ + DWORD dwThreadId = 0; + HANDLE hThread = CreateThread(NULL, 0, RunThreadReviewHistory, this, 0, &dwThreadId); + m_ThreadId = dwThreadId; + /*< LYW 20211029 - #3684 ADD End >*/ for (int i = 0; i < 105; i++) { @@ -93,6 +99,13 @@ m_nImageSize[i] = 0; } } + +/*< LYW 20211029 - #3684 ADD Start >*/ +CReveiwHistoryDlg::~CReveiwHistoryDlg(void) +{ + PostThreadMessage(m_ThreadId, WM_QUIT, 0, 0); +} +/*< LYW 20211029 - #3684 ADD End >*/ void CReveiwHistoryDlg::DoDataExchange(CDataExchange* pDX) { @@ -112,6 +125,7 @@ DDX_Text(pDX, IDC_EDIT_OFFSET_X, m_dEditOffsetX); DDX_Text(pDX, IDC_EDIT_OFFSET_Y, m_dEditOffsetY); DDX_Text(pDX, IDC_EDIT_DFFSET_GANTRY_IDX, m_strGantryIdx); + DDX_Text(pDX, IDC_STATIC_LAST_SAVE_OFFSET_TIME, m_TextLastSaveOffsetTime); } BEGIN_MESSAGE_MAP(CReveiwHistoryDlg, CDialogEx) @@ -124,6 +138,7 @@ ON_BN_CLICKED(IDC_BUTTON_MAPVIEW_FIT, &CReveiwHistoryDlg::OnBnClickedButtonMapviewFit) ON_MESSAGE(UM_FORMMAP_DEFECTSELECT, OnMapDefectSelected) ON_MESSAGE(UM_FORMMAP_DEFECTMOUSEOVER, OnMapDefectMouseOver) + ON_MESSAGE(UM_WARNING_OFFSET, OnDisplayWarning) ON_MESSAGE(UM_FORMMAP_IMAGEMOUSECLICK, OnImageClick) ON_COMMAND(ID_OPTION_PATHSETTING, &CReveiwHistoryDlg::OnOptionPathsetting) ON_COMMAND(ID_VIEW_ALLDEFECT, &CReveiwHistoryDlg::OnViewAlldefect) @@ -1236,6 +1251,12 @@ return 0; } +LRESULT CReveiwHistoryDlg::OnDisplayWarning(WPARAM wParam, LPARAM lParam) +{ + AfxMessageBox(_T("�꽑�깮�븯�떊 由щ럭 �뜲�씠�꽣�뒗 吏�湲� �쟻�슜�맂 OFFSET �뜲�씠�꽣 �씠�쟾�쓽 �뜲�씠�꽣 �엯�땲�떎. �솗�떎�븳 寃쎌슦媛� �븘�땲�씪硫� OFFSET �뀑�똿�쓣 湲덊빐二쇱떗�떆�삤."), MB_OK | MB_ICONWARNING); + return 0; +} + LRESULT CReveiwHistoryDlg::OnListDefectSelected(WPARAM wParam, LPARAM lParam) { int nSelectDefect = static_cast<int>(wParam); @@ -1440,6 +1461,8 @@ nSecond = write_local_time.wSecond; CString strTime; strTime.Format("%04d-%02d-%02d-%02d-%02d-%02d", nYear, nMonth, nDay, nHour, nMinute, nSecond); + + CloseHandle(h_File); m_vecStrGridTimeList.push_back(strTime); } @@ -1557,6 +1580,12 @@ Imagenoload(); return; } + + /*< LYW 20211028 - #3684 ADD Start >*/ + CString strBinFileName; + strBinFileName.Format("%s\\%s", strBinPath, strFileName); + m_CurrentResultFileTime = GetCurrentResultFileTime(strBinFileName); + /*< LYW 20211028 - #3684 ADD End >*/ if (bNewFile && m_chkSingle.GetCheck()) { @@ -1783,6 +1812,10 @@ { SetScrollSetting(); } + /*< LYW 20211028 - #3684 ADD Start >*/ + HWND hWnd = GetSafeHwnd(); + PostThreadMessage(m_ThreadId, UM_THREAD_WARNING_OFFSET, 0, 0); + /*< LYW 20211028 - #3684 ADD End >*/ } void CReveiwHistoryDlg::OnCbnSelchangeComboRawtype() @@ -2693,6 +2726,63 @@ m_ctlFileCount.GetWindowText(strCount); m_nFileCount = _ttoi(strCount); } + +/*< LYW 20211028 - #3684 ADD Start >*/ +void CReveiwHistoryDlg::UpdateLastSaveOffsetTime(CString FileName) +{ + + HANDLE h_file = CreateFile(FileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); + + FILETIME create_time, access_time, write_time; + GetFileTime(h_file, &create_time, &access_time, &write_time); + + SYSTEMTIME access_system_time; + FileTimeToSystemTime(&access_time, &access_system_time); + + SYSTEMTIME access_system_Local_time; + SystemTimeToTzSpecificLocalTime(NULL, &access_system_time, &access_system_Local_time); + + CTime FIleTime(access_system_Local_time); + m_LastSaveOffsetTime = FIleTime; + + CloseHandle(h_file); + + m_TextLastSaveOffsetTime.Format(_T("%04d/%02d/%02d/%02d:%02d:%02d"), m_LastSaveOffsetTime.GetYear(), m_LastSaveOffsetTime.GetMonth(), + m_LastSaveOffsetTime.GetDay(), m_LastSaveOffsetTime.GetHour(), m_LastSaveOffsetTime.GetMinute(), m_LastSaveOffsetTime.GetSecond()); + + UpdateData(FALSE); +} +CTime CReveiwHistoryDlg::GetCurrentResultFileTime(CString FileName) +{ + HANDLE h_file = CreateFile(FileName, GENERIC_READ, FILE_SHARE_READ, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL); + + if (h_file != INVALID_HANDLE_VALUE) + { + FILETIME create_time, access_time, write_time; + GetFileTime(h_file, &create_time, &access_time, &write_time); + + SYSTEMTIME access_system_time; + FileTimeToSystemTime(&access_time, &access_system_time); + + SYSTEMTIME access_system_Local_time; + SystemTimeToTzSpecificLocalTime(NULL, &access_system_time, &access_system_Local_time); + + CloseHandle(h_file); + + CTime FIleTime(access_system_Local_time); + m_CurrentResultFileTime = FIleTime; + + return m_CurrentResultFileTime; + } + + else + { + return CTime::GetCurrentTime(); + } + + +} +/*< LYW 20211028 - #3684 ADD End >*/ BOOL CReveiwHistoryDlg::GetCheckFileLoad(int nCount) { @@ -3949,6 +4039,8 @@ if (!macroFile.Read(strFilePath)) return FALSE; + UpdateLastSaveOffsetTime(strFilePath); + macroFile.GetItem(_T("CAMERA_COUNT"), m_nCameraCount, 0); macroFile.GetItem(_T("SCAN_COUNT"), m_nScanCount, 0); macroFile.GetItem(_T("XPOS_COUNT"), m_XposCount, 0); @@ -4004,6 +4096,9 @@ CString strForderPath; CString strFileName; CTime time = CTime::GetCurrentTime(); + /*< LYW 20211028 - #3684 ADD Start >*/ + m_LastSaveOffsetTime = time; + /*< LYW 20211028 - #3684 ADD End >*/ strFileName.Format(_T("ReviewOffSet_%04d%02d%02d%02d%02d%02d.cfg"), time.GetYear(), time.GetMonth(), time.GetDay(), time.GetHour(), time.GetMinute(), time.GetSecond()); strForderPath.Format(_T("%s%s"), REVIEW_OFFSET_BACKUP_FORDER_PATH, strFileName); @@ -4070,8 +4165,14 @@ bReturn = macroFile.Write(strFilePath); - if (bReturn) AfxMessageBox(_T("OFFSET SAVE SUCCESS"), MB_OK | MB_ICONASTERISK); - else AfxMessageBox(_T("OFFSET SAVE FAIL"), MB_OK | MB_ICONASTERISK); + if (bReturn) + { + /*< LYW 20211028 - #3684 ADD Start >*/ + UpdateLastSaveOffsetTime(strFilePath); + AfxMessageBox(_T("OFFSET SAVE SUCCESS"), MB_OK | MB_ICONASTERISK); + /*< LYW 20211028 - #3684 ADD End >*/ + } + else AfxMessageBox(_T("OFFSET SAVE FAIL"), MB_OK | MB_ICONHAND); return bReturn; } @@ -4259,3 +4360,27 @@ } } /*< LYW 20211025 - #3684 ADD End >*/ + +/*< LYW 20211029 - #3684 ADD Start >*/ +DWORD RunThreadReviewHistory(LPVOID param) +{ + MSG msg; + CReveiwHistoryDlg* pDlg = (CReveiwHistoryDlg*)param; + while (GetMessage(&msg, NULL, 0, 0)) + { + //CString* pstrLog = reinterpret_cast<CString*>(msg.wParam); + switch (msg.message) + { + case UM_THREAD_WARNING_OFFSET: + + Sleep(100); + pDlg->PostMessage(UM_WARNING_OFFSET); + break; + + default: + break; + } + } + return 0; +} +/*< LYW 20211029 - #3684 ADD End >*/ \ No newline at end of file -- Gitblit v1.9.3