📄 dipdoc.cpp
字号:
// DipDoc.cpp : implementation of the CDipDoc class
//
#include "stdafx.h"
#include "Dip.h"
#include "DipDoc.h"
#include "MainFrm.h"
#include "ChildFrm.h"
#include "DipView.h"
#include "AreaPro.h"
#include "PointPro.h"
#include "DlgMedianFilter.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
extern char szFilter[];
/////////////////////////////////////////////////////////////////////////////
// CDipDoc
IMPLEMENT_DYNCREATE(CDipDoc, CDocument)
BEGIN_MESSAGE_MAP(CDipDoc, CDocument)
//{{AFX_MSG_MAP(CDipDoc)
ON_COMMAND(ID_FILE_NEW, OnFileNew)
ON_COMMAND(ID_FILE_OPEN, OnFileOpen)
ON_COMMAND(ID_FILE_SAVE_AS, OnFileSaveAs)
ON_COMMAND(ID_ENHA_MidianF, OnENHAMidianF)
ON_COMMAND(ID_POINT_EQUA, OnPointEqua)
//}}AFX_MSG_MAP
END_MESSAGE_MAP()
/////////////////////////////////////////////////////////////////////////////
// CDipDoc construction/destruction
CDipDoc::CDipDoc()
{
// TODO: add one-time construction code here
m_pImageObject = NULL;
m_bImageLoaded = FALSE;
}
CDipDoc::~CDipDoc()
{
if(m_pImageObject != NULL)
{
delete m_pImageObject;
m_pImageObject = NULL;
}
}
BOOL CDipDoc::OnNewDocument()
{
if (!CDocument::OnNewDocument())
return FALSE;
// TODO: add reinitialization code here
// (SDI documents will reuse this document)
return TRUE;
}
/////////////////////////////////////////////////////////////////////////////
// CDipDoc serialization
void CDipDoc::Serialize(CArchive& ar)
{
if (ar.IsStoring())
{
// TODO: add storing code here
}
else
{
// TODO: add loading code here
}
}
/////////////////////////////////////////////////////////////////////////////
// CDipDoc diagnostics
#ifdef _DEBUG
void CDipDoc::AssertValid() const
{
CDocument::AssertValid();
}
void CDipDoc::Dump(CDumpContext& dc) const
{
CDocument::Dump(dc);
}
#endif //_DEBUG
/////////////////////////////////////////////////////////////////////////////
// CDipDoc commands
void CDipDoc::OnFileNew()
{
// TODO: Add your command handler code here
}
void CDipDoc::OnFileOpen()
{
// TODO: Add your command handler code here
static int nIndex = 1;
CFileDialog FileDlg( TRUE, NULL, NULL, OFN_HIDEREADONLY, szFilter );
FileDlg.m_ofn.nFilterIndex = (DWORD) nIndex;
if( FileDlg.DoModal() == IDOK )
{
CString strPathName = FileDlg.GetPathName();
AfxGetApp()->OpenDocumentFile( strPathName );
nIndex = (int) FileDlg.m_ofn.nFilterIndex;
if( !LoadImageToDocument() )
{
AfxMessageBox("无法载入图像文件!");
return;
}
}
}
void CDipDoc::OnFileSaveAs()
{
// TODO: Add your command handler code here
static int nIndex = 1;
CFileDialog DialogSaveAs( FALSE, NULL, m_pImageObject->GetImageName(),
OFN_HIDEREADONLY, szFilter );
DialogSaveAs.m_ofn.nFilterIndex = (DWORD) nIndex;
if( DialogSaveAs.DoModal() == IDOK )
{
CMainFrame *pMainFrame = ( CMainFrame * )AfxGetMainWnd();
CChildFrame *pChildFrame = ( CChildFrame * )pMainFrame->MDIGetActive();
CDipView *pDipView = ( CDipView * )pChildFrame->GetActiveView();
nIndex = (int) DialogSaveAs.m_ofn.nFilterIndex;
if( nIndex == 5 )
{
if( m_pImageObject->GetNumBits() != 24 )
{
AfxMessageBox("必须是24位真彩色图像才能存为JPEG格式!");
return;
}
}
if( m_pImageObject != NULL )
{
CString strPathName = DialogSaveAs.GetPathName();
int nFindIndex = strPathName.Find(".");
if( nFindIndex != -1)
strPathName = strPathName.Left( nFindIndex );
strPathName += CImageObject::szExtensions[ nIndex - 1 ];
m_pImageObject->Save( strPathName );
CString strFileName = DialogSaveAs.GetFileName();
nFindIndex = strFileName.Find(".");
if ( nFindIndex != -1 )
strFileName = strFileName.Left( nFindIndex );
strFileName += CImageObject::szExtensions[ nIndex - 1 ];
pChildFrame->SetWindowText( strFileName );
SetPathName( strPathName );
if( nIndex == 5 )
{
m_pImageObject->Load( strPathName );
pDipView->InvalidateRect( NULL, FALSE );
pDipView->UpdateWindow();
}
}
}
}
BOOL CDipDoc::LoadImageToDocument()
{
CString strPathName = GetPathName();
BeginWaitCursor();//设置等待光标
m_pImageObject = new CImageObject( strPathName.GetBuffer(3) );
EndWaitCursor();//取消等待光标
if( m_pImageObject == NULL )//读入图像文件失败
{
AfxMessageBox("无法创建图像类对象!");
return(FALSE); //返回FALSE
}
m_bImageLoaded = TRUE; //读入图像文件成功,设置相应变量
return(TRUE); //返回TRUE
}
void CDipDoc::OnENHAMidianF()
{
// 窗口高度
int nTempH;
// 窗口宽度
int nTempW;
// 窗口中心元素X坐标
int nTempXc;
// 窗口中心元素Y坐标
int nTempYc;
// 排序方式
int nSortType;
// 创建对话框
CDlgMedianFilter dlgPara;
// 初始化对话框变量值
dlgPara.m_nWindowSize = 0;
dlgPara.m_iTempH = 3;
dlgPara.m_iTempW = 3;
dlgPara.m_iTempMX = 1;
dlgPara.m_iTempMY = 1;
dlgPara.m_nSortType = 0;
// 显示对话框,提示用户设定平移量
if (dlgPara.DoModal() != IDOK)
{
// 返回
return;
}
// 获取用户设定的平移量
nTempH = dlgPara.m_iTempH;
nTempW = dlgPara.m_iTempW;
nTempXc = dlgPara.m_iTempMX;
nTempYc = dlgPara.m_iTempMY;
nSortType = dlgPara.m_nSortType;
// 删除对话框
delete dlgPara;
//创建点处理CPointPro类对象
CAreaPro AreaPro( m_pImageObject );
// 更改光标形状
BeginWaitCursor();
AreaPro.MedianFilter(nSortType, nTempW, nTempH, nTempXc, nTempYc);
// 恢复光标
EndWaitCursor();
// 更新视图
UpdateAllViews(NULL);
}
void CDipDoc::OnPointEqua()
{
//创建点处理CPointPro类对象
CPointPro PointOperation( m_pImageObject );
// 更改光标形状
BeginWaitCursor();
// 调用LinerTrans()函数进行线性变换
PointOperation.InteEqualize( m_pImageObject );
// 设置脏标记
//SetModifiedFlag(TRUE);
// 更新视图
UpdateAllViews(NULL);
// 恢复光标
EndWaitCursor();
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -