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