⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 imagesyszlf01doc.cpp

📁 模式识别的作业代码
💻 CPP
字号:
// ImageSysZLF01Doc.cpp : implementation of the CImageSysZLF01Doc class
//

#include "stdafx.h"
#include "ImageSysZLF01.h"

#include "ImageSysZLF01Doc.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

/////////////////////////////////////////////////////////////////////////////
// CImageSysZLF01Doc

IMPLEMENT_DYNCREATE(CImageSysZLF01Doc, CDocument)

BEGIN_MESSAGE_MAP(CImageSysZLF01Doc, CDocument)
	//{{AFX_MSG_MAP(CImageSysZLF01Doc)
		// NOTE - the ClassWizard will add and remove mapping macros here.
		//    DO NOT EDIT what you see in these blocks of generated code!
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CImageSysZLF01Doc construction/destruction

CImageSysZLF01Doc::CImageSysZLF01Doc()
{
	// TODO: add one-time construction code here
   	TRACE("CzlfDOC: structed!");


	//zlf add
	// 默认背景色,灰色
	m_refColorBKG = 0x00808080;	
	
	// 初始化变量
	m_hDIB = NULL;
	m_palDIB = NULL;
	m_pPrimitiveImage=NULL;
	m_sizeDoc = CSize(1,1);

}

CImageSysZLF01Doc::~CImageSysZLF01Doc()
{
	//zlf add
	// 判断DIB对象是否存在
	if (m_hDIB != NULL)
	{
		// 清除DIB对象
		::GlobalFree((HGLOBAL) m_hDIB);
	}
	
	// 判断调色板是否存在
	if (m_palDIB != NULL)
	{
		// 清除调色板
		delete m_palDIB;
	}
    
	// 判断原始图像是否存在
	if (m_pPrimitiveImage != NULL)
	{
		// 清除原始图像
		::GlobalFree((HGLOBAL)::GlobalHandle(m_pPrimitiveImage));
	}

}

BOOL CImageSysZLF01Doc::OnNewDocument()
{
	if (!CDocument::OnNewDocument())
		return FALSE;

	// TODO: add reinitialization code here
	// (SDI documents will reuse this document)

	return TRUE;
}



/////////////////////////////////////////////////////////////////////////////
// CImageSysZLF01Doc serialization

void CImageSysZLF01Doc::Serialize(CArchive& ar)
{
	if (ar.IsStoring())
	{
		// TODO: add storing code here
	}
	else
	{
		// TODO: add loading code here
	}
}

/////////////////////////////////////////////////////////////////////////////
// CImageSysZLF01Doc diagnostics

#ifdef _DEBUG
void CImageSysZLF01Doc::AssertValid() const
{
	CDocument::AssertValid();
}

void CImageSysZLF01Doc::Dump(CDumpContext& dc) const
{
	CDocument::Dump(dc);
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CImageSysZLF01Doc commands

//zlf add
void CImageSysZLF01Doc::InitDIBData()
{
	// 初始化DIB对象

	// 判断调色板是否为空
	if (m_palDIB != NULL)
	{
		// 删除调色板对象
		delete m_palDIB;

		// 重置调色板为空
		m_palDIB = NULL;
	}
	
	// 如果DIB对象为空,直接返回
	if (m_hDIB == NULL)
	{
		// 返回
		return;
	}
	
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);
	
	// 判断图像是否过大
	if (::DIBWidth(lpDIB) > INT_MAX ||::DIBHeight(lpDIB) > INT_MAX)
	{
		::GlobalUnlock((HGLOBAL) m_hDIB);
		
		// 释放DIB对象
		::GlobalFree((HGLOBAL) m_hDIB);
		
		// 设置DIB为空
		m_hDIB = NULL;
		
		CString strMsg;
		strMsg = "BMP图像太大!";
		
		// 提示用户
		MessageBox(NULL, strMsg, "系统提示", MB_ICONINFORMATION | MB_OK);
		
		// 返回
		return;
	}

   return;
}


BOOL CImageSysZLF01Doc::OnOpenDocument(LPCTSTR lpszPathName) 
{
	if (!CDocument::OnOpenDocument(lpszPathName))
		return FALSE;
	
	// TODO: Add your specialized creation code here
	//zlf add
	CFile file;
	CFileException fe;

	// 打开文件
	if (!file.Open(lpszPathName, CFile::modeRead | CFile::shareDenyWrite, &fe))
	{
		// 失败
		ReportSaveLoadException(lpszPathName, &fe,
			FALSE, AFX_IDP_FAILED_TO_OPEN_DOC);
		
		// 返回FALSE
		return FALSE;
	}
	
	DeleteContents();
	
	// 更改光标形状
	BeginWaitCursor();
	
	// 尝试调用ReadDIBFile()读取图像
	TRY
	{
		m_hDIB = ::ReadDIBFile(file);
	}
	CATCH (CFileException, eLoad)
	{
		// 读取失败
		file.Abort();
		
		// 恢复光标形状
		EndWaitCursor();
		
		// 报告失败
		ReportSaveLoadException(lpszPathName, eLoad,
			FALSE, AFX_IDP_FAILED_TO_OPEN_DOC);
		
		// 设置DIB为空
		m_hDIB = NULL;
		
		// 返回FALSE
		return FALSE;
	}
	END_CATCH
	
	// 初始化DIB
	InitDIBData();
	
    // 保存原始图像
	// 锁定DIB
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);
    
	BackupPrimitiveImage(lpDIB);
    
	// 恢复光标形状
	EndWaitCursor();
	
	// 判断读取文件是否成功
	if (m_hDIB == NULL)
	{
		// 失败,可能非BMP格式
		CString strMsg;
		strMsg = "读取图像时出错!可能是不支持该类型的图像文件!";
		
		// 提示出错
		MessageBox(NULL, strMsg, "系统提示", MB_ICONINFORMATION | MB_OK);
		
		// 返回FALSE
		return FALSE;
	}
	
	// 设置文件名称
	SetPathName(lpszPathName);
	
	// 初始化胀标记为FALSE
	SetModifiedFlag(FALSE);


	return TRUE;
}

BOOL CImageSysZLF01Doc::OnSaveDocument(LPCTSTR lpszPathName) 
{
	// TODO: Add your specialized code here and/or call the base class
	CFile file;
	CFileException fe;

	// 打开文件
	if (!file.Open(lpszPathName, CFile::modeCreate |
	  CFile::modeReadWrite | CFile::shareExclusive, &fe))
	{
		// 失败
		ReportSaveLoadException(lpszPathName, &fe,
			TRUE, AFX_IDP_INVALID_FILENAME);
		// 返回FALSE
		return FALSE;
	}

	// 尝试调用SaveDIB保存图像
	BOOL bSuccess = FALSE;
	TRY
	{
		
		// 更改光标形状
		BeginWaitCursor();

		// 尝试保存图像
		bSuccess = ::SaveDIB(m_hDIB, file);

		// 关闭文件
		file.Close();
	}
	CATCH (CException, eSave)
	{
		// 失败
		file.Abort();
		
		// 恢复光标形状
		EndWaitCursor();
		ReportSaveLoadException(lpszPathName, eSave,
			TRUE, AFX_IDP_FAILED_TO_SAVE_DOC);
		
		// 返回FALSE
		return FALSE;
	}
	END_CATCH

	// 恢复光标形状
	EndWaitCursor();
	
	// 重置胀标记为FALSE
	SetModifiedFlag(FALSE);

	if (!bSuccess)
	{
		// 保存失败,可能是其它格式的DIB,可以读取但是不能保存
		// 或者是SaveDIB函数有误

		CString strMsg;
		strMsg = "无法保存BMP图像!";
		
		// 提示出错
		MessageBox(NULL, strMsg, "系统提示", MB_ICONINFORMATION | MB_OK);
	}
	
	return bSuccess;
     
	return CDocument::OnSaveDocument(lpszPathName);
}

void CImageSysZLF01Doc::ReplaceHDIB(HDIB hDIB)
{
	// 替换DIB,在功能粘贴中用到该函数
	
	// 判断DIB是否为空
	if (m_hDIB != NULL)
	{
		// 非空,则清除
		::GlobalFree((HGLOBAL) m_hDIB);
	}

	// 替换成新的DIB对象
	m_hDIB = hDIB;

}


//将原始图像备份
BOOL CImageSysZLF01Doc::BackupPrimitiveImage(LPSTR lpDIB)
{
	LONG lDataSize=GetImageSize(lpDIB);

	HDIB hPrimitiveDIB ;
	if (!(hPrimitiveDIB = (HDIB) ::GlobalAlloc(GMEM_MOVEABLE | GMEM_ZEROINIT, lDataSize)))
	{
		AfxMessageBox("在保存原始图像时内存申请失败!");
		return NULL;
	};
    
    
	m_pPrimitiveImage=(LPSTR)GlobalLock(hPrimitiveDIB);
    
   	memcpy(m_pPrimitiveImage, lpDIB, lDataSize);

	GlobalUnlock(hPrimitiveDIB);
	return TRUE;
}


BOOL CImageSysZLF01Doc::RestorePrimitiveImage()
{
	LPSTR lpDIB=(LPSTR)GlobalLock(m_hDIB);
    
   	memcpy(lpDIB,m_pPrimitiveImage, GetImageSize(m_pPrimitiveImage));

	GlobalUnlock(m_hDIB);

	UpdateAllViews(NULL);

	return TRUE;
}


LPSTR CImageSysZLF01Doc::GetDIBPtr(HDIB hDib)
{
    LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);

	return lpDIB;
}

void CImageSysZLF01Doc::OnChangedViewList() 
{
	// TODO: Add your specialized code here and/or call the base class
	//this->RemoveView();

	CDocument::OnChangedViewList();
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -