// CameraViewReview.cpp : 구현 파일입니다.
|
//
|
|
#include "stdafx.h"
|
#include "CameraViewReview.h"
|
#include "CHImageControls/CHBufferDC.h"
|
|
using namespace CHImageControls;
|
|
// CCameraViewReview
|
#define IDR_SAVE_AS_IMAGE 10001
|
#define IDR_MANUAL_SIMUL 10002
|
|
IMPLEMENT_DYNAMIC(CCameraViewReview, CCameraImageView)
|
|
CCameraViewReview::CCameraViewReview(CWnd *pParentWnd) : CCameraImageView(pParentWnd)
|
{
|
m_bDrawROIRect = TRUE;
|
|
m_rectTracker.m_rect = CRect(0,0,0,0);
|
m_rectTracker.m_nStyle = CRectTracker::dottedLine | CRectTracker::resizeOutside | crossLine | xLine;
|
m_rectTracker.m_sizeMin = CSize(8,8);
|
m_bDrawTracker = FALSE;
|
|
m_ptDefectPos = CPoint(-1, -1);
|
|
m_bUseOnlyImageSave = TRUE;
|
}
|
|
CCameraViewReview::~CCameraViewReview()
|
{
|
}
|
|
BEGIN_MESSAGE_MAP(CCameraViewReview, CCameraImageView)
|
ON_WM_PAINT()
|
ON_COMMAND(IDR_ROI_RECT,&CCameraViewReview::OnROIRect)
|
ON_COMMAND(IDR_CLEAR_ROI_RECT,&CCameraViewReview::OnClearROIRect)
|
ON_COMMAND(IDR_SAVE_ROI_RECT,&CCameraViewReview::OnSaveROIRect)
|
ON_COMMAND(IDR_SAVE_IMAGE, &CCameraViewReview::OnSaveImage)
|
ON_COMMAND(IDR_SAVE_AS_IMAGE, &CCameraViewReview::OnSaveAsImage)
|
ON_COMMAND(IDR_MANUAL_SIMUL, &CCameraViewReview::OnManualSimulation)
|
ON_COMMAND(IDR_ONLY_SAVE_IMAGE, &CCameraViewReview::OnUseOnlyImageSave)
|
ON_WM_LBUTTONDOWN()
|
ON_WM_LBUTTONUP()
|
ON_WM_LBUTTONDBLCLK()
|
ON_WM_RBUTTONDOWN()
|
ON_WM_RBUTTONUP()
|
ON_WM_RBUTTONDBLCLK()
|
ON_WM_SETCURSOR()
|
ON_WM_MOUSEMOVE()
|
END_MESSAGE_MAP()
|
|
|
// CCameraViewReview 메시지 처리기입니다.
|
void CCameraViewReview::OnPaint()
|
{
|
CCHBufferDC *pDC = new CCHBufferDC(this); // device context for painting
|
|
UpdateImageView(pDC);
|
|
if (m_bDrawROIRect)
|
{
|
m_rectTracker.m_nStyle = CRectTracker::dottedLine;// | CRectTracker::resizeOutside;
|
DrawROIRect(pDC);
|
}
|
else
|
{
|
m_rectTracker.m_nStyle = CRectTracker::dottedLine | CRectTracker::resizeOutside | crossLine | xLine;;
|
}
|
|
m_rectTracker.m_rect.NormalizeRect();
|
if (m_rectTracker.m_rect.left>0 && m_rectTracker.m_rect.right<GetScaleWidth())
|
{
|
if (m_rectTracker.m_rect.top>0 && m_rectTracker.m_rect.bottom<GetScaleHeight())
|
{
|
m_rectTracker.Draw(pDC);
|
}
|
}
|
|
DrawDefectPos(pDC);
|
|
delete pDC;
|
|
}
|
|
void CCameraViewReview::SetDrawROIRect(BOOL bDraw)
|
{
|
m_bDrawROIRect = bDraw;
|
Invalidate(TRUE);
|
}
|
|
void CCameraViewReview::DrawDefectPos(CDC *pDC)
|
{
|
if (m_ptDefectPos.x==-1 || m_ptDefectPos.y==-1) return;
|
|
pDC->SelectStockObject(WHITE_PEN);
|
pDC->SelectStockObject(NULL_BRUSH);
|
|
CRect rtRect;
|
rtRect.left = m_ptDefectPos.x - 50;
|
rtRect.right = m_ptDefectPos.x + 50;
|
rtRect.top = m_ptDefectPos.y - 50;
|
rtRect.bottom = m_ptDefectPos.y + 50;
|
|
pDC->Rectangle(rtRect);
|
}
|
|
void CCameraViewReview::DrawROIRect(CDC *pDC)
|
{
|
if (m_rtROIRect.Width()==0 || m_rtROIRect.Height()==0) return;
|
|
// CPen pen, *pOldPen;
|
// pen.CreatePen(PS_DOT, 1, RGB(255,255,255));
|
// pOldPen = pDC->SelectObject(&pen);
|
// pDC->SelectStockObject(NULL_BRUSH);
|
//
|
// pDC->Rectangle(m_rtROIRect);
|
|
CFont font;
|
VERIFY(font.CreateFont(
|
15, // nHeight
|
6, // nWidth
|
0, // nEscapement
|
0, // nOrientation
|
FW_NORMAL, // nWeight
|
FALSE, // bItalic
|
FALSE, // bUnderline
|
0, // cStrikeOut
|
ANSI_CHARSET, // nCharSet
|
OUT_DEFAULT_PRECIS, // nOutPrecision
|
CLIP_DEFAULT_PRECIS, // nClipPrecision
|
DEFAULT_QUALITY, // nQuality
|
DEFAULT_PITCH | FF_SWISS, // nPitchAndFamily
|
_T("Arial"))); // lpszFacename
|
|
// Do something with the font just created...
|
CFont* def_font = pDC->SelectObject(&font);
|
// pDC->SetTextColor(RGB(255,255,255));
|
// pDC->SetBkMode(TRANSPARENT);
|
pDC->SetTextColor(RGB(255,255,0));
|
pDC->SetBkColor(RGB(0, 0, 0));
|
pDC->SetBkMode(OPAQUE);
|
|
CString strValue = _T("");
|
strValue.Format(_T("[Region] %d, %d, %d, %d"), m_rtROIRect.left, m_rtROIRect.top, m_rtROIRect.right, m_rtROIRect.bottom);
|
pDC->TextOut(m_rtROIRect.right+5, m_rtROIRect.top+5, strValue);
|
|
strValue.Format(_T("[Width] %d pix, %.3lf um"), m_sROIInfo.nWidthPixel, m_sROIInfo.dWidthRealUM);
|
pDC->TextOut(m_rtROIRect.right+5, m_rtROIRect.top+25, strValue);
|
|
strValue.Format(_T("[Height] %d pix, %.3lf um"), m_sROIInfo.nHeightPixel, m_sROIInfo.dHeightRealUM);
|
pDC->TextOut(m_rtROIRect.right+5, m_rtROIRect.top+45, strValue);
|
|
strValue.Format(_T("[Diagonal] %.3lf pix, %.3lf um"), m_sROIInfo.dDiagonalPixel, m_sROIInfo.dDiagonalRealUM);
|
pDC->TextOut(m_rtROIRect.right+5, m_rtROIRect.top+65, strValue);
|
|
strValue.Format(_T("[Resol_X] %.6lf um/pixel"), (m_dResolution/m_dWidthScale));
|
pDC->TextOut(m_rtROIRect.right+5, m_rtROIRect.top+85, strValue);
|
|
strValue.Format(_T("[Resol_Y] %.6lf um/pixel"), (m_dResolution/m_dHeightScale));
|
pDC->TextOut(m_rtROIRect.right+5, m_rtROIRect.top+105, strValue);
|
|
pDC->SelectObject(def_font);
|
|
}
|
|
void CCameraViewReview::OnROIRect()
|
{
|
m_bDrawROIRect = !m_bDrawROIRect;
|
Invalidate(TRUE);
|
}
|
|
void CCameraViewReview::OnClearROIRect()
|
{
|
ClearTrackerRect();
|
|
m_rtROIRect = CRect(0,0,0,0);
|
|
Invalidate(TRUE);
|
}
|
|
BOOL CCameraViewReview::GetTrackerRect(CRect& rtRect)
|
{
|
if (m_rectTracker.m_rect.Width()<0 || m_rectTracker.m_rect.Height()<0)
|
{
|
return FALSE;
|
}
|
|
rtRect = m_rectTracker.m_rect;
|
|
return TRUE;
|
}
|
|
void CCameraViewReview::SetDefectPos(const CPoint& ptPoint)
|
{
|
m_ptDefectPos = ptPoint;
|
Invalidate(TRUE);
|
}
|
|
void CCameraViewReview::SetTrackerRect(const CRect& rtRect)
|
{
|
m_rectTracker.m_rect = rtRect;
|
Invalidate(TRUE);
|
}
|
|
void CCameraViewReview::ClearTrackerRect()
|
{
|
m_rectTracker.m_rect = CRect(0,0,0,0);
|
Invalidate(TRUE);
|
}
|
|
void CCameraViewReview::OnSaveROIRect()
|
{
|
if (m_rtROIRect.Width()<1 || m_rtROIRect.Height()<1) return;
|
|
//CString szFilter = _T("All Files(*.*)|*.*||");
|
CString szFilter = _T("BMP(*.bmp)|*.bmp| JPG(*.jpg)|*.jpg| All Files(*.*)|*.*||");
|
|
CString strPath;
|
CFileDialog dlg(FALSE, NULL, NULL, OFN_HIDEREADONLY, szFilter);
|
dlg.m_ofn.lpstrTitle = _T("Save Image");
|
|
if(dlg.DoModal() == IDCANCEL) return;
|
|
CRect rtRect;
|
rtRect.left = int(double(m_rtROIRect.left) / m_dWidthScale + 0.5);
|
rtRect.top = int(double(m_rtROIRect.top) / m_dHeightScale + 0.5);
|
rtRect.right = int(double(m_rtROIRect.right) / m_dWidthScale + 0.5);
|
rtRect.bottom = int(double(m_rtROIRect.bottom) / m_dHeightScale + 0.5);
|
|
CCHImageData subImage;
|
if (GetSubImage(rtRect, &subImage)==FALSE)
|
{
|
return;
|
}
|
|
if (subImage.SaveImage(dlg.GetPathName())==FALSE) return;
|
|
return;
|
}
|
|
void CCameraViewReview::OnLButtonDown(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
if (m_pParentWnd==NULL || !GetImageExist()) return;
|
|
if (point.x > -1 && point.x < GetScaleWidth() &&
|
point.y > -1 && point.y < GetScaleHeight() )
|
{
|
if (m_rectTracker.HitTest(point) < 0)
|
{
|
// just to demonstrate CRectTracker::TrackRubberBand
|
if (m_rectTracker.TrackRubberBand(this, point, TRUE))
|
{
|
Invalidate();
|
}
|
}
|
else if (m_rectTracker.Track(this, point, TRUE))
|
{
|
Invalidate();
|
}
|
}
|
|
CRect rect;
|
this->GetClientRect(rect);
|
|
point.x += m_nHScroll;
|
point.y += m_nVScroll;
|
m_pParentWnd->SendMessage(WM_LBUTTONDOWN, static_cast<WPARAM>(nFlags), MAKELPARAM(point.x, point.y));
|
|
// __super::OnLButtonDown(nFlags, point);
|
}
|
|
void CCameraViewReview::OnLButtonUp(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
if (m_pParentWnd==NULL) return;
|
|
CRect rect;
|
this->GetClientRect(rect);
|
|
point.x += m_nHScroll;
|
point.y += m_nVScroll;
|
m_pParentWnd->SendMessage(WM_LBUTTONUP, static_cast<WPARAM>(nFlags), MAKELPARAM(point.x, point.y));
|
|
if (GetTrackerRect(m_rtROIRect))
|
{
|
m_sROIInfo.nWidthPixel = m_rtROIRect.Width();
|
m_sROIInfo.nHeightPixel = m_rtROIRect.Height();
|
m_sROIInfo.dDiagonalPixel = sqrt(double(m_sROIInfo.nWidthPixel*m_sROIInfo.nWidthPixel + m_sROIInfo.nHeightPixel*m_sROIInfo.nHeightPixel));
|
|
m_sROIInfo.dWidthRealUM = m_sROIInfo.nWidthPixel * (m_dResolution / m_dWidthScale) ;
|
m_sROIInfo.dHeightRealUM = m_sROIInfo.nHeightPixel * (m_dResolution / m_dHeightScale);
|
m_sROIInfo.dDiagonalRealUM = sqrt((m_sROIInfo.dWidthRealUM*m_sROIInfo.dWidthRealUM)+(m_sROIInfo.dHeightRealUM*m_sROIInfo.dHeightRealUM));
|
|
Invalidate(TRUE);
|
}
|
|
// __super::OnLButtonUp(nFlags, point);
|
}
|
|
void CCameraViewReview::OnLButtonDblClk(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
if (m_pParentWnd==NULL) return;
|
|
point.x += m_nHScroll;
|
point.y += m_nVScroll;
|
m_pParentWnd->SendMessage(WM_LBUTTONDBLCLK, static_cast<WPARAM>(nFlags), MAKELPARAM(point.x, point.y));
|
|
// __super::OnLButtonDblClk(nFlags, point);
|
}
|
|
void CCameraViewReview::ContextMenu(UINT nFlags, CPoint point )
|
{
|
CMenu menu;
|
CMenu popMenu;
|
menu.CreateMenu(); // 최상위 뼈대 메뉴
|
popMenu.CreatePopupMenu(); // 팝업메뉴
|
BOOL bAddMenu = FALSE;
|
|
popMenu.AppendMenu(MF_STRING, IDR_LOAD_IMAGE, _T("Load Image"));
|
popMenu.AppendMenu(MF_STRING, IDR_SAVE_IMAGE, _T("Save Image")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_STRING, IDR_SAVE_AS_IMAGE, _T("Save as Image")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_STRING, IDR_ONLY_SAVE_IMAGE, _T("Only Save Image")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_STRING, IDR_MANUAL_SIMUL, _T("Manual Simulation")); // 시뮬레이션 메뉴
|
popMenu.AppendMenu(MF_SEPARATOR);
|
popMenu.AppendMenu(MF_STRING, IDR_CENTER_LINE, _T("Center Line"));
|
popMenu.AppendMenu(MF_STRING, IDR_RULER, _T("Ruler"));
|
popMenu.AppendMenu(MF_STRING, IDR_ROI_RECT, _T("ROI Rect")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_STRING, IDR_CLEAR_ROI_RECT, _T("Clear ROI Rect")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_STRING, IDR_SAVE_ROI_RECT, _T("Save ROI Rect")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_SEPARATOR);
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_ORIGIN, _T("1:1 View"));
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_FIT, _T("Fit View")); // 색상의 서브메뉴 추가
|
popMenu.AppendMenu(MF_SEPARATOR);
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_COLOR, _T("Color"));
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_GRAY, _T("Gray"));
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_RED, _T("Red"));
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_GREEN, _T("Green"));
|
popMenu.AppendMenu(MF_STRING, IDR_VIEW_BLUE, _T("Blue"));
|
|
// 메뉴 상태 처리
|
if (m_bDrawCenterLine)
|
{
|
popMenu.CheckMenuItem(IDR_CENTER_LINE, MF_CHECKED);
|
}
|
|
if (m_bDrawRuler)
|
{
|
popMenu.CheckMenuItem(IDR_RULER, MF_CHECKED);
|
}
|
|
if (m_bDrawROIRect)
|
{
|
popMenu.CheckMenuItem(IDR_ROI_RECT, MF_CHECKED);
|
}
|
|
switch(m_nDrawMode)
|
{
|
case 0:
|
popMenu.CheckMenuItem(IDR_VIEW_ORIGIN, MF_CHECKED);
|
break;
|
case 1:
|
popMenu.CheckMenuItem(IDR_VIEW_FIT, MF_CHECKED);
|
break;
|
}
|
|
// 메뉴 상태 처리
|
switch(m_nViewBand)
|
{
|
case BandTypeRed:
|
popMenu.CheckMenuItem(IDR_VIEW_RED, MF_CHECKED);
|
break;
|
case BandTypeGreen:
|
popMenu.CheckMenuItem(IDR_VIEW_GREEN, MF_CHECKED);
|
break;
|
case BandTypeBlue:
|
popMenu.CheckMenuItem(IDR_VIEW_BLUE, MF_CHECKED);
|
break;
|
case BandTypeGray:
|
popMenu.CheckMenuItem(IDR_VIEW_GRAY, MF_CHECKED);
|
break;
|
default:
|
popMenu.CheckMenuItem(IDR_VIEW_COLOR, MF_CHECKED);
|
break;
|
}
|
|
// 컨텍스트 메뉴 호출
|
CRect rect;
|
GetWindowRect(rect);
|
int nX = rect.left + point.x;
|
int nY = rect.top + point.y;
|
popMenu.TrackPopupMenu(TPM_LEFTALIGN | TPM_RIGHTBUTTON, nX, nY, this);
|
|
if (m_pParentWnd==NULL) return;
|
point.x += m_nHScroll;
|
point.y += m_nVScroll;
|
m_pParentWnd->SendMessage(WM_RBUTTONDOWN, static_cast<WPARAM>(nFlags), MAKELPARAM(point.x, point.y));
|
}
|
|
void CCameraViewReview::OnRButtonDown(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
|
|
if(m_bUseOnlyImageSave)
|
ContextMenu(nFlags, point);
|
else
|
OnSaveImage(); //이미지 저장 모드 cmj 20180710
|
|
|
|
return;
|
|
// __super::OnRButtonDown(nFlags, point);
|
}
|
|
void CCameraViewReview::OnRButtonUp(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
if (m_pParentWnd==NULL) return;
|
|
point.x += m_nHScroll;
|
point.y += m_nVScroll;
|
m_pParentWnd->SendMessage(WM_RBUTTONUP, static_cast<WPARAM>(nFlags), MAKELPARAM(point.x, point.y));
|
|
// __super::OnRButtonUp(nFlags, point);
|
}
|
|
void CCameraViewReview::OnRButtonDblClk(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
if (m_pParentWnd==NULL) return;
|
|
point.x += m_nHScroll;
|
point.y += m_nVScroll;
|
|
m_bUseOnlyImageSave = TRUE;
|
AfxMessageBox(_T("Change Context Menu Mod"));
|
|
m_pParentWnd->SendMessage(WM_RBUTTONDBLCLK, static_cast<WPARAM>(nFlags), MAKELPARAM(point.x, point.y));
|
|
// __super::OnRButtonDblClk(nFlags, point);
|
}
|
void CCameraViewReview::OnUseOnlyImageSave()
|
{
|
m_bUseOnlyImageSave = FALSE;
|
AfxMessageBox(_T("Change Only Image Save Mod"));
|
|
}
|
|
|
BOOL CCameraViewReview::OnSetCursor(CWnd* pWnd, UINT nHitTest, UINT message)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
if (m_rectTracker.SetCursor(this, nHitTest))
|
return TRUE;
|
|
return CCameraImageView::OnSetCursor(pWnd, nHitTest, message);
|
}
|
|
void CCameraViewReview::OnMouseMove(UINT nFlags, CPoint point)
|
{
|
// TODO: 여기에 메시지 처리기 코드를 추가 및/또는 기본값을 호출합니다.
|
|
// CCameraImageView::OnMouseMove(nFlags, point);
|
}
|
|
void CCameraViewReview::OnSaveImage()
|
{
|
CString strSaveFilename = _T("");
|
|
if (m_pCIV2P==NULL)
|
{
|
CString szFilter = _T("BMP(*.bmp)|*.bmp| JPG(*.jpg)|*.jpg| All Files(*.*)|*.*||");
|
|
CString strPath;
|
CFileDialog dlg(FALSE, szFilter, NULL, OFN_HIDEREADONLY, szFilter);
|
dlg.m_ofn.lpstrTitle = _T("Save Image");
|
|
if(dlg.DoModal() == IDOK)
|
{
|
strSaveFilename = dlg.GetPathName();
|
}
|
else
|
{
|
return;
|
}
|
}
|
else
|
{
|
m_pCIV2P->CIV2P_GetImagePathName(strSaveFilename);
|
}
|
|
SaveImage(strSaveFilename);
|
|
}
|
|
void CCameraViewReview::OnSaveAsImage()
|
{
|
CCameraImageView::OnSaveImage();
|
|
}
|
|
void CCameraViewReview::OnManualSimulation()
|
{
|
if (m_pCIV2P==NULL) return;
|
|
m_pCIV2P->CIV2P_ManualSimulation(this);
|
|
Invalidate(FALSE);
|
}
|