亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? fretransdoc.cpp

?? 此代碼實現圖像正交變換,包括傅立葉變換,離散余弦變換,沃爾什變換
?? CPP
字號:
// FreTransDoc.cpp : implementation of the CFreTransDoc class
//

#include "stdafx.h"
#include "FreTrans.h"

#include "FreTransDoc.h"

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

/////////////////////////////////////////////////////////////////////////////
// CFreTransDoc

IMPLEMENT_DYNCREATE(CFreTransDoc, CDocument)

BEGIN_MESSAGE_MAP(CFreTransDoc, CDocument)
	//{{AFX_MSG_MAP(CFreTransDoc)
	ON_COMMAND(ID_FILE_REOPEN, OnFileReopen)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CFreTransDoc construction/destruction

CFreTransDoc::CFreTransDoc()
{
	// TODO: add one-time construction code here
	// 默認背景色,灰色
	m_refColorBKG = 0x00808080;	
	
	// 初始化變量
	m_pDibImage = NULL;
	m_hDIB = NULL;
	m_palDIB = NULL;
	m_sizeDoc = CSize(1,1);
}

CFreTransDoc::~CFreTransDoc()
{
	// 判斷DIB對象是否存在
	if (m_hDIB != NULL)
	{
		// 清除DIB對象
		::GlobalFree((HGLOBAL) m_hDIB);
	}
	
	// 判斷調色板是否存在
	if (m_palDIB != NULL)
	{
		// 清除調色板
		delete m_palDIB;
		m_palDIB = NULL;
	}

	// 判斷DibImage對象是否存在
	if (m_pDibImage != NULL)
	{
		// 清除DibImage對象
		delete m_pDibImage;
		m_pDibImage = NULL;
	}
}

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

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

	return TRUE;
}



/////////////////////////////////////////////////////////////////////////////
// CFreTransDoc serialization

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

/////////////////////////////////////////////////////////////////////////////
// CFreTransDoc diagnostics

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

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

/////////////////////////////////////////////////////////////////////////////
// CFreTransDoc commands

void CFreTransDoc::ReplaceHDIB(HDIB hDIB)
{
	// 替換DIB,在功能粘貼中用到該函數	
	if (m_hDIB != NULL)
	{
		::GlobalFree((HGLOBAL) m_hDIB);
	}
	m_hDIB = hDIB;		
}

void CFreTransDoc::InitDIBData()
{
	// 初始化DIB對象

	if (m_palDIB != NULL)
	{
		delete m_palDIB;
		m_palDIB = NULL;
	}	
	if (m_hDIB == NULL)
	{
		return;
	}
	
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);
	
	// 判斷圖像是否過大
	if (m_pDibImage->DIBWidth(lpDIB) > INT_MAX ||m_pDibImage->DIBHeight(lpDIB) 
		> INT_MAX)
	{
		::GlobalUnlock((HGLOBAL) m_hDIB);
		::GlobalFree((HGLOBAL) m_hDIB);

		m_hDIB = NULL;
		
		CString strMsg;
		strMsg = "BMP圖像太大!";
		MessageBox(NULL, strMsg, "系統提示", MB_ICONINFORMATION | MB_OK);

		return;
	}
	
	m_sizeDoc = CSize((int) m_pDibImage->DIBWidth(lpDIB), 
		(int) m_pDibImage->DIBHeight(lpDIB));
	
	::GlobalUnlock((HGLOBAL) m_hDIB);
	
	// 創建新調色板
	m_palDIB = new CPalette;
	if (m_palDIB == NULL)
	{
		::GlobalFree((HGLOBAL) m_hDIB);
		m_hDIB = NULL;

		return;
	}

	if (m_pDibImage->CreateDIBPalette(m_hDIB, m_palDIB) == NULL)
	{
		delete m_palDIB;
		m_palDIB = NULL;

		return;
	}
}

BOOL CFreTransDoc::OnOpenDocument(LPCTSTR lpszPathName) 
{
	CFile file;
	CFileException fe;

	if (!file.Open(lpszPathName, CFile::modeRead | CFile::shareDenyWrite, &fe))
	{
		ReportSaveLoadException(lpszPathName, &fe,FALSE, 
			AFX_IDP_FAILED_TO_OPEN_DOC);

		return FALSE;
	}
	
	DeleteContents();

	BeginWaitCursor();

	if(m_pDibImage != NULL)
	{
		delete m_pDibImage;
		m_pDibImage = NULL;
	}
	m_pDibImage = new CDibImage;

	TRY
	{
		m_hDIB = m_pDibImage->ReadDIBFile(file);
	}
	CATCH (CFileException, eLoad)
	{
		file.Abort();
		EndWaitCursor();

		ReportSaveLoadException(lpszPathName, eLoad,FALSE, 
			AFX_IDP_FAILED_TO_OPEN_DOC);
		
		m_hDIB = NULL;

		if(m_pDibImage != NULL)
		{
			delete m_pDibImage;
			m_pDibImage = NULL;
		}

		return FALSE;
	}
	END_CATCH

	InitDIBData();
	EndWaitCursor();
	
	// 判斷讀取文件是否成功
	if (m_hDIB == NULL)
	{
		CString strMsg;
		strMsg = "讀取圖像時出錯!可能是不支持該類型的圖像文件!";
		MessageBox(NULL, strMsg, "系統提示", MB_ICONINFORMATION | MB_OK);

		if(m_pDibImage != NULL)
		{
			delete m_pDibImage;
			m_pDibImage = NULL;
		}
		
		return FALSE;
	}
		
	SetPathName(lpszPathName);			// 設置文件名稱	
	SetModifiedFlag(FALSE);				// 初始化脹標記為FALSE

	return TRUE;
}

BOOL CFreTransDoc::OnSaveDocument(LPCTSTR lpszPathName) 
{
	CFile file;
	CFileException fe;

	if (!file.Open(lpszPathName, CFile::modeCreate |CFile::modeReadWrite 
		| CFile::shareExclusive, &fe))
	{
		ReportSaveLoadException(lpszPathName,&fe,TRUE,AFX_IDP_INVALID_FILENAME);
		return FALSE;
	}

	BOOL bSuccess = FALSE;
	TRY
	{
		BeginWaitCursor();
		bSuccess = m_pDibImage->SaveDIB(m_hDIB, file);
		file.Close();
	}
	CATCH (CException, eSave)
	{
		file.Abort();
		EndWaitCursor();
		ReportSaveLoadException(lpszPathName,eSave,TRUE,
			AFX_IDP_FAILED_TO_SAVE_DOC);

		return FALSE;
	}
	END_CATCH

	EndWaitCursor();
	SetModifiedFlag(FALSE);

	if (!bSuccess)
	{
		// 保存失敗,可能是其它格式的DIB,可以讀取但是不能保存
		// 或者是SaveDIB函數有誤
		CString strMsg;
		strMsg = "無法保存BMP圖像!";
		MessageBox(NULL, strMsg, "系統提示", MB_ICONINFORMATION | MB_OK);
	}
	
	return bSuccess;
}

void CFreTransDoc::OnFileReopen() 
{
	// 重新打開圖像,放棄所有修改
 
	// 判斷當前圖像是否已經被改動
	if (IsModified())
	{
		if (MessageBox(NULL, "重新打開圖像將丟失所有改動!是否繼續?", 
			"系統提示", MB_ICONQUESTION | MB_YESNO) == IDNO)
		{
			return;
		}
	}
	
	CFile file;
 	CFileException fe;
 	CString strPathName;
 	strPathName = GetPathName();

 	if (!file.Open(strPathName, CFile::modeRead | CFile::shareDenyWrite, &fe))
 	{
 		ReportSaveLoadException(strPathName,&fe,FALSE,AFX_IDP_FAILED_TO_OPEN_DOC);
 
 		return;
 	}
 	
 	BeginWaitCursor();
 	
	if(m_pDibImage != NULL)
	{
		delete m_pDibImage;
		m_pDibImage = NULL;
	}
	m_pDibImage = new CDibImage;

 	TRY
 	{
 		m_hDIB = m_pDibImage->ReadDIBFile(file);
 	}
 	CATCH (CFileException, eLoad)
 	{
 		file.Abort();
 		EndWaitCursor();
 		
 		ReportSaveLoadException(strPathName,eLoad,FALSE,AFX_IDP_FAILED_TO_OPEN_DOC);
 
 		m_hDIB = NULL;
		if(m_pDibImage != NULL)
		{
			delete m_pDibImage;
			m_pDibImage = NULL;
		}

 		return;
 	}
 	END_CATCH
 	
 	InitDIBData();
 	
 	if (m_hDIB == NULL)
 	{
 		CString strMsg;
 		strMsg = "讀取圖像時出錯!可能是不支持該類型的圖像文件!";
 		MessageBox(NULL, strMsg, "系統提示", MB_ICONINFORMATION | MB_OK);

 		EndWaitCursor();

		if(m_pDibImage != NULL)
		{
			delete m_pDibImage;
			m_pDibImage = NULL;
		}
 
 		return;
 	}
 	
 	SetModifiedFlag(FALSE);
 	UpdateAllViews(NULL);
 	EndWaitCursor();

 	return;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
免费高清在线视频一区·| 久久综合色婷婷| 国产精品国产a| 99久久夜色精品国产网站| 中文av一区二区| 欧美性猛片aaaaaaa做受| 亚洲综合在线视频| 这里是久久伊人| 国产精品一区二区无线| 一区二区三区精品视频在线| 亚洲免费观看高清完整| 91精品国产综合久久精品性色| 欧美伦理电影网| www.亚洲色图.com| 国产一区二区三区黄视频| 亚洲高清免费观看高清完整版在线观看 | 久久九九久精品国产免费直播| www.亚洲在线| 91官网在线免费观看| 国产一区二区伦理片| 成人av电影免费观看| 国内精品在线播放| 日韩av一区二区三区四区| 亚洲免费在线视频一区 二区| 亚洲亚洲精品在线观看| 美女视频黄 久久| 亚洲中国最大av网站| 欧美韩国日本不卡| 2019国产精品| 亚洲黄网站在线观看| 最新日韩av在线| 日本一区二区三区久久久久久久久不 | 欧美亚洲高清一区| 日韩美一区二区三区| 欧美性极品少妇| 久久综合色8888| 性做久久久久久久久| 亚洲一区自拍偷拍| 国产精品99久久久久久似苏梦涵 | 日韩三级精品电影久久久 | 91麻豆视频网站| voyeur盗摄精品| 欧美一激情一区二区三区| 国产精品三级电影| 蜜桃久久av一区| 91国产精品成人| 日韩理论片在线| 亚洲自拍偷拍九九九| 国产大陆亚洲精品国产| 国产一二精品视频| 8x福利精品第一导航| 亚洲女人****多毛耸耸8| 狠狠色丁香久久婷婷综合_中| 在线一区二区三区做爰视频网站| 久久久亚洲国产美女国产盗摄| 久久久久国产精品免费免费搜索| 香蕉av福利精品导航| 色爱区综合激月婷婷| 国产精品午夜在线观看| 久久成人久久鬼色| 成人毛片视频在线观看| 色综合久久久久网| 欧美日韩成人综合在线一区二区| 日韩三级视频在线看| 水野朝阳av一区二区三区| 国精品**一区二区三区在线蜜桃| 在线播放中文一区| 亚洲自拍都市欧美小说| 在线观看视频91| 久久免费视频色| 国产一级精品在线| 久久久av毛片精品| 国产精品 日产精品 欧美精品| 日韩美女视频在线| 韩国视频一区二区| 精品福利一区二区三区| 亚洲精品ww久久久久久p站| 99国内精品久久| 亚洲人成网站在线| 色妹子一区二区| 一区二区三区四区精品在线视频 | 国产高清在线精品| 国产亚洲精久久久久久| 不卡大黄网站免费看| 日韩美女视频19| 日本精品视频一区二区三区| 一区二区三区在线观看欧美 | 国产一区二区三区在线观看精品 | 欧洲在线/亚洲| 亚洲va韩国va欧美va精品| 欧美日韩国产综合视频在线观看 | 国产伦精品一区二区三区免费迷| 国产日韩精品一区二区三区 | 国产自产高清不卡| 中文字幕中文字幕在线一区| 91国在线观看| 日本sm残虐另类| 久久久久9999亚洲精品| 一本久久a久久免费精品不卡| 亚洲va欧美va人人爽午夜 | 成人亚洲一区二区一| 一区二区三区高清不卡| 欧美精品一区二区三区一线天视频 | 亚洲精品在线观| av在线不卡免费看| 日本中文字幕不卡| 自拍偷拍亚洲综合| 日韩三级视频在线看| av午夜一区麻豆| 麻豆视频一区二区| 亚洲另类在线视频| 久久久www免费人成精品| 在线免费一区三区| 成人晚上爱看视频| 日韩av高清在线观看| 国产精品国产自产拍高清av | 精品国产麻豆免费人成网站| av在线一区二区三区| 精品制服美女久久| 精品粉嫩aⅴ一区二区三区四区| 成人毛片老司机大片| 奇米精品一区二区三区四区 | 麻豆国产91在线播放| 亚洲三级免费电影| 国产欧美日韩麻豆91| 精品美女被调教视频大全网站| 日本不卡一区二区三区| 亚洲精品成人天堂一二三| 国产日韩欧美高清| 久久嫩草精品久久久精品一| 欧美日韩一区二区三区高清| 五月激情综合色| 久久男人中文字幕资源站| 欧美精品第1页| 91一区二区三区在线观看| 国产在线乱码一区二区三区| 午夜精品久久久久久久久| 亚洲乱码精品一二三四区日韩在线| 精品电影一区二区| 日韩一级大片在线观看| 欧美日韩免费一区二区三区视频| av成人老司机| 成人激情动漫在线观看| 国产成人亚洲综合a∨婷婷| 麻豆国产欧美日韩综合精品二区| 日韩中文字幕不卡| 日本午夜精品视频在线观看| 午夜精品久久久久久久99樱桃| 亚洲国产一区在线观看| 亚洲午夜私人影院| 日韩福利视频导航| 日本欧美一区二区三区| 全国精品久久少妇| 日韩高清不卡在线| 国内精品在线播放| 国产69精品久久99不卡| 午夜影院在线观看欧美| 午夜精品成人在线| 免费欧美日韩国产三级电影| 久久aⅴ国产欧美74aaa| 国内国产精品久久| 成人免费视频视频在线观看免费 | 亚洲欧美激情视频在线观看一区二区三区| 中文一区一区三区高中清不卡| 国产精品久久精品日日| 亚洲人精品午夜| 五月激情六月综合| 激情综合色综合久久综合| 国产黑丝在线一区二区三区| 99精品视频在线免费观看| 色综合亚洲欧洲| 国产精品18久久久久久vr| 粗大黑人巨茎大战欧美成人| 99精品欧美一区二区三区综合在线| 一本大道久久a久久精二百 | 久久久久国产精品免费免费搜索| 国产欧美一区二区精品婷婷| 亚洲精品免费在线观看| 性欧美大战久久久久久久久| 精品亚洲porn| 97久久久精品综合88久久| 欧美这里有精品| 久久久精品国产免大香伊| 亚洲人精品午夜| 老司机午夜精品| 色播五月激情综合网| 欧美大白屁股肥臀xxxxxx| 国产精品福利在线播放| 免费观看在线色综合| 色综合久久综合网欧美综合网| 日韩视频一区在线观看| 亚洲麻豆国产自偷在线| 精品在线播放午夜| 欧美视频在线一区| 欧美国产一区在线| 老司机免费视频一区二区三区| 94-欧美-setu| 久久久久久久电影| 免费高清不卡av| 欧美日韩第一区日日骚|