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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? faceview.cpp

?? 人臉檢測(cè)系統(tǒng)---可以較好的實(shí)現(xiàn)人臉定位
?? CPP
字號(hào):
// 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();
	
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看国产91| 欧美国产综合色视频| 欧美四级电影在线观看| 99久久久久久99| 91麻豆文化传媒在线观看| 99久久精品免费观看| 色诱亚洲精品久久久久久| 一本色道久久综合精品竹菊| 在线欧美一区二区| 欧美区一区二区三区| 欧美一区二区三区四区久久| 欧美精品xxxxbbbb| 欧美一级日韩不卡播放免费| 精品福利视频一区二区三区| 国产亚洲va综合人人澡精品 | 亚洲女厕所小便bbb| 亚洲老妇xxxxxx| 亚洲动漫第一页| 久久99精品久久久久久国产越南| 精品一区二区三区免费播放| 国产成人免费视| 91亚洲男人天堂| 欧美日韩一本到| 日韩一卡二卡三卡国产欧美| 久久女同性恋中文字幕| 国产精品福利在线播放| 亚洲综合久久久| 蜜桃视频第一区免费观看| 久久精品国产999大香线蕉| 国产精品一区二区视频| 91在线视频网址| 欧美丰满嫩嫩电影| 久久久久久久久久久黄色| 亚洲乱码精品一二三四区日韩在线| 亚洲午夜电影在线| 国产精品一区在线观看你懂的| 成人动漫在线一区| 欧美日韩高清一区| 国产欧美日韩久久| 亚洲国产一区二区视频| 国产在线不卡一卡二卡三卡四卡| 99久久亚洲一区二区三区青草 | 国产精品乱人伦一区二区| 一区二区高清免费观看影视大全 | 成人av在线电影| 欧美美女一区二区在线观看| 国产亚洲精久久久久久| 亚洲五月六月丁香激情| 狠狠网亚洲精品| 亚洲色图视频网站| 日本女人一区二区三区| 一区二区三区视频在线观看| 2020国产精品久久精品美国| 国产不卡视频在线播放| 不卡高清视频专区| 日韩限制级电影在线观看| 亚洲手机成人高清视频| 国产一区二区三区四区在线观看| 色激情天天射综合网| 久久网站热最新地址| 亚洲已满18点击进入久久| 国产在线播放一区三区四| 欧美日韩国产乱码电影| 中文字幕免费不卡在线| 久久se精品一区精品二区| 在线观看一区日韩| 国产精品午夜在线观看| 久久狠狠亚洲综合| 欧美美女一区二区| 亚洲一区二区三区四区在线观看 | 国产精品免费视频网站| 免费观看久久久4p| 国产一区二区伦理| 国产精品久久久久久亚洲毛片| 亚洲成人av电影| 91在线精品秘密一区二区| 久久综合色一综合色88| 人妖欧美一区二区| 欧美久久婷婷综合色| 一区二区三区小说| 波多野洁衣一区| 久久精品一区四区| 另类小说视频一区二区| 88在线观看91蜜桃国自产| 一区二区三区欧美| 色综合天天天天做夜夜夜夜做| 欧美国产精品v| 国产精品综合视频| 337p日本欧洲亚洲大胆精品| 美女视频黄a大片欧美| 67194成人在线观看| 亚洲成人久久影院| 欧美亚洲图片小说| 亚洲一区二区视频| 欧美亚州韩日在线看免费版国语版| 中文字幕一区二区三区不卡在线 | 色激情天天射综合网| 亚洲三级在线免费观看| av毛片久久久久**hd| 国产精品色在线| 成人av在线播放网站| 国产精品传媒视频| 一本久久精品一区二区| 亚洲另类色综合网站| 欧美羞羞免费网站| 香蕉久久一区二区不卡无毒影院 | 国产日韩av一区| 国产精品一区二区三区网站| 久久久99久久| 成人av电影在线| 亚洲色大成网站www久久九九| 91日韩在线专区| 亚洲一区在线播放| 欧美一区二区视频免费观看| 免费欧美日韩国产三级电影| 日韩欧美国产一区二区在线播放| 免费国产亚洲视频| 久久久精品日韩欧美| 成人性生交大片免费| 亚洲欧美一区二区三区国产精品 | 成人国产精品免费网站| 亚洲欧美日韩在线不卡| 欧美亚洲国产bt| 免费成人你懂的| 久久久国产精品麻豆| 国产成人综合视频| 亚洲欧美自拍偷拍色图| 欧美偷拍一区二区| 蜜臀久久久99精品久久久久久| 久久久精品综合| 色婷婷久久久亚洲一区二区三区| 亚洲动漫第一页| 26uuu国产在线精品一区二区| 国产91在线观看丝袜| 亚洲综合在线视频| 欧美一区二区三区公司| 国产精品亚洲人在线观看| 自拍偷拍国产精品| 欧美电影一区二区| 国产福利91精品| 一区二区三区四区激情| 日韩精品专区在线| 99久久婷婷国产综合精品 | 欧美色综合久久| 黄网站免费久久| 亚洲男帅同性gay1069| 日韩欧美综合一区| 9i看片成人免费高清| 丝袜美腿亚洲综合| 日本一二三不卡| 欧美日韩成人综合| 成人一区二区在线观看| 亚洲成人免费av| 中文字幕欧美区| 欧美欧美欧美欧美| 成人av网址在线| 免费人成黄页网站在线一区二区| 中文字幕一区免费在线观看| 在线播放/欧美激情| av一区二区不卡| 久久精品国产久精国产爱| 一区二区三区四区亚洲| 久久亚洲综合色| 欧美日韩国产免费| 99精品桃花视频在线观看| 麻豆成人久久精品二区三区红| 亚洲色图欧洲色图| 国产日韩精品视频一区| 欧美一级专区免费大片| 在线精品视频一区二区三四| 国产福利不卡视频| 久久国产尿小便嘘嘘| 亚洲一区二区3| 中文字幕一区二区三区四区不卡| 精品国产99国产精品| 欧美狂野另类xxxxoooo| 91丝袜美女网| 成人综合婷婷国产精品久久| 久久99精品国产麻豆婷婷洗澡| 亚洲综合免费观看高清在线观看| 国产精品久久久久久福利一牛影视| 欧美成人免费网站| 欧美精品久久99久久在免费线| 97久久超碰国产精品| 国产69精品一区二区亚洲孕妇| 久久国产麻豆精品| 日韩中文字幕91| 午夜精品一区二区三区免费视频| 亚洲裸体在线观看| 一区视频在线播放| 国产精品久久国产精麻豆99网站| 久久综合久久综合久久综合| 欧美一区二区网站| 91精品国产黑色紧身裤美女| 欧美日韩一区二区在线观看| 欧美在线观看一二区| 在线观看日韩电影| 欧美午夜宅男影院| 欧美视频三区在线播放| 欧美综合一区二区|