From d179e328a058dba6782074c560b0853482dcc658 Mon Sep 17 00:00:00 2001
From: LYW <leeyeanwoo@diteam.co.kr>
Date: 목, 11 11월 2021 17:53:57 +0900
Subject: [PATCH] Ongoing70 #3766 CF AOI Review 전설비 설정한 기준치 이상 Offset 적용시 경고 기능 추가

---
 ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp |  196 ++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 194 insertions(+), 2 deletions(-)

diff --git a/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp b/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp
index 0f820c7..0b307fc 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,12 @@
 	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 >*/
+	m_CheckInsViewCenterLine.SetCheck(FALSE);
 
 	for (int i = 0; i < 105; i++)
 	{
@@ -93,6 +100,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 +126,8 @@
 	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);
+	DDX_Control(pDX, IDC_CHECK_INS_VIEW_CENTER_LINE, m_CheckInsViewCenterLine);
 }
 
 BEGIN_MESSAGE_MAP(CReveiwHistoryDlg, CDialogEx)
@@ -124,6 +140,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)
@@ -140,6 +157,7 @@
 	ON_WM_KEYDOWN()
 	ON_BN_CLICKED(IDC_BUTTON_OFFSET_APPLY, &CReveiwHistoryDlg::OnBnClickedButtonOffsetApply)
 	ON_BN_CLICKED(IDC_BUTTON_OFFSET_SAVE, &CReveiwHistoryDlg::OnBnClickedButtonOffsetSave)
+	ON_BN_CLICKED(IDC_CHECK_INS_VIEW_CENTER_LINE, &CReveiwHistoryDlg::OnBnClickedCheckInsViewCenterLine)
 END_MESSAGE_MAP()
 
 // CReveiwHistoryDlg 硫붿떆吏� 泥섎━湲�
@@ -329,6 +347,10 @@
 		{
 			dc.SetStretchBltMode(COLORONCOLOR);
 			m_AlignSecend.Draw(dc, m_Align_rect2);
+		}
+		if (m_CheckInsViewCenterLine.GetCheck() == TRUE)
+		{
+			DrawInsViewCenterLine(&dc);
 		}
 		CDialogEx::OnPaint();
 	}
@@ -1236,6 +1258,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 +1468,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 +1587,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 +1819,12 @@
 	{
 		SetScrollSetting();
 	}
+	/*< LYW 20211028 - #3684 ADD Start >*/
+	if (m_LastSaveOffsetTime >= m_CurrentResultFileTime)
+	{
+		PostThreadMessage(m_ThreadId, UM_THREAD_WARNING_OFFSET, 0, 0);
+	}
+	/*< LYW 20211028 - #3684 ADD End >*/
 }
 
 void CReveiwHistoryDlg::OnCbnSelchangeComboRawtype()
@@ -1797,6 +1839,25 @@
 
 	m_ConfigOption.m_nSelectRawType = 3;
 
+}
+
+void CReveiwHistoryDlg::DrawInsViewCenterLine(CPaintDC * pDC)
+{
+	if (m_picture_rect2.Width() == 0 || m_picture_rect2.Height() == 0) return;
+
+	CRect rtDraw = m_picture_rect2;
+
+	CPen pen, *pPen = NULL;
+	pen.CreatePen(PS_DOT, 1, RGB(255, 0, 0));
+	pDC->SelectObject(&pen);
+
+	//pDC->SelectStockObject(WHITE_PEN);
+
+	// center line
+	pDC->MoveTo((rtDraw.Width() / 2) + rtDraw.left, 0 + rtDraw.top);
+	pDC->LineTo((rtDraw.Width() / 2) + rtDraw.left, rtDraw.Height() + rtDraw.top);
+	pDC->MoveTo(0 + rtDraw.left, (rtDraw.Height() / 2) + rtDraw.top);
+	pDC->LineTo(rtDraw.Width() + rtDraw.left, (rtDraw.Height() / 2) + rtDraw.top);
 }
 
 void CReveiwHistoryDlg::OnBnClickedBtnFindBin()
@@ -2693,6 +2754,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)
 {
@@ -3939,6 +4057,7 @@
 {
 	// TODO: �뿬湲곗뿉 而⑦듃濡� �븣由� 泥섎━湲� 肄붾뱶瑜� 異붽��빀�땲�떎.
 	SaveOffset();
+	SendMsg2ReviewSystem();
 }
 
 BOOL CReveiwHistoryDlg::LoadOffset(CString strFilePath)
@@ -3949,9 +4068,15 @@
 	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);
+	/*< LYW 20211111 - #3766 ADD Start >*/
+	macroFile.GetItem(_T("WARN_STANDARD"), m_dWarnStandard, 0);
+	macroFile.GetItem(_T("HARD_STANDARD"), m_dHardStandard, 0);
+	/*< LYW 20211111 - #3766 ADD End >*/
 	CString strItem = _T("");
 	double dXoffset = 0;
 	double dYoffset = 0;
@@ -4004,6 +4129,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);
 
@@ -4028,6 +4156,14 @@
 
 	strItem.Format(_T("XPOS_COUNT"));
 	macroFile.SetItem(strItem, m_XposCount);
+
+	/*< LYW 20211111 - #3766 ADD Start >*/
+	strItem.Format(_T("WARN_STANDARD"));
+	macroFile.SetItem(strItem, m_dWarnStandard);
+
+	strItem.Format(_T("HARD_STANDARD"));
+	macroFile.SetItem(strItem, m_dHardStandard);
+	/*< LYW 20211111 - #3766 ADD End >*/
 
 
 	CString strData;
@@ -4070,10 +4206,35 @@
 
 	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;
+}
+
+BOOL CReveiwHistoryDlg::SendMsg2ReviewSystem()
+{
+	HWND hWnd = ::FindWindow(NULL, _T("ReviewSystem"));
+
+	if (hWnd)
+	{
+		COPYDATASTRUCT cds;
+		cds.dwData = COPYDATA_REVIEWHISTORYOR2REVIEWSYSTEM;
+		cds.cbData = 0;
+		cds.lpData = 0;
+
+		::SendMessage(hWnd, WM_COPYDATA, 0, (LPARAM)(LPVOID)&cds);
+
+		return TRUE;
+	}
+
+	return FALSE;
 }
 
 BOOL CReveiwHistoryDlg::ApplyOffset(int nModuleidx, int nCamIndex, int ScanIndex, double dXOffsetValue, double dYOffsetValue)
@@ -4259,3 +4420,34 @@
 	}
 }
 /*< 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 >*/
+
+void CReveiwHistoryDlg::OnBnClickedCheckInsViewCenterLine()
+{
+	// TODO: �뿬湲곗뿉 而⑦듃濡� �븣由� 泥섎━湲� 肄붾뱶瑜� 異붽��빀�땲�떎.
+	Invalidate(TRUE);
+	
+}

--
Gitblit v1.9.3