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

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

?? facedetectionview.cpp

?? 人臉識別,希望對大家有所幫助!它的應用將擴展到教育、培訓和娛樂等新的領域。
?? CPP
字號:
// FaceDetectionView.cpp : implementation of the CFaceDetectionView class
//

#include "stdafx.h"
#include "FaceDetection.h"

#include "FaceDetectionDoc.h"
#include "FaceDetectionView.h"
#include "dibapi.h"

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

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionView

IMPLEMENT_DYNCREATE(CFaceDetectionView, CView)

BEGIN_MESSAGE_MAP(CFaceDetectionView, CView)
	//{{AFX_MSG_MAP(CFaceDetectionView)
	ON_COMMAND(ID_LIGHT, OnLightconpensate)
	ON_COMMAND(ID_SKINTONE, OnSkintone)
	ON_COMMAND(ID_DILATION_FIRST, OnDilationFirst)
	ON_COMMAND(ID_ERASION, OnErasionFirst)
	ON_COMMAND(ID_DELETE_FALSE_AREA, OnDeleteFalseArea)
	ON_COMMAND(ID_DILATION, OnDilationAgain)
	ON_COMMAND(ID_ERASION_AGAIN, OnErasionAgain)
	ON_COMMAND(ID_GET_FACE_AREA, OnGetFaceArea)
	ON_COMMAND(ID_EYEMAPC, OnEyemapc)
	ON_COMMAND(ID_EYEMAPL, OnEyemapl)
	ON_COMMAND(ID_EYEMAP, OnEyemap)
	ON_COMMAND(ID_DELETE_FALSE_EYE, OnDeleteFalseEye)
	ON_COMMAND(ID_DILATION_EYE, OnDilationEye)
	ON_COMMAND(ID_EYE_CENTER, OnEyeCenter)
	ON_COMMAND(ID_MOUSEMAP, OnMousemap)
	ON_COMMAND(ID_ERASION_MOUSE, OnErasionMouse)
	ON_COMMAND(ID_DELETESCATER, OnDeletescater)
	ON_COMMAND(ID_MOUTH_CENTER, OnMouthCenter)
	ON_COMMAND(ID_GOULE_FACE, OnGouleFace)
	//}}AFX_MSG_MAP
	// Standard printing commands
	ON_COMMAND(ID_FILE_PRINT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_DIRECT, CView::OnFilePrint)
	ON_COMMAND(ID_FILE_PRINT_PREVIEW, CView::OnFilePrintPreview)
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionView construction/destruction

CFaceDetectionView::CFaceDetectionView()
{
	// TODO: add construction code here
	faceNum = 0;
	facedetect=false;
	eyedetect=false;
	mousedetect=false;

}

CFaceDetectionView::~CFaceDetectionView()
{
}

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

	return CView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionView drawing

void CFaceDetectionView::OnDraw(CDC* pDC)
{
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
		
	HDIB m_hDIB = pDoc->m_hDIB;

	// 判斷DIB是否為空
	if (m_hDIB != NULL)
	{
		LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);
		
		// 獲取DIB寬度
		int cxDIB = (int) ::DIBWidth(lpDIB);
		
		// 獲取DIB高度
		int cyDIB = (int) ::DIBHeight(lpDIB);

		::GlobalUnlock((HGLOBAL) m_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;
		}
		

		::PaintDIB(pDC->m_hDC, &rcDest, pDoc->m_hDIB,
			&rcDIB, NULL);
	}
	// TODO: add draw code for native data here
}

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionView printing

BOOL CFaceDetectionView::OnPreparePrinting(CPrintInfo* pInfo)
{
	// default preparation
	return DoPreparePrinting(pInfo);
}

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

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

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionView diagnostics

#ifdef _DEBUG
void CFaceDetectionView::AssertValid() const
{
	CView::AssertValid();
}

void CFaceDetectionView::Dump(CDumpContext& dc) const
{
	CView::Dump(dc);
}

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

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionView message handlers

void CFaceDetectionView::OnLightconpensate() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->LightingCompensate();
	pDoc->UpdateAllViews(NULL);
		
}

void CFaceDetectionView::OnSkintone() 
{
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Skintone();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnDilationFirst() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Dilation();
	pDoc->Dilation();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnErasionFirst() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Erasion();
	pDoc->Erasion();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnDeleteFalseArea() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->DeleteFalseArea();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnDilationAgain() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Dilation();
	pDoc->Dilation();
	pDoc->Dilation();
	pDoc->Dilation();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnErasionAgain() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Erasion();
	pDoc->Erasion();
	pDoc->Erasion();
	pDoc->Erasion();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnGetFaceArea() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->FaceLocate(faceLocation,faceNum);
	facedetect=true;
	pDoc->UpdateAllViews(NULL);
	
}


void CFaceDetectionView::OnEyemapc() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->EyeMappingC();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnEyemapl() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->EyeMappingL();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnEyemap() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Eyemap();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnDeleteFalseEye() 
{
	// TODO: Add your command handler code here
	if (!facedetect)
	{
		AfxMessageBox("請先檢測人臉!");
			return;
	}
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->DeleteFasleEye(faceLocation[0]);
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnDilationEye() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->Dilation();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnEyeCenter() 
{
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->EyeCenter(eye1,eye2);
	eyedetect=true;
	pDoc->UpdateAllViews(NULL);	
	
}

void CFaceDetectionView::OnMousemap() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->MouseMap();
	pDoc->UpdateAllViews(NULL);	
	
}

void CFaceDetectionView::OnErasionMouse() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->ErasionMouse();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnDeletescater() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->DeleteScatePoint();
	pDoc->Dilation();
	pDoc->UpdateAllViews(NULL);
	
}

void CFaceDetectionView::OnMouthCenter() 
{
	// TODO: Add your command handler code here
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->MouthCenter(mouthLocation);
	mousedetect=true;
	pDoc->UpdateAllViews(NULL);
	result = true;
}

void CFaceDetectionView::OnGouleFace() 
{
	// TODO: Add your command handler code here
	if(!(facedetect&&mousedetect&&eyedetect))
	{
		AfxMessageBox("請先完成人臉檢測、人眼定位和嘴巴定位!");
			return;
	}
	CFaceDetectionDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	pDoc->EllipseFace(mouthLocation,eye1,eye2,faceLocation[0]);
	pDoc->UpdateAllViews(NULL);
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区免费不卡| 欧美性生交片4| 欧美性做爰猛烈叫床潮| 精品欧美一区二区久久| 日韩美女啊v在线免费观看| 日本在线不卡一区| 不卡大黄网站免费看| 日韩精品中文字幕一区| 亚洲男人天堂av| 国产成人综合网| 欧美一区二区日韩| 美日韩一区二区| 色综合久久66| 国产欧美日韩精品在线| 日本在线播放一区二区三区| 91性感美女视频| 亚洲精品在线电影| 日韩av在线免费观看不卡| 色综合久久88色综合天天6| 久久精品夜色噜噜亚洲aⅴ| 三级久久三级久久| 欧美怡红院视频| 国产精品成人免费精品自在线观看| 丝袜美腿亚洲一区二区图片| 色综合久久88色综合天天| 国产精品女人毛片| 国产成人在线电影| 欧美—级在线免费片| 国产一区二区免费视频| 精品国产精品一区二区夜夜嗨| 日韩精品一二三区| 日韩欧美一区二区不卡| 美女精品一区二区| 日韩视频免费观看高清在线视频| 亚洲成人动漫一区| 欧美日本一区二区在线观看| 亚洲第一av色| 欧美一级日韩一级| 久久99深爱久久99精品| 精品久久久久久久一区二区蜜臀| 日韩av电影免费观看高清完整版在线观看 | 精品视频色一区| wwww国产精品欧美| 国产在线日韩欧美| 日韩一区二区视频在线观看| 天天综合色天天综合色h| 日本久久一区二区| 亚洲最大的成人av| 日本韩国一区二区| 午夜精品久久久久久久99樱桃| 在线观看成人免费视频| 亚洲免费观看在线视频| 91在线看国产| 成人免费在线观看入口| jvid福利写真一区二区三区| 国产视频911| 国产91在线观看丝袜| 国产亚洲人成网站| 国产91高潮流白浆在线麻豆| 国产欧美日韩另类视频免费观看| 日韩av二区在线播放| 成人国产精品免费观看视频| 国产日韩欧美电影| 99综合电影在线视频| 国产精品久久久久久久久图文区 | 国产精品1区2区3区| 天堂在线一区二区| 7777精品伊人久久久大香线蕉| 亚洲一区二区精品久久av| 日本韩国精品一区二区在线观看| 一区二区三区在线观看欧美| 欧美在线观看你懂的| 日韩 欧美一区二区三区| 3atv在线一区二区三区| 麻豆成人av在线| 亚洲国产精品成人综合| 色呦呦一区二区三区| 亚洲成人免费视| 91精品国产全国免费观看| 亚洲午夜激情网页| 欧美在线观看禁18| 国产高清不卡二三区| 亚洲精品国产a| 678五月天丁香亚洲综合网| 免费久久99精品国产| 国产精品视频一二三区| 色天天综合久久久久综合片| 日本亚洲视频在线| 国产欧美一区二区精品性色超碰| 色偷偷久久人人79超碰人人澡| 丝袜亚洲另类欧美| 国产午夜精品一区二区| 日本乱码高清不卡字幕| 青娱乐精品视频在线| 欧美激情自拍偷拍| 欧美福利视频导航| 成人综合在线观看| 日韩av一区二区三区四区| 国产精品女上位| 91精品中文字幕一区二区三区| 国产成人免费网站| 日韩电影免费在线看| 国产精品久久久久久久岛一牛影视| 欧美日韩国产成人在线91| 国产精品一区二区黑丝| 亚洲va国产va欧美va观看| 国产精品久久久久久久久免费相片 | 日韩美女视频一区二区| 精品少妇一区二区三区免费观看 | 在线观看91视频| 国产69精品久久99不卡| 日韩和欧美一区二区| 亚洲免费观看高清| 日韩一区二区高清| 91精品国产综合久久久久| av不卡免费电影| 国产伦精品一区二区三区视频青涩| 一区二区欧美国产| 欧美高清在线一区二区| 欧美videos中文字幕| 欧美日韩国产大片| 在线精品国精品国产尤物884a| 成人晚上爱看视频| 国产一区二区美女| 美美哒免费高清在线观看视频一区二区 | 亚洲桃色在线一区| 国产日产精品一区| 欧美一激情一区二区三区| 欧美四级电影在线观看| 国产一区二区影院| 麻豆精品在线观看| 免费在线观看一区二区三区| 成人视屏免费看| 韩国一区二区视频| 久久99精品视频| 免费精品99久久国产综合精品| 亚洲国产一二三| 亚洲一区二区三区在线| 亚洲乱码国产乱码精品精小说| 日韩一区在线播放| 亚洲色欲色欲www| 亚洲欧美日韩人成在线播放| 亚洲欧洲在线观看av| 成人免费在线视频| 亚洲男同性视频| 亚洲自拍偷拍九九九| 亚洲同性同志一二三专区| 一色屋精品亚洲香蕉网站| 国产精品久久久久久久久搜平片| 中文字幕一区二区三区不卡| 亚洲人精品午夜| 亚洲国产精品尤物yw在线观看| 亚洲二区在线视频| 日日欢夜夜爽一区| 亚洲国产精品尤物yw在线观看| 美日韩一区二区三区| 国产成人综合亚洲网站| av一区二区三区四区| 欧美在线色视频| 日韩午夜小视频| 欧美激情一区二区在线| 综合欧美一区二区三区| 亚洲午夜久久久久久久久电影院| 亚洲一区二区视频在线| 日本伊人色综合网| 国产高清亚洲一区| 91福利在线看| 欧美成va人片在线观看| 国产精品色婷婷久久58| 亚洲一区二区三区国产| 极品瑜伽女神91| 91免费观看视频| 欧美日韩情趣电影| 国产精品色噜噜| 日韩高清欧美激情| 国产精品12区| 欧美日韩午夜在线| 中文字幕精品—区二区四季| 午夜影视日本亚洲欧洲精品| 九九国产精品视频| 欧洲av在线精品| 久久精品日产第一区二区三区高清版| 午夜精品一区二区三区免费视频| 国产一区中文字幕| 欧美三级乱人伦电影| 久久久久国产一区二区三区四区| 亚洲欧美色一区| 久久99久久99精品免视看婷婷| 欧美一区二区在线播放| 国产精品卡一卡二卡三| 日韩中文字幕av电影| 99久久99久久精品免费看蜜桃| 欧美一区二区免费视频| 亚洲天堂2016| 国产成人在线看| 精品视频在线免费| 亚洲视频一区二区在线| 国产成人免费视频一区| 日韩一级免费观看| 一区二区在线电影|