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

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

?? faceview.cpp

?? 一個關于人臉檢測的源代碼
?? CPP
字號:
// faceView.cpp : implementation of the CFaceView class
//

#include "stdafx.h"
#include "face.h"
#include "DIB.h"
#include "faceDoc.h"
#include "faceView.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif
extern class DIB gDib;
extern HANDLE hDIB;
extern HANDLE hDIBTemp;
extern int gheight;
extern int gwidth;
extern WORD gwBytesPerLine;
/////////////////////////////////////////////////////////////////////////////
// CFaceView

IMPLEMENT_DYNCREATE(CFaceView, CScrollView)

BEGIN_MESSAGE_MAP(CFaceView, CScrollView)
	//{{AFX_MSG_MAP(CFaceView)
	ON_COMMAND(ID_ERASION, OnErasion)
	ON_COMMAND(ID_EYEMAP, OnEyemap)
	ON_COMMAND(ID_EYEMAPC, OnEyemapc)
	ON_COMMAND(ID_EYEMAPL, OnEyemapl)
	ON_COMMAND(ID_GET_FACE_AREA, OnGetFaceArea)
	ON_COMMAND(ID_LIGHTINGCONPENSATE, OnLightingconpensate)
	ON_COMMAND(ID_SKINTONE, OnSkintone)
	ON_COMMAND(ID_DELETE_FALSE_AREA, OnDeleteFalseArea)
	ON_COMMAND(ID_DILATION, OnDilation)
	ON_COMMAND(ID_ERASION_AGAIN, OnErasionAgain)
	ON_COMMAND(ID_DILATION_FIRST, OnDilationFirst)
	ON_COMMAND(ID_EYE_CB, OnEyeCb)
	ON_COMMAND(ID_EYE_Cr, OnEYECr)
	ON_COMMAND(ID_DELETE_FALSE_EYE, OnDeleteFalseEye)
	ON_COMMAND(ID_DELETESCATER, OnDeletescater)
	ON_COMMAND(ID_MOUSEMAP, OnMousemap)
	ON_COMMAND(ID_ERASION_MOUSE, OnErasionMouse)
	ON_COMMAND(ID_MOUTH_CENTER, OnMouthCenter)
	ON_COMMAND(ID_DILATION_EYE, OnDilationEye)
	ON_COMMAND(ID_EYE_CENTER, OnEyeCenter)
	ON_COMMAND(ID_GOULE_FACE, OnGouleFace)
	//}}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()

/////////////////////////////////////////////////////////////////////////////
// CFaceView construction/destruction

CFaceView::CFaceView()
{
	lpRgb = NULL;
	lpYcc = NULL;
	faceNum = 0;
	for(int i=0; i<ImgRange; i++)
		for (int j=0; j<ImgRange; j++)
		{
			this->emymapc[i][j] = false;
			this->emymapl[i][j] = false;
			this->lab[i][j] = false;
		}
	this->result = false;
}

CFaceView::~CFaceView()
{
}

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

	return CScrollView::PreCreateWindow(cs);
}

/////////////////////////////////////////////////////////////////////////////
// CFaceView drawing

void CFaceView::OnDraw(CDC* pDC)
{
	CFaceDoc* pDoc = GetDocument();
	ASSERT_VALID(pDoc);
	if(hDIB)
		gDib.PaintDIBTrue(pDC->GetSafeHdc(),CRect(0,0,gwidth,gheight),hDIB,CRect(0,0,gwidth,gheight),SRCCOPY);
	
	// TODO: add draw code for native data here
}

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

	CSize sizeTotal;
	// TODO: calculate the total size of this view
	sizeTotal.cx = sizeTotal.cy = 100;
	SetScrollSizes(MM_TEXT, sizeTotal);
}

/////////////////////////////////////////////////////////////////////////////
// CFaceView printing

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

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

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

/////////////////////////////////////////////////////////////////////////////
// CFaceView diagnostics

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

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

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

/////////////////////////////////////////////////////////////////////////////
// CFaceView message handlers

void CFaceView::OnErasion() 
{
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	Invalidate();
	
}

void CFaceView::OnEyemap() 
{
	LPBYTE lpData;
	long lOffset;
	lpData = gDib.FindDIBBits(hDIB);
	for (int i=0; i<gheight; i++)
		for (int j=0; j<gwidth; j++)
		{
			lOffset = gDib.PixelOffset(i, j, gwBytesPerLine);
			if( this->emymapc[i][j] && this->emymapl[i][j])
			{
				*(lpData + lOffset++) = 255;
				*(lpData + lOffset++) = 255;
				*(lpData + lOffset++) = 255;
			}

			else
			{
				*(lpData + lOffset++) = 0;
				*(lpData + lOffset++) = 0;
				*(lpData + lOffset++) = 0;
			}
		}
	Invalidate();
}

void CFaceView::OnEyemapc() 
{	
	LPBYTE lpData;
	if(lpYcc)
		delete[] lpYcc;
	lpYcc = new BYTE[gwBytesPerLine * gheight];
	 gDib.RgbtoYcb(hDIBTemp,lpYcc);
	 
	GlobalLock(hDIB);
	lpData = gDib.FindDIBBits(hDIB);
	//memcpy(lpData,gDib.YcctoRgb(lpYcc,gwBytesPerLine,gheight,gwidth),gwBytesPerLine*gheight);

	gDib.EyeMapC(lpData,lpYcc,gwBytesPerLine,CRect(0,0,gwidth-1,gheight-1));
	for(int i=0; i<gheight; i++)
		for (int j=0; j<gwidth; j++)
		{
			long lOffset;
			lOffset = gDib.PixelOffset(i, j, gwBytesPerLine);
			if(*(lpData + lOffset) == 255)
			{
				this->emymapc[i][j] = true;
			}
		}
	GlobalUnlock(hDIB);
	Invalidate();
	
}

void CFaceView::OnEyemapl() 
{
	LPBYTE lpDataR,lpDataD;
	if(lpYcc)
		delete[] lpYcc;
	GlobalLock(hDIBTemp);
	lpDataR = gDib.FindDIBBits(hDIBTemp);
	lpYcc = new BYTE[gwBytesPerLine * gheight];
	gDib.RgbtoYcb(hDIBTemp,lpYcc);
	lpDataD = gDib.FindDIBBits(hDIB);
	memcpy(lpDataD,lpDataR,gwBytesPerLine*gheight);
	gDib.EyeMapL(lpDataD,gwBytesPerLine, CRect(0,0,gwidth-1,gheight-1));
	for (int i=0; i<gheight; i++)
		for (int j=0; j<gwidth; j++)
		{
			long lOffset;
			lOffset = gDib.PixelOffset(i, j, gwBytesPerLine);
			if(*(lpDataD + lOffset) == 255)
			{
				this->emymapl[i][j] = true;
			}
		}
		GlobalUnlock(hDIBTemp);
	Invalidate();
	
}

void CFaceView::OnGetFaceArea() 
{
	gDib.FaceLocate(hDIB,faceLocation,faceNum);
	Invalidate();
	
}

void CFaceView::OnLightingconpensate() 
{	
	hDIBTemp = gDib.CopyHandle(hDIB);
	gDib.LightingCompensate(hDIB);
	GlobalUnlock(hDIB);
	Invalidate();
	
}

void CFaceView::OnSkintone() 
{	
	lpYcc = new BYTE[gwBytesPerLine * gheight];
	gDib.RgbtoYcb(hDIB,lpYcc);
	gDib.YccTransform(lpYcc, gwBytesPerLine,gheight,gwidth);
	gDib.faceear(lpYcc,gwBytesPerLine,gheight,gwidth,flag);
	
	LPBYTE lpData = (LPBYTE)GlobalLock(hDIB)+sizeof(BITMAPINFOHEADER);
	
	for (int i=0; i<gheight; i++)
		for (int j=0; j<gwidth; j++)
		{	
			long lOffset = gDib.PixelOffset(i, j, gwBytesPerLine);
			if (flag[i][j] == true)
			{
				*(lpData + lOffset++) = 255;
				*(lpData + lOffset++) = 255;
				*(lpData + lOffset++) = 255;
			}
			else
			{
				*(lpData + lOffset++) = 0;
				*(lpData + lOffset++) = 0;
				*(lpData + lOffset++) = 0;
			}
		}
		
		GlobalUnlock(hDIB);
		Invalidate();
}

void CFaceView::OnDeleteFalseArea() 
{
	gDib.ErasionFalseArea(hDIB);
	
	Invalidate();
	
}

void CFaceView::OnDilation() 
{
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	
	

	Invalidate();
	
}

void CFaceView::OnErasionAgain() 
{
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	gDib.Erasion(hDIB);
	LPBYTE lpData;
	GlobalLock(hDIB);
	lpData = gDib.FindDIBBits(hDIB);
	for (int i=0;i<gheight; i++)
		for (int j=0; j<gwidth; j++)
		{
			long lOffset = gDib.PixelOffset(i, j, gwBytesPerLine);
			if(*(lpData + lOffset) == 255)
			{
				this->lab[i][j] = true;
			}
		}
	GlobalUnlock(hDIB);
	Invalidate();
	
}

void CFaceView::OnDilationFirst() 
{
	gDib.Dilation(hDIB);
	gDib.Dilation(hDIB);
	Invalidate();
	
}

void CFaceView::OnEyeCb() 
{	
	lpRB = new BYTE[gwBytesPerLine * gheight];
	gDib.RgbtoYcb(hDIBTemp,lpRB);
	LPBYTE lpData =gDib.FindDIBBits(hDIB);
	gDib.EyeMapb(lpData,lpRB,gwBytesPerLine,CRect(0,0,gwidth-1,gheight-1));
	Invalidate();
	
}

void CFaceView::OnEYECr() 
{
	lpRB = new BYTE[gwBytesPerLine * gheight];
	gDib.RgbtoYcb(hDIBTemp,lpRB);
	LPBYTE lpData =gDib.FindDIBBits(hDIB);
	gDib.EyeMapR(lpData,lpRB,gwBytesPerLine,CRect(0,0,gwidth-1,gheight-1));
	Invalidate();
}

void CFaceView::OnDeleteFalseEye() 
{
	gDib.DeleteFasleEye(hDIB,faceLocation[0]);
	Invalidate();
}

void CFaceView::OnDeletescater() 
{
	gDib.DeleteScatePoint(hDIB);
	gDib.Dilation(hDIB);
	Invalidate();
	
}

void CFaceView::OnMousemap() 
{	
	if(lpYcc)
		delete [] lpYcc;
	lpYcc = new BYTE[gwBytesPerLine * gheight];
	if(!lpYcc)
		return;
	gDib.RgbtoYcb(hDIBTemp,lpYcc);
	LPBYTE lpData = gDib.FindDIBBits(hDIB);
	gDib.MouseMap(lpData,lpYcc,gwBytesPerLine,CRect(0,0,gwidth-1,gheight-1));
	//gDib.Erasion2(hDIB);
	
	Invalidate();
	

	
}

void CFaceView::OnErasionMouse() 
{
	gDib.Erasion2(hDIB);
	//gDib.DeleteScatePoint(hDIB);
	//gDib.Dilation(hDIB);
	//gDib.Dilation(hDIB);
	//gDib.DeleteScatePoint(hDIB);
	Invalidate();
}

void CFaceView::OnMouthCenter() 
{
	gDib.MouthCenter(hDIB,CRect(0,0,gwidth-1,gheight-1),mouthLocation);
	this->result = true;
	Invalidate();
}

void CFaceView::OnDilationEye() 
{
	gDib.Dilation(hDIB);
	Invalidate();
		
}

void CFaceView::OnEyeCenter() 
{
	gDib.EyeCenter(hDIB,CRect(0,0,gwidth-1,gheight-1),eye1,eye2);
	Invalidate();
}

void CFaceView::OnGouleFace() 
{
	gDib.EllipseFace(hDIBTemp,this->mouthLocation,this->eye1,this->eye2);
	if(hDIB)
		GlobalFree(hDIB);
	hDIB = gDib.CopyHandle(hDIBTemp);
	Invalidate();
	
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
天堂av在线一区| 欧美激情一区在线观看| 激情文学综合网| 日本一区二区三级电影在线观看| 成人avav在线| 中文字幕在线不卡| 欧美日韩国产美| 麻豆一区二区三区| 中文字幕一区二区日韩精品绯色| 欧美精品 日韩| 成人深夜福利app| 天堂久久久久va久久久久| 国产亚洲欧美色| 91美女在线观看| 极品少妇xxxx精品少妇偷拍| 亚洲少妇最新在线视频| 日韩午夜激情视频| 日本韩国欧美一区二区三区| 精品一区二区国语对白| 亚洲男同性视频| 国产日韩影视精品| 欧美色欧美亚洲另类二区| 国产成人av资源| 免费不卡在线视频| 一区二区三区加勒比av| 国产午夜精品一区二区三区嫩草| 日本道在线观看一区二区| 成年人午夜久久久| 精品一区二区精品| 午夜精品久久久久久久蜜桃app | 欧美综合视频在线观看| 国产精品中文字幕日韩精品 | 成人成人成人在线视频| 蜜臀av一区二区| 亚洲综合在线五月| 2024国产精品| 精品美女在线播放| 欧美高清dvd| 欧美无乱码久久久免费午夜一区| 成人综合婷婷国产精品久久蜜臀 | 91免费看`日韩一区二区| 国产成人综合亚洲91猫咪| 免费久久精品视频| 天天影视涩香欲综合网 | 国产午夜亚洲精品不卡| 日韩女优av电影| 538在线一区二区精品国产| 91久久精品一区二区| 豆国产96在线|亚洲| 麻豆国产精品一区二区三区| 日韩二区在线观看| 亚洲你懂的在线视频| 亚洲综合在线视频| 日韩视频在线你懂得| 日韩三级高清在线| 久久女同精品一区二区| 日本一区二区三级电影在线观看| 中文字幕一区视频| 亚洲一区在线观看视频| 午夜激情一区二区三区| 看电影不卡的网站| 国产成人在线色| 99精品视频在线观看| 在线免费观看一区| 91精品国产福利| 久久这里只有精品首页| 国产欧美一区二区精品秋霞影院| 国产欧美一区二区三区网站| 国产精品久久777777| 国产精品久久免费看| 一区二区三区成人| 亚洲福利一区二区| 久久电影国产免费久久电影 | 国产精品影视在线观看| 国产91露脸合集magnet| 91浏览器打开| 欧美日韩免费在线视频| 精品国产青草久久久久福利| 国产亚洲精品资源在线26u| 亚洲日本电影在线| 亚洲一区二区三区四区在线观看 | 成人91在线观看| 91麻豆精东视频| 日韩精品在线网站| 欧美国产一区视频在线观看| 一区二区在线看| 日本视频免费一区| 成人app软件下载大全免费| 在线精品视频一区二区三四| 久久亚洲二区三区| 亚洲人成影院在线观看| 久久精品国产在热久久| 精品久久久久久久久久久院品网 | 从欧美一区二区三区| 欧美优质美女网站| 日韩精品一区二区在线| 一区二区三区资源| 免播放器亚洲一区| 色综合久久88色综合天天| 欧美一区二区三区成人| 国产精品久久久爽爽爽麻豆色哟哟| 一区二区三区日本| 国产成人在线免费| 欧美精品在线视频| 成人免费在线观看入口| 秋霞午夜鲁丝一区二区老狼| 色综合久久久久| 亚洲精品一区二区三区香蕉| 亚洲伊人色欲综合网| 国内精品国产成人| 欧美日本免费一区二区三区| 欧美激情一区二区三区四区| 免费在线视频一区| 97成人超碰视| 久久精品欧美日韩精品| 日韩电影免费在线观看网站| 色婷婷精品久久二区二区蜜臂av | 精品国内二区三区| 久久久噜噜噜久噜久久综合| 亚洲国产精品黑人久久久| 另类调教123区| 欧洲精品一区二区三区在线观看| 一区精品在线播放| 久99久精品视频免费观看| 在线播放91灌醉迷j高跟美女 | 欧美性色欧美a在线播放| 综合久久国产九一剧情麻豆| 精品在线你懂的| 欧美电影免费观看高清完整版在线 | 欧美精品亚洲二区| 亚洲愉拍自拍另类高清精品| www.一区二区| 欧美激情一区在线| 国产剧情一区二区| 久久色.com| 久久av中文字幕片| 精品欧美一区二区在线观看| 亚洲精选在线视频| 欧美性受极品xxxx喷水| 久久品道一品道久久精品| 久久 天天综合| 欧美一个色资源| 日韩二区三区在线观看| 9191成人精品久久| 免费久久99精品国产| 欧美日本一区二区三区四区| 日韩专区在线视频| 欧美日韩在线播放| 日本不卡1234视频| 日韩手机在线导航| 国内不卡的二区三区中文字幕| 欧美一区二区视频网站| 激情六月婷婷综合| 久久老女人爱爱| 免费人成网站在线观看欧美高清| 国产一区二区三区香蕉| 久久久国产精品麻豆| 国产91对白在线观看九色| 国产精品久久精品日日| 97久久超碰国产精品电影| 亚洲国产一区二区三区青草影视| 国产精品18久久久久久久久| 亚洲日本免费电影| 91香蕉视频污| 日韩高清国产一区在线| 欧美男女性生活在线直播观看| 亚洲不卡一区二区三区| 日韩免费观看高清完整版在线观看| 免费观看成人鲁鲁鲁鲁鲁视频| 久久亚洲一区二区三区四区| 亚洲永久免费av| 日韩一级黄色大片| 国产乱码精品一区二区三区忘忧草| 精品乱码亚洲一区二区不卡| 久久91精品国产91久久小草| 久久久亚洲精品石原莉奈 | 国内精品伊人久久久久av影院 | 亚洲激情六月丁香| 67194成人在线观看| 亚洲国产成人va在线观看天堂 | 中文字幕 久热精品 视频在线| 91日韩在线专区| 一区二区激情视频| 亚洲精品一区二区三区蜜桃下载| 国产99一区视频免费| 亚洲欧美偷拍另类a∨色屁股| 欧美精品自拍偷拍动漫精品| 国产剧情在线观看一区二区| 亚洲午夜久久久久| 日韩欧美色电影| 91福利视频久久久久| 日韩国产精品久久久| 国产精品久久毛片a| 欧美在线观看视频一区二区三区| 韩国一区二区三区| 国产精品天美传媒| 欧美性色黄大片| www.欧美色图| 日日嗨av一区二区三区四区| 亚洲天堂2014|