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

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

?? earview.cpp

?? 人耳識別技術是20世紀90年代末開始興起的一種生物特征識別技術
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// EARView.cpp : implementation of the CEARView class
//

#include "stdafx.h"
#include "EAR.h"

#include "EARDoc.h"
#include "EARView.h"

//添加頭文件
#include "MainFrm.h"
#include "IntensityDlg.h"		// 直方圖
#include "LinerParaDlg.h"		// 線性變換
#include "PointThreDlg.h"		// 閾值變換
#include "PointWinDlg.h"		// 窗口變換
#include "PointStreDlg.h"		// 灰度拉伸

#include "SmoothDlg.h"			// 圖像平滑
#include "MidFilterDlg.h"		// 中值濾波
#include "SharpThreDlg.h"		// 圖像梯度銳化

#include "MorphErosionDlg.h"	// 圖像腐蝕
#include "MorphDilationDlg.h"	// 圖像膨脹
#include "MorphOpenDlg.h"		// 開運算
#include "MorphCloseDlg.h"		// 閉運算

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

/////////////////////////////////////////////////////////////////////////////
// CEARView

IMPLEMENT_DYNCREATE(CEARView, CScrollView)

BEGIN_MESSAGE_MAP(CEARView, CScrollView)
	//{{AFX_MSG_MAP(CEARView)
	ON_WM_ERASEBKGND()
	ON_COMMAND(ID_EDIT_COPY, OnEditCopy)
	ON_UPDATE_COMMAND_UI(ID_EDIT_COPY, OnUpdateEditCopy)
	ON_COMMAND(ID_EDIT_PASTE, OnEditPaste)
	ON_UPDATE_COMMAND_UI(ID_EDIT_PASTE, OnUpdateEditPaste)
	ON_COMMAND(ID_VEIW_INTENSITY, OnVeiwIntensity)
	ON_COMMAND(ID_POINT_INVERT, OnPointInvert)
	ON_COMMAND(ID_POINT_LINER, OnPointLiner)
	ON_COMMAND(ID_POINT_THRE, OnPointThre)
	ON_COMMAND(ID_POINT_WIND, OnPointWind)
	ON_COMMAND(ID_POINT_STRE, OnPointStre)
	ON_COMMAND(ID_POINT_EQUA, OnPointEqua)
	ON_COMMAND(ID_ENHA_SMOOTH, OnEnhaSmooth)
	ON_COMMAND(ID_ENHA_GRADSHARP, OnEnhaGradsharp)
	ON_COMMAND(ID_ENHA_MIDIANF, OnEnhaMidianF)
	ON_COMMAND(ID_ENHA_SHARP, OnEnhaSharp)
	ON_COMMAND(ID_MORPH_EROSION, OnMorphErosion)
	ON_COMMAND(ID_MORPH_DILATION, OnMorphDilation)
	ON_COMMAND(ID_MORPH_OPEN, OnMorphOpen)
	ON_COMMAND(ID_MORPH_CLOSE, OnMorphClose)
	ON_COMMAND(ID_EDGE_SOBEL, OnEdgeSobel)
	ON_COMMAND(ID_EDGE_KIRSCH, OnEdgeKirsch)
	ON_COMMAND(ID_EDGE_CONTOUR, OnEdgeContour)
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CScrollView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CScrollView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CEARView construction/destruction

CEARView::CEARView()
{
	// TODO: add construction code here

}

CEARView::~CEARView()
{
}

BOOL CEARView::PreCreateWindow(CREATESTRUCT& cs)
{
	// TODO: Modify the Window class or styles here by modifying
	//  the CREATESTRUCT cs

	return CScrollView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CEARView drawing

void CEARView::OnDraw(CDC* pDC)
{
	// TODO: add draw code for native data here
	BeginWaitCursor();

	CEARDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);

	HDIB hDIB = pDoc->GetHDIB();
	if (hDIB != NULL)
	{
		LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) hDIB);
		int cxDIB = (int) pDoc->GetDibImage()->DIBWidth(lpDIB);
		int cyDIB = (int) pDoc->GetDibImage()->DIBHeight(lpDIB);

		::GlobalUnlock((HGLOBAL) hDIB);
		
		CRect rcDIB;
		rcDIB.top = rcDIB.left = 0;
		rcDIB.right = cxDIB;
		rcDIB.bottom = cyDIB;
		
		CRect rcDest;
		
		if (pDC->IsPrinting())
		{
			// 是打印,計算輸出圖像的位置和大小,以便符合頁面
			
			// 獲取打印頁面的水平寬度(象素)
			int cxPage = pDC->GetDeviceCaps(HORZRES);			
			// 獲取打印頁面的垂直高度(象素)
			int cyPage = pDC->GetDeviceCaps(VERTRES);			
			// 獲取打印機每英寸象素數
			int cxInch = pDC->GetDeviceCaps(LOGPIXELSX);
			int cyInch = pDC->GetDeviceCaps(LOGPIXELSY);
			
			// 計算打印圖像大小(縮放,根據頁面寬度調整圖像大小)
			rcDest.top = rcDest.left = 0;
			rcDest.bottom = (int)(((double)cyDIB * cxPage * cyInch)
					/ ((double)cxDIB * cxInch));
			rcDest.right = cxPage;
			
			// 計算打印圖像位置(垂直居中)
			int temp = cyPage - (rcDest.bottom - rcDest.top);
			rcDest.bottom += temp/2;
			rcDest.top += temp/2;
		}
		else   
		{
			// 不必縮放圖像
			rcDest = rcDIB;
		}
		
		pDoc->GetDibImage()->PaintDIB(pDC->m_hDC, &rcDest, pDoc->GetHDIB(),
			&rcDIB, pDoc->GetDocPalette());
	}
	
	EndWaitCursor();
}

void CEARView::OnInitialUpdate()
{
	CScrollView::OnInitialUpdate();

	// TODO: calculate the total size of this view
}

/////////////////////////////////////////////////////////////////////////////
// CEARView printing

BOOL CEARView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	// 設置總頁數為一
	pInfo->SetMaxPage(1);
	return DoPreparePrinting(pInfo);
}

void CEARView::OnBeginPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add extra initialization before printing
}

void CEARView::OnEndPrinting(CDC* /*pDC*/, CPrintInfo* /*pInfo*/)
{
	// TODO: add cleanup after printing
}

/////////////////////////////////////////////////////////////////////////////
// CEARView diagnostics

#ifdef _DEBUG
void CEARView::AssertValid() const
{
	CScrollView::AssertValid();
}

void CEARView::Dump(CDumpContext& dc) const
{
	CScrollView::Dump(dc);
}

CEARDoc* CEARView::GetDocument() // non-debug version is inline
{
	ASSERT(m_pDocument->IsKindOf(RUNTIME_CLASS(CEARDoc)));
	return (CEARDoc*)m_pDocument;
}
#endif //_DEBUG

/////////////////////////////////////////////////////////////////////////////
// CEARView message handlers

LRESULT CEARView::OnDoRealize(WPARAM wParam, LPARAM)
{
	ASSERT(wParam != NULL);

	CEARDoc* pDoc = GetDocument();	
	if (pDoc->GetHDIB() == NULL)
	{
		return 0L;
	}
	
	CPalette* pPal = pDoc->GetDocPalette();
	if (pPal != NULL)
	{
		CMainFrame* pAppFrame = (CMainFrame*) AfxGetApp()->m_pMainWnd;
		ASSERT_KINDOF(CMainFrame, pAppFrame);
		
		CClientDC appDC(pAppFrame);

		// All views but one should be a background palette.
		// wParam contains a handle to the active view, so the SelectPalette
		// bForceBackground flag is FALSE only if wParam == m_hWnd (this view)
		CPalette* oldPalette = appDC.SelectPalette(pPal,((HWND)wParam)!=m_hWnd);	
		if (oldPalette != NULL)
		{
			UINT nColorsChanged = appDC.RealizePalette();
			if (nColorsChanged > 0)
			{
				pDoc->UpdateAllViews(NULL);
			}
			appDC.SelectPalette(oldPalette, TRUE);
		}
		else
		{
			TRACE0("\tCCh1_1View::OnPaletteChanged中調用SelectPalette()失敗!\n");
		}
	}
	
	return 0L;
}

BOOL CEARView::OnEraseBkgnd(CDC* pDC) 
{
	// TODO: Add your message handler code here and/or call default
	// 主要是為了設置子窗體默認的背景色
	// 背景色由文檔成員變量m_refColorBKG指定

	CEARDoc* pDoc = GetDocument();
	CBrush brush(pDoc->m_refColorBKG);                                              
	CBrush* pOldBrush = pDC->SelectObject(&brush);
		
	CRect rectClip;
	pDC->GetClipBox(&rectClip);			// 獲取重繪區域	
	pDC->PatBlt(rectClip.left, rectClip.top, rectClip.Width(), 
		rectClip.Height(), PATCOPY);

	pDC->SelectObject(pOldBrush);                                                  

	return TRUE;
}

void CEARView::OnEditCopy() 
{
	// TODO: Add your command handler code here
	// 復制當前圖像

	CEARDoc* pDoc = GetDocument();
	
	if (OpenClipboard())
	{
		BeginWaitCursor();
		EmptyClipboard();
		
		// 復制當前圖像到剪貼板
		SetClipboardData (CF_DIB, pDoc->GetDibImage()->
			CopyHandle((HANDLE) pDoc->GetHDIB()) );

		CloseClipboard();
		EndWaitCursor();
	}		
}

void CEARView::OnUpdateEditCopy(CCmdUI* pCmdUI) 
{
	// TODO: Add your command update UI handler code here
	// 如果當前DIB對象不空,復制菜單項有效
	pCmdUI->Enable(GetDocument()->GetHDIB() != NULL);
}

void CEARView::OnEditPaste() 
{
	// TODO: Add your command handler code here
	// 粘貼圖像
	
	HDIB hNewDIB = NULL;
	CEARDoc* pDoc = GetDocument();
	
	if (OpenClipboard())
	{
		BeginWaitCursor();

		// 讀取剪貼板中的圖像
		hNewDIB = (HDIB)pDoc->GetDibImage()->CopyHandle(::GetClipboardData(CF_DIB));

		CloseClipboard();
		
		if (hNewDIB != NULL)
		{
			pDoc->ReplaceHDIB(hNewDIB);		// 替換DIB,同時釋放舊DIB對象		
			pDoc->InitDIBData();			// 更新DIB大小和調色板		
			pDoc->SetModifiedFlag(TRUE);	// 設置臟標記	
			SetScrollSizes(MM_TEXT, pDoc->GetDocSize());	// 重新設置滾動視圖大小		
			OnDoRealize((WPARAM)m_hWnd,0);	// 實現新的調色板		
			pDoc->UpdateAllViews(NULL);		// 更新視圖
		}

		EndWaitCursor();
	}
}

void CEARView::OnUpdateEditPaste(CCmdUI* pCmdUI) 
{
	// TODO: Add your command update UI handler code here
	// 如果當前剪貼板中有DIB對象,粘貼菜單項有效
	pCmdUI->Enable(::IsClipboardFormatAvailable(CF_DIB));	
}

void CEARView::OnActivateView(BOOL bActivate, CView* pActivateView, CView* pDeactiveView) 
{
	// TODO: Add your specialized code here and/or call the base class
	CScrollView::OnActivateView(bActivate, pActivateView, pDeactiveView);
	
	if (bActivate)
	{
		ASSERT(pActivateView == this);
		OnDoRealize((WPARAM)m_hWnd, 0);   // same as SendMessage(WM_DOREALIZE);
	}
}

void CEARView::CalcWindowRect(LPRECT lpClientRect, UINT nAdjustType) 
{
	// TODO: Add your specialized code here and/or call the base class
	CScrollView::OnInitialUpdate();
	ASSERT(GetDocument() != NULL);
	
	SetScrollSizes(MM_TEXT, GetDocument()->GetDocSize());
}

void CEARView::OnVeiwIntensity() 
{
	// TODO: Add your command handler code here
	// 查看當前圖像灰度直方圖

	CEARDoc* pDoc = GetDocument();
	
	LPSTR lpDIB;			// 指向DIB的指針	
	LPSTR    lpDIBBits;		// 指向DIB象素指針
	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());	
	// 找到DIB圖像象素起始位置
	lpDIBBits = pDoc->GetDibImage()->FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖,其它的可以類推)
	if (pDoc->GetDibImage()->DIBNumColors(lpDIB) != 256)
	{
		MessageBox("目前只支持查看256色位圖灰度直方圖!", "系統提示" , 
			MB_ICONINFORMATION | MB_OK);
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
		
		return;
	}
	
	BeginWaitCursor();

	CIntensityDlg dlgPara;
	dlgPara.m_lpDIBBits = lpDIBBits;
	dlgPara.m_lWidth = pDoc->GetDibImage()->DIBWidth(lpDIB);
	dlgPara.m_lHeight = pDoc->GetDibImage()->DIBHeight(lpDIB);
	dlgPara.m_iLowGray = 0;
	dlgPara.m_iUpGray = 255;
	
	// 顯示對話框,提示用戶設定平移量
	if (dlgPara.DoModal() != IDOK)
	{
		return;
	}

	::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
	EndWaitCursor();	
}

void CEARView::OnPointInvert() 
{
	// TODO: Add your command handler code here
	// 圖像反色
	
	CEARDoc* pDoc = GetDocument();
	
	LPSTR lpDIB;			// 指向DIB的指針	
	LPSTR    lpDIBBits;		// 指向DIB象素指針	
	FLOAT fA;				// 線性變換的斜率	
	FLOAT fB;				// 線性變換的截距	
	// 反色操作的線性變換的方程是-x + 255
	fA = -1.0;
	fB = 255.0;
	
	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());
	// 找到DIB圖像象素起始位置
	lpDIBBits = pDoc->GetDibImage()->FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖的反色,其它的可以類推)
	if (pDoc->GetDibImage()->DIBNumColors(lpDIB) != 256)
	{
		MessageBox("目前只支持256色位圖的反色!", "系統提示" , 
			MB_ICONINFORMATION | MB_OK);
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
		
		return;
	}
	
	BeginWaitCursor();
	
	// 調用LinerTrans()函數反色
	pDoc->GetDibImage()->LinerTrans(lpDIBBits,pDoc->GetDibImage()->DIBWidth(lpDIB), 
		pDoc->GetDibImage()->DIBHeight(lpDIB), fA, fB);
	
	pDoc->SetModifiedFlag(TRUE);	// 設置臟標記	
	pDoc->UpdateAllViews(NULL);		// 更新視圖
	
	::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());
	EndWaitCursor();	
}

void CEARView::OnPointLiner() 
{
	// TODO: Add your command handler code here
	// 線性變換

	CEARDoc* pDoc = GetDocument();
		
	LPSTR lpDIB;				// 指向DIB的指針	
	LPSTR    lpDIBBits;			// 指向DIB象素指針	
	CLinerParaDlg dlgPara;		// 創建對話框	
	FLOAT fA;					// 線性變換的斜率	
	FLOAT fB;					// 線性變換的截距
	
	lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) pDoc->GetHDIB());
	// 找到DIB圖像象素起始位置
	lpDIBBits = pDoc->GetDibImage()->FindDIBBits(lpDIB);
	
	// 判斷是否是8-bpp位圖(這里為了方便,只處理8-bpp位圖的線性變換,其它的可以類推)
	if (pDoc->GetDibImage()->DIBNumColors(lpDIB) != 256)
	{
		MessageBox("目前只支持256色位圖的線性變換!", "系統提示" , 
			MB_ICONINFORMATION | MB_OK);
		::GlobalUnlock((HGLOBAL) pDoc->GetHDIB());

		return;
	}
	
	dlgPara.m_fA = 2.0;
	dlgPara.m_fB = -128.0;
	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久麻豆| 国产精品77777| 精品噜噜噜噜久久久久久久久试看 | 欧美三级电影在线看| 亚洲18女电影在线观看| 久久视频一区二区| 欧美性受xxxx| a美女胸又www黄视频久久| 亚洲国产精品久久艾草纯爱| 欧美成人精品二区三区99精品| 色综合视频一区二区三区高清| 久热成人在线视频| 亚洲成人激情社区| 亚洲影视在线观看| 国产欧美精品一区aⅴ影院 | 色国产精品一区在线观看| 激情综合五月婷婷| 免费一级片91| 91精品国产欧美日韩| 欧美三级日韩在线| 欧美午夜精品久久久久久超碰| 国产成人精品免费看| 国产激情91久久精品导航| 精品亚洲国内自在自线福利| 天堂成人免费av电影一区| 亚洲在线视频网站| 亚洲一区二区三区视频在线播放| 亚洲视频 欧洲视频| 中文字幕一区二区在线观看| 国产精品视频免费| 国产精品视频在线看| 中文字幕在线不卡视频| 综合激情成人伊人| 亚洲第一电影网| 日韩黄色在线观看| 国产专区综合网| 成人精品视频一区二区三区尤物| 国产福利一区二区三区视频| 成人永久aaa| 欧美日韩一区二区不卡| 91精品国产色综合久久久蜜香臀| 欧美mv日韩mv| 国产精品九色蝌蚪自拍| 亚洲r级在线视频| 国产一区二区女| 色综合久久中文综合久久牛| 欧美日韩精品一区二区三区四区| 91麻豆精品国产| 国产午夜精品在线观看| 亚洲综合色网站| 极品销魂美女一区二区三区| 91丝袜呻吟高潮美腿白嫩在线观看| 欧美做爰猛烈大尺度电影无法无天| 9191久久久久久久久久久| 精品国产乱码久久久久久老虎| 中文字幕亚洲一区二区av在线 | 欧美一区二区免费| 国产精品久久久久一区二区三区 | 久久久不卡影院| 日韩精品亚洲一区| 一本色道综合亚洲| 久久久不卡影院| 日本一道高清亚洲日美韩| 99精品视频在线免费观看| 久久久五月婷婷| 久久精品99国产国产精| 在线综合视频播放| 国产亚洲综合在线| 蜜臂av日日欢夜夜爽一区| 欧美午夜精品久久久久久孕妇| 国产精品国产自产拍高清av王其 | 一区视频在线播放| 国产老肥熟一区二区三区| 91精品国产综合久久久久久漫画 | 一本大道久久精品懂色aⅴ| 欧美精品亚洲一区二区在线播放| 国产亚洲精品中文字幕| 国产福利不卡视频| 久久久久久久久久久99999| 国产激情一区二区三区桃花岛亚洲| 91精品国产高清一区二区三区蜜臀| 夜夜精品视频一区二区 | 欧美三级乱人伦电影| 丝袜亚洲精品中文字幕一区| 欧日韩精品视频| 天天做天天摸天天爽国产一区| 欧美日韩夫妻久久| 经典一区二区三区| 欧美激情艳妇裸体舞| 91在线看国产| 丝瓜av网站精品一区二区| 69久久99精品久久久久婷婷| 日本亚洲天堂网| 国产无人区一区二区三区| 色婷婷激情综合| 久久99精品国产.久久久久 | 午夜在线成人av| 精品国产污网站| 91在线视频观看| 日本中文一区二区三区| 中文文精品字幕一区二区| 国产69精品久久99不卡| 亚洲午夜视频在线| 国产香蕉久久精品综合网| 欧美日韩国产免费| 成人一道本在线| 免费在线观看视频一区| 中文字幕一区二区三区在线不卡| 欧美日韩一级片网站| 成人午夜视频网站| 另类欧美日韩国产在线| 一区二区国产视频| 中文字幕av一区二区三区免费看| 欧美年轻男男videosbes| 成人av动漫网站| 国产电影精品久久禁18| 日韩高清一级片| 亚洲一区在线播放| 国产精品久久久久久久久图文区 | 亚洲同性gay激情无套| 精品电影一区二区| 日韩一二三区视频| 3d动漫精品啪啪一区二区竹菊| 日本韩国欧美在线| 色综合久久99| 成av人片一区二区| 国产a精品视频| 国产乱淫av一区二区三区| 亚洲超碰精品一区二区| 亚洲欧美日韩国产手机在线| 国产亚洲欧洲一区高清在线观看| 69精品人人人人| 欧美精品vⅰdeose4hd| 日韩电影免费在线看| 亚洲精品乱码久久久久久久久 | 欧美一区二区三区电影| 精品视频一区二区不卡| 热久久一区二区| 亚洲欧美一区二区三区国产精品 | 亚洲aⅴ怡春院| 国产精品色眯眯| 亚洲日本va午夜在线影院| 成人欧美一区二区三区白人 | 久久久久久久久久看片| 国产亚洲自拍一区| 国产精品久久久久久久久晋中| 国产网红主播福利一区二区| 国产精品国产三级国产aⅴ中文| 国产精品丝袜在线| 亚洲亚洲精品在线观看| 日本网站在线观看一区二区三区| 国产精品中文字幕日韩精品| 成人午夜在线视频| 欧美日韩国产一二三| 久久综合狠狠综合久久激情| 国产片一区二区三区| 亚洲综合免费观看高清完整版在线 | 国产亚洲综合性久久久影院| 五月激情综合色| 国产高清不卡一区| 欧美日韩国产在线观看| 91精品婷婷国产综合久久性色 | 亚洲午夜精品网| 久久疯狂做爰流白浆xx| 色香蕉久久蜜桃| 欧美精品v国产精品v日韩精品| 国产午夜亚洲精品午夜鲁丝片| 亚洲综合免费观看高清完整版| 国产精品亚洲一区二区三区在线| 91首页免费视频| 国产精品沙发午睡系列990531| 石原莉奈在线亚洲三区| 波多野结衣精品在线| 欧美日韩成人综合在线一区二区| 久久久久久久久久久久电影| 亚洲国产精品视频| 97超碰欧美中文字幕| 国产欧美日韩在线看| 国产成人精品在线看| 欧美精品在线观看一区二区| 亚洲综合在线视频| 成人美女视频在线观看18| 精品少妇一区二区三区在线播放 | 精品国产青草久久久久福利| 午夜精品成人在线视频| 欧美午夜片在线看| 亚洲va欧美va国产va天堂影院| 国产精品一卡二卡在线观看| 国产女同互慰高潮91漫画| 黑人巨大精品欧美一区| 久久精品人人做人人爽人人| 丁香一区二区三区| 国产精品国产三级国产aⅴ原创| 国产乱码精品一区二区三| 国产精品视频免费看| 91年精品国产| 亚洲国产色一区| 久久蜜桃av一区精品变态类天堂| 国产在线精品视频| 成人欧美一区二区三区小说 |