From aef69faaca3401fa1224884e686bce36b0c88acb Mon Sep 17 00:00:00 2001
From: LYW <leeyeanwoo@diteam.co.kr>
Date: 화, 26 10월 2021 16:57:35 +0900
Subject: [PATCH] Ongoing80 #3684 CF AOI Review 전설비 Review History Defect이미지 클릭시 Offset 자동 계산 기능 추가

---
 ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp |  505 +++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 500 insertions(+), 5 deletions(-)

diff --git a/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp b/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp
index 81b16e1..0f820c7 100644
--- a/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp
+++ b/ReviewHistory/ReveiwHistory/ReveiwHistoryDlg.cpp
@@ -12,6 +12,7 @@
 #include "akGridCtrl/GridCellCheck.h"
 #include "akImageView.h"
 #include <algorithm>
+#include "MacroFile.h"
 
 #ifdef _DEBUG
 #define new DEBUG_NEW
@@ -54,6 +55,11 @@
 CReveiwHistoryDlg::CReveiwHistoryDlg(CWnd* pParent /*=nullptr*/)
 	: CDialogEx(IDD_DLG_REVIEWHISTORY, pParent)
 	, m_nFileCount(0)
+	, m_nEditCamIdx(0)
+	, m_nEditScanIdx(0)
+	, m_dEditOffsetX(0)
+	, m_dEditOffsetY(0)
+	, m_strGantryIdx(_T(""))
 {
 	m_hIcon = AfxGetApp()->LoadIcon(IDR_MAINFRAME);
 
@@ -73,6 +79,10 @@
 	m_nImageCount = 0;
 	m_nCellCount = 0;
 	m_bAsending = FALSE;
+	/*< LYW 20211018 - #3684 ADD Start >*/
+	m_dCurDefectIdx = 0;
+	m_dCurDefectID = 0;
+	/*< LYW 20211018 - #3684 ADD End >*/
 
 	for (int i = 0; i < 105; i++)
 	{
@@ -97,6 +107,11 @@
 	DDX_Text(pDX, IDC_EDIT_FILE_COUNT, m_nFileCount);
 	DDX_Control(pDX, IDC_EDIT_FILE_COUNT, m_ctlFileCount);
 	DDX_Control(pDX, IDC_PROGRESS_LOAD, m_ctlProgress);
+	DDX_Text(pDX, IDC_EDIT_OFFSET_CAM_IDX, m_nEditCamIdx);
+	DDX_Text(pDX, IDC_EDIT_OFFSET_SCAN_IDX, m_nEditScanIdx);
+	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);
 }
 
 BEGIN_MESSAGE_MAP(CReveiwHistoryDlg, CDialogEx)
@@ -109,6 +124,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_FORMMAP_IMAGEMOUSECLICK, OnImageClick)
 	ON_COMMAND(ID_OPTION_PATHSETTING, &CReveiwHistoryDlg::OnOptionPathsetting)
 	ON_COMMAND(ID_VIEW_ALLDEFECT, &CReveiwHistoryDlg::OnViewAlldefect)
 	ON_COMMAND(ID_VIEW_REVIEWDEFECT, &CReveiwHistoryDlg::OnViewReviewdefect)
@@ -121,6 +137,9 @@
 	ON_BN_CLICKED(IDC_CHK_REVIEW_DEFECT, &CReveiwHistoryDlg::OnClickedChkReviewDefect)
 	ON_BN_CLICKED(IDC_CHK_SINGLE, &CReveiwHistoryDlg::OnClickedChkSingle)
 	ON_EN_CHANGE(IDC_EDIT_FILE_COUNT, &CReveiwHistoryDlg::OnChangeEditFileCount)
+	ON_WM_KEYDOWN()
+	ON_BN_CLICKED(IDC_BUTTON_OFFSET_APPLY, &CReveiwHistoryDlg::OnBnClickedButtonOffsetApply)
+	ON_BN_CLICKED(IDC_BUTTON_OFFSET_SAVE, &CReveiwHistoryDlg::OnBnClickedButtonOffsetSave)
 END_MESSAGE_MAP()
 
 // CReveiwHistoryDlg 硫붿떆吏� 泥섎━湲�
@@ -193,6 +212,13 @@
 	InitGridReviewLIst(&m_gridReviewList, IDC_STATIC_GRID_GLASS);
 	InitGridDefectLIst(&m_gridDefectInfo, IDC_STATIC_GRID_DEFECT);
 	InitGridGlassLIst(&m_gridGlassInfo, IDC_STATIC_GRID_GLASS_INFO);
+
+	/*< LYW 20211025 - #3684 ADD Start >*/
+	CString strPath = _T("");
+	InitDataInfo();
+	strPath.Format(_T("%s%s"), REVIEW_OFFSET_CONFIGFILE_PATH, REVIEW_OFFSET_CONFIGFILE_NAME);
+	LoadOffset(strPath);
+	/*< LYW 20211025 - #3684 ADD End >*/
 
 	OnViewReviewdefect();
 
@@ -279,7 +305,15 @@
 // 			// 洹몃┝�쓣 Picture Control �겕湲곕줈 �솕硫댁뿉 異쒕젰�븳�떎.
 // 			m_ReviewImage.Draw(dc, m_picture_rect);
 // 		}
-		if (!m_DefectImage.IsNull())
+		//LYW 20210825 #3486 ADD START
+		if (!m_DefectRotateImage.IsNull())
+		{
+			dc.SetStretchBltMode(COLORONCOLOR);
+			// 洹몃┝�쓣 Picture Control �겕湲곕줈 �솕硫댁뿉 異쒕젰�븳�떎.
+			m_DefectRotateImage.Draw(dc, m_picture_rect2);
+		}
+		//LYW 20210825 #3486 ADD END
+		else if (!m_DefectImage.IsNull())
 		{
 			dc.SetStretchBltMode(COLORONCOLOR);
 			// 洹몃┝�쓣 Picture Control �겕湲곕줈 �솕硫댁뿉 異쒕젰�븳�떎.
@@ -730,7 +764,7 @@
 
 			return TRUE;
 		}
-		else if (NM_CLICK == pDispInfo->hdr.code)
+		else if (NM_CLICK == pDispInfo->hdr.code || LVN_ITEMCHANGING == pDispInfo->hdr.code)
 		{
 			if (pDispInfo->item.row == 0)
 			{
@@ -856,7 +890,7 @@
 
 			return TRUE;
 		}
-		else if (NM_CLICK == pDispInfo->hdr.code)
+		else if (NM_CLICK == pDispInfo->hdr.code || LVN_ITEMCHANGING == pDispInfo->hdr.code)
 		{
 			if (pDispInfo->item.row == 0)
 			{
@@ -870,6 +904,7 @@
 					_akDefect* pDefectInfo = &m_Formation.m_vecDefects[pDispInfo->item.row - 1];
 
 					m_FormationMap.setSelectDefect(pDefectInfo->m_nDefectID);
+					
 					//ImageShow(pDefectInfo->m_nDefectID);
 					if (!m_bDefectAll)
 					{
@@ -1210,6 +1245,62 @@
 
 	return 0;
 }
+
+/*< LYW 20211018 - #3684 ADD Start >*/
+LRESULT CReveiwHistoryDlg::OnImageClick(WPARAM wParam, LPARAM lParam)
+{
+	CPathSettingDlg* lpDlg = CPathSettingDlg::GetMgr();
+	if (lpDlg == NULL) return 0;
+	
+	_akDefect			*pDefect;
+ 	pDefect = &m_Formation.m_vecDefects[m_dCurDefectIdx];
+	if (pDefect == NULL) return 0;
+
+	CPoint Point;
+	Point.x = GET_X_LPARAM(lParam);
+	Point.y = GET_Y_LPARAM(lParam);
+
+	int dOffsetDrectionX;
+	int dOffsetDrectionY;
+
+	if (lpDlg->m_comboDirectionX.GetCurSel() == 1) dOffsetDrectionX = -1;
+	else dOffsetDrectionX = 1;
+
+	if (lpDlg->m_comboDirectionY.GetCurSel() == 1) dOffsetDrectionY = -1;
+	else dOffsetDrectionY = 1;
+
+	if (pDefect->m_nDefectID == m_dCurDefectID)
+	{
+		m_nEditCamIdx = pDefect->m_nCameraID;
+		m_nEditScanIdx = pDefect->m_nScanIdx;
+		m_nCurModelIdx = pDefect->m_nModelIdx;
+		if (m_nCurModelIdx == 0)
+		{
+			m_strGantryIdx = _T("Left");
+			m_dEditOffsetX = (double)(dOffsetDrectionX * (Point.x / 5)) / 1000;
+			m_dEditOffsetY = (double)-(dOffsetDrectionY * (Point.y / 5)) / 1000;
+		}
+		else if (m_nCurModelIdx == 1)
+		{
+			m_strGantryIdx = _T("Right");
+			m_dEditOffsetX = (double)-(dOffsetDrectionX * (Point.x / 5)) / 1000;
+			m_dEditOffsetY = (double)-(dOffsetDrectionY * (Point.y / 5)) / 1000;
+		}
+		else AfxMessageBox(_T("寃먰듃由� �씤�뜳�뒪媛� 鍮꾩젙�긽 �엯�땲�떎."), MB_OK | MB_ICONWARNING);
+	}
+
+	else
+	{
+		if (IDOK == AfxMessageBox(_T("�씠誘몄� �씤�뜳�뒪媛� �씪移섑븯吏� �븡�뒿�땲�떎."), MB_OK | MB_ICONWARNING))
+		{
+			return 0;
+		}
+	}
+
+	UpdateData(FALSE);
+	return 0;
+}
+/*< LYW 20211018 - #3684 ADD End >*/
 
 LRESULT CReveiwHistoryDlg::OnMapDefectMouseOver(WPARAM wParam, LPARAM lParam)
 {
@@ -1968,6 +2059,9 @@
 
 	m_DefectImage.Destroy();
 	m_ReviewImage.Destroy();
+	//LYW 20210825 #3486 ADD START
+	m_DefectRotateImage.Destroy();
+	//LYW 20210825 #3486 ADD END
 
 	m_AlignFirst.Destroy();
 	m_AlignSecend.Destroy();
@@ -2010,6 +2104,13 @@
 		}
 	}
 	_akReviewList* pImageInfo = &m_Formation.m_vecImage[nIndex];
+	m_dCurDefectID = pImageInfo->m_nDefectID;
+ 	m_dCurDefectIdx = nIndex;
+// 	_akDefect			*pDefect;
+// 	pDefect = &m_Formation.m_vecDefects[nIndex];
+// 	m_dCurDefectCam = pDefect->m_nCameraID;
+// 	m_dCurDefectModuleIdx = pDefect->m_nModelIdx;
+// 	m_dCurDefectScan = pDefect->m_nScanIdx;
 	//紐� 踰덉㎏ �씤吏� �뜕吏꾨떎.
 
 	CString wekfjlwe = pImageInfo->m_strReviewImageName;
@@ -2055,7 +2156,7 @@
 	DeftectPath.Format(_T("%s\\%s\\%s"), strReviewPath, strReviewImagePath, strReviewImageName);
 	//DeftectPath2.Format(_T("%s\\%s"), strInspectorPath, strInspectorName);
 	if (strInspectorName == "*" || strInspectorName == "**" || strInspectorName == "***") strInspectorName = "";
-	DeftectPath2.Format(_T("%s\\%s\\%s"), strInspectorPath, pImageInfo->m_strGlassID, strReviewImageName);
+	DeftectPath2.Format(_T("%s\\%s\\%s"), strInspectorPath, pImageInfo->m_strGlassID, strInspectorName);
 
 	AlignPath.Format(_T("%s\\%s\\%s"), strAlignPath, pImageInfo->m_strGlassID, strAlignName);
 	AlignPath2.Format(_T("%s\\%s\\%s"), strAlignPath, pImageInfo->m_strGlassID, strAlignName2);
@@ -2096,13 +2197,21 @@
 	if (CFile::GetStatus(DeftectPath2, FileOn) && strInspectorName != "") //�뙆�씪�씠 �엳�쓣 �븣
 	{
 		m_DefectImage.Load(DeftectPath2);
+		//LYW 20210825 #3486 ADD START
+		m_DefectRotateImage.Create(m_DefectImage.GetWidth(), m_DefectImage.GetHeight(), m_DefectImage.GetBPP(), 0);
+		ImageRotate(m_DefectImage, m_DefectRotateImage);
+		//LYW 20210825 #3486 ADD END
 		HBITMAP hBmp = (HBITMAP)::LoadImage(AfxGetInstanceHandle(), DeftectPath2,
 			IMAGE_BITMAP, 0, 0, LR_LOADFROMFILE | LR_CREATEDIBSECTION);
 
 
 		InvalidateRect(m_picture_rect2, FALSE);
 		dc.SetStretchBltMode(COLORONCOLOR);
-		m_DefectImage.Draw(dc, m_picture_rect2);
+		//LYW 20210825 #3486 MOD START
+		m_DefectRotateImage.Draw(dc, m_picture_rect2);
+		//LYW 20210825 #3486 MOD END
+		//original
+		//m_DefectImage.Draw(dc, m_picture_rect2);
 	}
 	else
 	{
@@ -2490,6 +2599,9 @@
 
 //	m_ReviewImage.Destroy();
 	m_DefectImage.Destroy();
+	//LYW 20210825 #3486 ADD START
+	m_DefectRotateImage.Destroy();
+	//LYW 20210825 #3486 ADD END
 	m_AlignFirst.Destroy();
 	m_AlignSecend.Destroy();
 
@@ -2526,6 +2638,48 @@
 	m_AlignFirst.Draw(dc, m_Align_rect);
 	m_AlignSecend.Draw(dc, m_Align_rect2);
 }
+
+//LYW 20210825 #3486 ADD START
+void CReveiwHistoryDlg::ImageRotate(CImage & SrcImage, CImage & DstImage, double degree/* = 180.0 */)
+{
+	int Height = SrcImage.GetHeight(); // �꽭濡� 湲몄씠 ���옣
+	int Width = SrcImage.GetWidth(); // 媛�濡� 湲몄씠 ���옣
+	int new_x, new_y;
+	int R, G, B;
+	int center_x = (SrcImage.GetWidth() / 2); // �쉶�쟾 以묒떖�젏
+	int center_y = (SrcImage.GetHeight() / 2); // �쉶�쟾 以묒떖�젏
+
+	double seta = 3.14 / (180.0 / degree); // �씪�뵒�븞
+	double CosSeta = cos(seta);
+	double SinSeta = sin(seta);
+
+	for (int y = 0; y < Height; y++)
+	{
+		for (int x = 0; x < Width; x++)
+		{
+			new_x = (int)((x - center_x) * CosSeta - (y - center_y) * SinSeta + center_x);
+			new_y = (int)((x - center_x) * SinSeta + (y - center_y) * CosSeta + center_y);
+
+			if ((new_x < 0) || (new_x > Width) || (new_y < 0) || (new_y > Height))
+				//�씠誘몄� 踰붿쐞瑜� 踰쀬뼱�굹硫� 0 媛�
+			{
+				R = 0;
+				G = 0;
+				B = 0;
+			}
+			else
+			{
+				R = GetRValue(SrcImage.GetPixel(new_x, new_y));
+				G = GetGValue(SrcImage.GetPixel(new_x, new_y));
+				B = GetBValue(SrcImage.GetPixel(new_x, new_y));
+			}
+			DstImage.SetPixel((int)x, (int)y, RGB(R, G, B));
+			new_x = 0; new_y = 0;
+		}
+	}
+
+}
+//LYW 20210825 #3486 ADD END
 
 void CReveiwHistoryDlg::OnChangeEditFileCount()
 {
@@ -3764,3 +3918,344 @@
 	}
 	m_Formation.m_vecHeaderTemp.clear();
 }
+
+
+void CReveiwHistoryDlg::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags)
+{
+	// TODO: �뿬湲곗뿉 硫붿떆吏� 泥섎━湲� 肄붾뱶瑜� 異붽� 諛�/�삉�뒗 湲곕낯媛믪쓣 �샇異쒗빀�땲�떎.
+
+	CDialogEx::OnKeyDown(nChar, nRepCnt, nFlags);
+}
+
+/*< LYW 20211025 - #3684 ADD Start >*/
+void CReveiwHistoryDlg::OnBnClickedButtonOffsetApply()
+{
+	// TODO: �뿬湲곗뿉 而⑦듃濡� �븣由� 泥섎━湲� 肄붾뱶瑜� 異붽��빀�땲�떎.
+	ApplyOffset(m_nCurModelIdx, m_nEditCamIdx, m_nEditScanIdx, m_dEditOffsetX, m_dEditOffsetY);
+}
+
+
+void CReveiwHistoryDlg::OnBnClickedButtonOffsetSave()
+{
+	// TODO: �뿬湲곗뿉 而⑦듃濡� �븣由� 泥섎━湲� 肄붾뱶瑜� 異붽��빀�땲�떎.
+	SaveOffset();
+}
+
+BOOL CReveiwHistoryDlg::LoadOffset(CString strFilePath)
+{
+	//dBarValue = 0;
+	CMacroFile macroFile;
+
+	if (!macroFile.Read(strFilePath))
+		return FALSE;
+
+	macroFile.GetItem(_T("CAMERA_COUNT"), m_nCameraCount, 0);
+	macroFile.GetItem(_T("SCAN_COUNT"), m_nScanCount, 0);
+	macroFile.GetItem(_T("XPOS_COUNT"), m_XposCount, 0);
+	CString strItem = _T("");
+	double dXoffset = 0;
+	double dYoffset = 0;
+	double dXMin = 0;
+	double dXMAX = 0;
+
+	double dValue = 0;
+	dValue = 2 * CAM_MAX_COUNT*SCAN_MAX_COUNT;
+	dValue = 1600 / dValue;
+
+	for (int nModuleidx = 0; nModuleidx < 2; nModuleidx++)
+	{
+		for (int nCamidx = 0; nCamidx < CAM_MAX_COUNT; nCamidx++)
+		{
+			for (int nScanidx = 0; nScanidx < SCAN_MAX_COUNT; nScanidx++)
+			{
+
+				for (int nXposIndex = 0; nXposIndex < XPOS_MAX_COUNT; nXposIndex++)
+				{
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_OFFSET_X"), nModuleidx, nCamidx, nScanidx, nXposIndex);
+					macroFile.GetItem(strItem, dXoffset);
+
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_OFFSET_Y"), nModuleidx, nCamidx, nScanidx, nXposIndex);
+					macroFile.GetItem(strItem, dYoffset);
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_XPOS_X_MIN"), nModuleidx, nCamidx, nScanidx, nXposIndex);
+					macroFile.GetItem(strItem, dXMin);
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_XPOS_X_MAN"), nModuleidx, nCamidx, nScanidx, nXposIndex);
+					macroFile.GetItem(strItem, dXMAX);
+
+					SetInputOffSet(nModuleidx, nCamidx, nScanidx, nXposIndex, dXoffset, dYoffset, dXMin, dXMAX);
+
+				}
+				//IncressProcessBar(dValue);
+			}
+		}
+	}
+
+	return TRUE;
+
+}
+
+BOOL CReveiwHistoryDlg::SaveOffset()
+{
+	//dBarValue = 0;
+
+	CString strForderPath;
+	CString strFileName;
+	CTime time = CTime::GetCurrentTime();
+	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);
+
+	CopyFile(REVIEW_OFFSET_CONFIGFILE_FULL_PATHNAME, strForderPath, FALSE);
+
+	BOOL bReturn = FALSE;
+	CString strTemp;
+	int nTemp;
+	double dTemp;
+
+	CMacroFile macroFile;
+	macroFile.Clear();
+
+	CString strItem = _T("");
+
+
+	strItem.Format(_T("CAMERA_COUNT"));
+	macroFile.SetItem(strItem, m_nCameraCount);
+
+	strItem.Format(_T("SCAN_COUNT"));
+	macroFile.SetItem(strItem, m_nScanCount);
+
+	strItem.Format(_T("XPOS_COUNT"));
+	macroFile.SetItem(strItem, m_XposCount);
+
+
+	CString strData;
+	double dData = 0;
+	for (int nModuleidx = 0; nModuleidx < 2; nModuleidx++)
+	{
+		for (int nCamidx = 0; nCamidx < CAM_MAX_COUNT; nCamidx++)
+		{
+			for (int nScanidx = 0; nScanidx < SCAN_MAX_COUNT; nScanidx++)
+			{
+
+				for (int nXposIndex = 0; nXposIndex < XPOS_MAX_COUNT; nXposIndex++)
+				{
+
+					OffSetInfo pOffSet = GetOffSetInfo(nModuleidx, nCamidx, nScanidx, nXposIndex);
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_OFFSET_X"), nModuleidx, nCamidx, nScanidx);
+					dData = pOffSet.dXoffSetValue;
+					macroFile.SetItem(strItem, dData);
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_OFFSET_Y"), nModuleidx, nCamidx, nScanidx);
+					dData = pOffSet.dYoffSetValue;
+					macroFile.SetItem(strItem, dData);
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_XPOS_X_MIN"), nModuleidx, nCamidx, nScanidx);
+					dData = pOffSet.dXposMin;
+					macroFile.SetItem(strItem, dData);
+
+					strItem.Format(_T("MODULE[%d]_CAM[%d]_SCAN[%d]_IDX[%d]_XPOS_X_MAN"), nModuleidx, nCamidx, nScanidx);
+					dData = pOffSet.dXposMax;
+					macroFile.SetItem(strItem, dData);
+				}
+				//IncressProcessBar(5);
+			}
+		}
+	}
+
+	CString strFilePath;
+	strFilePath.Format(_T("%s%s"), REVIEW_OFFSET_CONFIGFILE_PATH, REVIEW_OFFSET_CONFIGFILE_NAME);
+
+	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);
+
+	return bReturn;
+}
+
+BOOL CReveiwHistoryDlg::ApplyOffset(int nModuleidx, int nCamIndex, int ScanIndex, double dXOffsetValue, double dYOffsetValue)
+{
+	if (nCamIndex > CAM_MAX_COUNT || nCamIndex < 0)
+	{
+		return FALSE;
+	}
+
+	if (ScanIndex > SCAN_MAX_COUNT || ScanIndex < 0)
+	{
+		return FALSE;
+	}
+
+
+	if (nModuleidx == 0)
+	{
+		VecOffSetScanData* pScandata = &m_vecOffSetCameraInfo[nCamIndex];
+		VecOffSetData* pData = &pScandata->at(ScanIndex);
+		OffSetInfo* pOffSetData = &pData->at(0);
+		if (pOffSetData->bCheckSave == TRUE)
+		{
+			AfxMessageBox(_T("�씠誘� ���옣�븳 OFFSET �엯�땲�떎. �떎�떆 �뀑�똿�쓣 �썝�븯�떆硫� �봽濡쒓렇�옩�쓣 �옱�떆�옉 �빐二쇱꽭�슂"), MB_OK | MB_ICONWARNING);
+			return FALSE;
+		}
+		else
+		{
+			pOffSetData->dXoffSetValue += dXOffsetValue;
+			pOffSetData->dYoffSetValue += dYOffsetValue;
+			pOffSetData->bCheckSave = TRUE;
+		}
+	}
+	else if (nModuleidx == 1)
+	{
+		VecOffSetScanData* pScandata = &m_vecOffSetCameraInfo2[nCamIndex];
+		VecOffSetData* pData = &pScandata->at(ScanIndex);
+		OffSetInfo* pOffSetData = &pData->at(0);
+		if (pOffSetData->bCheckSave == TRUE)
+		{
+			AfxMessageBox(_T("�씠誘� ���옣�븳 OFFSET �엯�땲�떎. �떎�떆 �뀑�똿�쓣 �썝�븯�떆硫� �봽濡쒓렇�옩�쓣 �옱�떆�옉 �빐二쇱꽭�슂"), MB_OK | MB_ICONWARNING);
+			return FALSE;
+		}
+		else
+		{
+			pOffSetData->dXoffSetValue += dXOffsetValue;
+			pOffSetData->dYoffSetValue += dYOffsetValue;
+			pOffSetData->bCheckSave = TRUE;
+		}
+	}
+	else
+	{
+		return FALSE;
+	}
+}
+
+BOOL CReveiwHistoryDlg::SetInputOffSet(int nModuleidx, int nCamIndex, int ScanIndex, int nXposIndex, double dXOffsetValue, double dYOffsetValue, double dXposMin, double dXposMax, BOOL bCheckSave/* = 0*/)
+{
+	if (nCamIndex > CAM_MAX_COUNT || nCamIndex < 0)
+	{
+		return FALSE;
+	}
+
+	if (ScanIndex > SCAN_MAX_COUNT || ScanIndex < 0)
+	{
+		return FALSE;
+	}
+
+
+	if (nModuleidx == 0)
+	{
+		VecOffSetScanData* pScandata = &m_vecOffSetCameraInfo[nCamIndex];
+		VecOffSetData* pData = &pScandata->at(ScanIndex);
+		OffSetInfo* pOffSetData = &pData->at(nXposIndex);
+		pOffSetData->dXoffSetValue = dXOffsetValue;
+		pOffSetData->dYoffSetValue = dYOffsetValue;
+		pOffSetData->dXposMin = dXposMin;
+		pOffSetData->dXposMax = dXposMax;
+		pOffSetData->bCheckSave = bCheckSave;
+
+	}
+	else if (nModuleidx == 1)
+	{
+		VecOffSetScanData* pScandata = &m_vecOffSetCameraInfo2[nCamIndex];
+		VecOffSetData* pData = &pScandata->at(ScanIndex);
+		OffSetInfo* pOffSetData = &pData->at(nXposIndex);
+		pOffSetData->dXoffSetValue = dXOffsetValue;
+		pOffSetData->dYoffSetValue = dYOffsetValue;
+		pOffSetData->dXposMin = dXposMin;
+		pOffSetData->dXposMax = dXposMax;
+		pOffSetData->bCheckSave = bCheckSave;
+	}
+	else
+	{
+		return FALSE;
+	}
+}
+
+void CReveiwHistoryDlg::InitDataInfo()
+{
+	//誘몃━ 怨듦컙 �븷�떦
+	for (int nCamidx = 0; nCamidx < CAM_MAX_COUNT; nCamidx++)
+	{
+
+		VecOffSetScanData pVecScanData;
+		for (int nScanidx = 0; nScanidx < SCAN_MAX_COUNT; nScanidx++)
+		{
+			VecOffSetData     pVecData;
+			for (int nXposIndex = 0; nXposIndex < XPOS_MAX_COUNT; nXposIndex++)
+			{
+
+				OffSetInfo pInfo;
+				pInfo.nXposIndex = nXposIndex;
+				pInfo.nScanIndex = nScanidx;
+				pInfo.nCamIndex = nCamidx;
+				pVecData.push_back(pInfo);
+
+			}
+			pVecScanData.push_back(pVecData);
+
+		}
+
+		m_vecOffSetCameraInfo.push_back(pVecScanData);
+	}
+
+	for (int nCamidx = 0; nCamidx < CAM_MAX_COUNT; nCamidx++)
+	{
+
+		VecOffSetScanData pVecScanData;
+		for (int nScanidx = 0; nScanidx < SCAN_MAX_COUNT; nScanidx++)
+		{
+			VecOffSetData     pVecData;
+			for (int nXposIndex = 0; nXposIndex < XPOS_MAX_COUNT; nXposIndex++)
+			{
+
+				OffSetInfo pInfo;
+				pInfo.nXposIndex = nXposIndex;
+				pInfo.nScanIndex = nScanidx;
+				pInfo.nCamIndex = nCamidx;
+				pVecData.push_back(pInfo);
+
+			}
+			pVecScanData.push_back(pVecData);
+
+		}
+
+		m_vecOffSetCameraInfo2.push_back(pVecScanData);
+	}
+
+}
+
+OffSetInfo CReveiwHistoryDlg::GetOffSetInfo(int nModuleidx, int nCamIndex, int ScanIndex, int nXposIndex)
+{
+	OffSetInfo pOFF;
+	if (nCamIndex > CAM_MAX_COUNT || nCamIndex < 0)
+	{
+		return pOFF;
+	}
+
+	if (ScanIndex > SCAN_MAX_COUNT || ScanIndex < 0)
+	{
+		return pOFF;
+	}
+
+
+	if (nModuleidx == 0)
+	{
+		VecOffSetScanData* pScandata = &m_vecOffSetCameraInfo[nCamIndex];
+		VecOffSetData* pData = &pScandata->at(ScanIndex);
+		OffSetInfo* pOffSetData = &pData->at(nXposIndex);
+
+		return *pOffSetData;
+	}
+	else if (nModuleidx == 1)
+	{
+		VecOffSetScanData* pScandata = &m_vecOffSetCameraInfo2[nCamIndex];
+		VecOffSetData* pData = &pScandata->at(ScanIndex);
+		OffSetInfo* pOffSetData = &pData->at(nXposIndex);
+		return *pOffSetData;
+	}
+	else
+	{
+		return pOFF;
+	}
+}
+/*< LYW 20211025 - #3684 ADD End >*/

--
Gitblit v1.9.3