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

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

?? facedetectiondoc.cpp

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

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

#include "FaceDetectionDoc.h"

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

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionDoc

IMPLEMENT_DYNCREATE(CFaceDetectionDoc, CDocument)

BEGIN_MESSAGE_MAP(CFaceDetectionDoc, CDocument)
	//{{AFX_MSG_MAP(CFaceDetectionDoc)
	ON_COMMAND(ID_FILE_SAVE_AS, OnFileSaveAs)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionDoc construction/destruction

CFaceDetectionDoc::CFaceDetectionDoc()
{
	// TODO: add one-time construction code here
	int i,j;
	m_hDIB=NULL;
	for( i=0; i<ImgRange; i++)
		for ( j=0; j<ImgRange; j++)
		{
			emymapc[i][j] = false;
			emymapl[i][j] = false;
			//lab[i][j] = false;
		}
	for( i=0;i<ImgRange; i++)
		for ( j=0; j<ImgRange; j++)
			lab[i][j] = false;

}

CFaceDetectionDoc::~CFaceDetectionDoc()
{
}

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

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

	return TRUE;
}



/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionDoc serialization

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

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionDoc diagnostics

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

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

/////////////////////////////////////////////////////////////////////////////
// CFaceDetectionDoc commands

BOOL CFaceDetectionDoc::OnOpenDocument(LPCTSTR lpszPathName) 
{
	if (!CDocument::OnOpenDocument(lpszPathName))
		return FALSE;
	CFile fileM;
	CFileException feM;
	m_hDIB = NULL;
	if (!fileM.Open(lpszPathName, CFile::modeRead | CFile::shareDenyWrite, &feM))
	{
		// 失敗
		ReportSaveLoadException(lpszPathName, &feM,FALSE, AFX_IDP_FAILED_TO_OPEN_DOC);	
		// 返回FALSE
		return FALSE;
	}
	if (!fileM2.Open(lpszPathName, CFile::modeRead | CFile::shareDenyWrite, &feM))
	{
		// 失敗
		ReportSaveLoadException(lpszPathName, &feM,FALSE, AFX_IDP_FAILED_TO_OPEN_DOC);	
		// 返回FALSE
		return FALSE;
	}
		TRY
	{
		m_hDIB = ::ReadDIBFile(fileM);
	}
	CATCH (CFileException, eLoad)
	{
		// 讀取失敗
		fileM.Abort();		
		// 恢復光標形狀
		EndWaitCursor();		
		// 報告失敗
		ReportSaveLoadException(lpszPathName, eLoad,
			FALSE, AFX_IDP_FAILED_TO_OPEN_DOC);	
		// 設置DIB為空
		m_hDIB = NULL;	
		fileM.Close();
		// 返回FALSE
		return FALSE;
	}
	END_CATCH
	m_hDIBtemp=(HDIB)CopyHandle(m_hDIB);
	//if(fileM.Read(&bmfHeaderMulspec,sizeof(BITMAPFILEHEADER)) != sizeof(BITMAPFILEHEADER))
	//return FALSE;

	fileM.Close();
	// TODO: Add your specialized creation code here
	return TRUE;
}
bool CFaceDetectionDoc::LightingCompensate()
{

	LPBITMAPINFOHEADER lpbi;
	lpbi = (LPBITMAPINFOHEADER)::GlobalLock((HGLOBAL) m_hDIB);//讀取頭文件
	lLineBytesMulspec = WIDTHBYTES((lpbi->biWidth)*24);
	::GlobalUnlock((HGLOBAL) m_hDIB);
	int width,height;
	LPBYTE lpData;
	long wBytesPerLine;
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);	
	// 獲取DIB寬度
	width= (int) ::DIBWidth(lpDIB);		
	// 獲取DIB高度
	height= (int) ::DIBHeight(lpDIB);
	::GlobalUnlock((HGLOBAL) m_hDIB);
	lpData = (unsigned char*)::FindDIBBits(lpDIB);
	//得到圖片每行的象素所占字節個數
	wBytesPerLine = lLineBytesMulspec;
	//比例系數
	const float thresholdco = 0.05;
	//象素個數的臨界常數
	const int thresholdnum = 100;
	//灰度級數組
	int histogram[256];
	for(int i =0;i<256;i++)
		histogram[i] = 0;
	//對于過于小的圖片的判斷
	if(width*height*thresholdco < thresholdnum)
		return false;
	int colorr,colorg,colorb;
	long lOffset;
	//考察整個圖片
	for( i=0;i<height;i++)
		for(int j=0;j<width;j++)
		{	
			//得到象素數據的偏移
			lOffset = i*wBytesPerLine + j*3;
			//得到rgb值
			colorb = *(lpData+lOffset++);
			colorg = *(lpData+lOffset++);
			colorr = *(lpData+lOffset++);
			//計算灰度值
			int gray = (colorr * 299 + colorg * 587 + colorb * 114)/1000;
			histogram[gray]++;
		}
		int calnum =0;
		int total = width*height;
		int num;
		//下面的循環得到滿足系數thresholdco的臨界灰度級
		for(i =0;i<256;i++)
		{
			if((float)calnum/total < thresholdco)
			{
				calnum+= histogram[255-i];
				num = i;
			}
			else
				break;
		}
		int averagegray = 0;
		calnum =0;
		//得到滿足條件的象素總的灰度值
		for(i = 255;i>=255-num;i--)
		{
			averagegray += histogram[i]*i;
			calnum += histogram[i];
		}
		averagegray /=calnum;
		//得到光線補償的系數
		float co = 255.0/(float)averagegray;
		//下面的循環對圖象進行光線補償
		for(i =0;i<height;i++)
			for(int j=0;j<width;j++)
			{	
				//得到數據便宜
				lOffset =i*wBytesPerLine + j*3;
				//得到藍色分量
				colorb = *(lpData+lOffset);
				//調整
				colorb *=co;
				//臨界判斷
				if(colorb >255)
					colorb = 255;
				//保存
				*(lpData+lOffset) = colorb;
				//綠色分量
				colorb = *(lpData+lOffset+1);
				colorb *=co;
				if(colorb >255)
					colorb = 255;
				*(lpData+lOffset+1) = colorb;
				//紅色分量
				colorb = *(lpData+lOffset+2);
				colorb *=co;
				if(colorb >255)
					colorb = 255;
				*(lpData+lOffset+2) = colorb;
			}
	return TRUE;
}
void CFaceDetectionDoc::RgbtoYcb(HDIB hDIB,LPBYTE lpYcb)
{
	LPBITMAPINFOHEADER lpbi;
	lpbi = (LPBITMAPINFOHEADER)::GlobalLock((HGLOBAL) hDIB);//讀取頭文件
	lLineBytesMulspec = WIDTHBYTES((lpbi->biWidth)*24);
	::GlobalUnlock((HGLOBAL)hDIB);
	int width,height;
	WORD wBytesPerLine;
	LPBYTE lpData;
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) hDIB);	
	// 獲取DIB寬度
	width= (int) ::DIBWidth(lpDIB);		
	// 獲取DIB高度
	height= (int) ::DIBHeight(lpDIB);
	lpData = (unsigned char*)::FindDIBBits(lpDIB);
	//得到圖象的基本信息	
	wBytesPerLine = lLineBytesMulspec;//得到圖片每行的象素所占字節個數

	long lOffset;
	//下面的循環實現從rgb到ycc的轉化
	for(int i=0;i<height;i++)
		for(int j=0;j<width;j++)
		{
			
			lOffset = i*wBytesPerLine + j*3;	//得到象素數據的偏移
			//得到rgb數值
			int b = *(lpData + lOffset);
			int g = *(lpData + lOffset+1);
			int r = *(lpData + lOffset+2);
			//計算得到y,cr,cb的數值
			int Y = (257*r+504*g+98*b)/1000+16;
			int Cr = (439*r-368*g-71*b)/1000+128;
			int Cb = (-148*r-291*g+439*b)/1000+128;
			//保存計算得到的數值
			*(lpYcb+lOffset++) = Y;
			*(lpYcb+lOffset++) = Cr;
			*(lpYcb+lOffset++) = Cb;
		}
	::GlobalUnlock((HGLOBAL) hDIB);
}

//////////////*皮膚顏色建模*//////////////
int CFaceDetectionDoc::_Cb(int Y)
{	
	int Cb;
	//如果亮度很小的情況
	if(Y<Kl)
		Cb = 108 + ((Kl-Y)*10)/(Kl-Ymin);
	//亮度很大的情況
	else if(Y>Kh)
		Cb = 108 + ((Y-Kh)*10)/(Ymax - Kh);
	else 
		Cb = -1;
	return Cb;
}

int CFaceDetectionDoc::_Cr(int Y)
{
	int Cr;
	//亮度很小的情況
	if(Y<Kl)
		Cr = 154 - ((Kl-Y)*10)/(Kl-Ymin);
	//亮度很大的情況
	else if(Y>Kh)
		Cr = 154 - ((Y-Kh)*22)/(Ymax - Kh);
	else
		Cr = -1;
	return Cr;
}
int CFaceDetectionDoc::_WCr(int Y)
{
	int WCr;
	if(Y<Kl)
		//亮度很小的情況
		WCr = WLcr + ((Y-Ymin)*(Wcr-WLcr))/(Kl-Ymin);
	else if(Y>Kh)
		//亮度很大的情況
		WCr = WHcr + ((Ymax-Y)*(Wcr-WHcr))/(Ymax-Kh);
	else WCr = -1;
	return WCr;
}

int CFaceDetectionDoc:: _WCb(int Y)
{
	int WCb;
	if(Y<Kl)
		//亮度很小的情況
		WCb = WLcb + ((Y-Ymin)*(Wcb-WLcb))/(Kl-Ymin);
	else if(Y>Kh)
		//亮度很大的情況
		WCb = WHcb + ((Ymax-Y)*(Wcb-WHcb))/(Ymax-Kh);
	else WCb = -1;
	return WCb;
}
void CFaceDetectionDoc::YccTransform(LPBYTE lpYcc,WORD wBytesPerLine,int height,int width)
{	
	int Y,Cr,Cb;
	long lOffset;
	//下面的循環實現ycc色彩空間的非線性轉換
	for(int i=0;i<height;i++)
		for(int j=0;j<width;j++)
		{	
			//得到數據偏移
			lOffset = i*wBytesPerLine + j*3;
			//得到y,Cr,Cb數值
			Y = *(lpYcc+lOffset);
			Cr = *(lpYcc+lOffset+1);
			Cb = *(lpYcc+lOffset+2);
			//如果y數值在兩個臨界值之間,保持不變
			if(Y>=Kl && Y<=Kh)
				continue;
			//調用非線性轉換函數調整Cr,Cb的數值
			Cr = (Cr-_Cr(Y))*(Wcr/_WCr(Y))+_Cr(Kh);
			Cb = (Cb-_Cb(Y))*(Wcb/_WCb(Y))+_Cb(Kh);
			*(lpYcc+lOffset+1) = Cr;
			*(lpYcc+lOffset+2) = Cb;
		}
}

void CFaceDetectionDoc::faceear(LPBYTE lpYcc, WORD wBytesPerLine, int height,int width, bool flag[ImgRange][ImgRange])
{	
	//初始化標志位
	for (int i=0; i<ImgRange; i++)
		for (int j=0; j<ImgRange; j++)
		{
			flag[i][j] = false;
		}
	long lOffset;
	int Cr;
	int Cb;
	for (i=0; i<height; i++)
		for (int j=0; j<width; j++)
		{	
			//得到偏移
			lOffset = i*wBytesPerLine + j*3;
			//得到Cr,Cb數值
			Cr = *(lpYcc+lOffset+1);
			Cb = *(lpYcc+lOffset+2);
			//人臉顏色建模
			if(FaceModeling(Cr,Cb))
			{	
				//修改標志位
				flag[i][j] = true;
			}
		}	
}
BOOL CFaceDetectionDoc::FaceModeling(int Cr,int Cb)
{	
	//Cb的系數常量
	const float cx = 122.453;//114.38;
	//cr的系數常量
	const float cy = 158.442;//160.02;
	//角度常量
	const float theta = 2.53;
	//x軸線和y軸線的兩個常量
	const float ecx = 1.60;
	const float ecy = 2.41;
	//長軸
	const float a = 25.39;
	//短軸
	const float b = 14.03;
	//相似度常量
	const float judge = 0.5;
	//計算得到x軸數值
	float  x = cos(theta)*(Cb-cx)+sin(theta)*(Cr-cy);
	//y軸數值
	float  y = -sin(theta)*(Cb -cx)+cos(theta)*(Cr-cy);
	//計算離心率
	float temp = pow(x-ecx,2)/pow(a,2)+pow(y-ecy,2)/pow(b,2);
	//如果滿足要求返回真,否則假
	if(fabs(temp-1.0)<judge)
		return TRUE;
	else
		return FALSE;
}

void CFaceDetectionDoc::Skintone() 
{	
	LPBITMAPINFOHEADER lpbi;
	lpbi = (LPBITMAPINFOHEADER)::GlobalLock((HGLOBAL) m_hDIB);//讀取頭文件
	lLineBytesMulspec = WIDTHBYTES((lpbi->biWidth)*24);
	::GlobalUnlock((HGLOBAL) m_hDIB);
	int width,height;
	LPBYTE lpData;
	long wBytesPerLine;
	LPSTR lpDIB = (LPSTR) ::GlobalLock((HGLOBAL) m_hDIB);	
	// 獲取DIB寬度
	width= (int) ::DIBWidth(lpDIB);		
	// 獲取DIB高度
	height= (int) ::DIBHeight(lpDIB);
	::GlobalUnlock((HGLOBAL) m_hDIB);
	lpData = (unsigned char*)::FindDIBBits(lpDIB);
	//得到圖片每行的象素所占字節個數
	wBytesPerLine = lLineBytesMulspec;
	lpYcc = new BYTE[wBytesPerLine * height];
	RgbtoYcb(m_hDIB,lpYcc);
	YccTransform(lpYcc, wBytesPerLine,height,width);
	faceear(lpYcc,wBytesPerLine,height,width,flag);	
	lpData =(LPBYTE)::GlobalLock(lpDIB)+sizeof(BITMAPINFOHEADER);	
	for (int i=0; i<height; i++)
		for (int j=0; j<width; j++)
		{	
			long lOffset = i*wBytesPerLine + j*3;
			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(lpDIB);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产自产v一区二区三区c| 一区二区在线观看av| 欧美aaa在线| 欧美成人免费网站| 国产资源精品在线观看| 国产日韩欧美精品一区| eeuss鲁片一区二区三区在线观看| 国产午夜精品福利| 99视频一区二区三区| 亚洲一区二区三区在线播放| 欧美三电影在线| 日日夜夜精品视频免费| 日韩欧美123| 国产成人a级片| 亚洲色图制服丝袜| 欧美一区二区三区在线视频| 国内精品伊人久久久久av一坑| 国产日韩欧美综合一区| 色综合久久久久网| 天堂成人国产精品一区| 日韩一级视频免费观看在线| 国产91精品在线观看| 一区二区三区不卡视频| 日韩视频在线一区二区| 成人禁用看黄a在线| 亚洲一区在线观看视频| 日韩欧美不卡在线观看视频| 成人精品国产免费网站| 亚洲国产成人porn| 精品国产一区二区三区四区四 | 国产在线播放一区二区三区| 中文字幕va一区二区三区| 欧美三片在线视频观看| 精品亚洲aⅴ乱码一区二区三区| 亚洲欧洲美洲综合色网| 宅男在线国产精品| 成人爱爱电影网址| 美腿丝袜亚洲色图| 亚洲欧美日韩一区二区三区在线观看 | 男男视频亚洲欧美| 国产精品灌醉下药二区| 日韩一区二区在线看| 91视频精品在这里| 韩国av一区二区三区四区| 亚洲综合色丁香婷婷六月图片| xnxx国产精品| 欧美日韩成人高清| 成人激情开心网| 久久99精品久久久| 亚洲一区二区三区小说| 国产精品人成在线观看免费| 日韩视频一区二区三区| 欧美色综合久久| 高潮精品一区videoshd| 美女网站视频久久| 一区二区在线观看视频| 中文字幕av不卡| 2020日本不卡一区二区视频| 欧美日韩高清一区二区三区| 色综合夜色一区| 国产精品资源在线看| 蜜桃传媒麻豆第一区在线观看| 亚洲一二三专区| 亚洲人妖av一区二区| 欧美激情中文不卡| 精品久久久久久无| 日韩免费一区二区三区在线播放| 欧美性受xxxx| 在线观看欧美日本| 91丨porny丨最新| 岛国av在线一区| 国产毛片精品视频| 国产一区亚洲一区| 国产一区二区三区香蕉| 欧美中文字幕不卡| 91美女片黄在线| 99久久精品国产观看| 成人高清av在线| 大尺度一区二区| 高清国产一区二区三区| 国产盗摄一区二区三区| 国产经典欧美精品| 国产传媒久久文化传媒| 国产精品一区二区无线| 国产精品一区二区三区99| 国产精品1区二区.| 国产不卡视频在线播放| 成人丝袜视频网| thepron国产精品| 91首页免费视频| 欧美午夜电影在线播放| 欧美日韩大陆在线| 91精品国产色综合久久不卡电影| 51精品国自产在线| 欧美一区二区三区喷汁尤物| 欧美一区二区三区免费观看视频| 欧美一区二区三区免费大片| 日韩欧美一级特黄在线播放| 久久久欧美精品sm网站| 中文字幕精品—区二区四季| 亚洲欧美日韩国产综合在线| 一区二区三区国产豹纹内裤在线| 亚洲成人午夜电影| 美女诱惑一区二区| 粉嫩一区二区三区性色av| 91欧美激情一区二区三区成人| 欧美综合在线视频| 日韩欧美国产精品| 国产精品久久久久久妇女6080| 亚洲欧美电影院| 日韩不卡一二三区| 成人永久看片免费视频天堂| 一本大道久久a久久综合婷婷| 555www色欧美视频| 国产日韩av一区二区| 玉米视频成人免费看| 男男视频亚洲欧美| 成人av在线资源网站| 欧美精品久久99久久在免费线 | 国产精品自拍一区| 91小视频在线| 欧美xxxxx牲另类人与| 中文字幕亚洲成人| 美国毛片一区二区| 91色porny蝌蚪| 日韩一区二区在线播放| 亚洲欧洲日韩av| 理论电影国产精品| 91麻豆文化传媒在线观看| 欧美一区2区视频在线观看| 国产精品久久久久影院老司| 蜜臀av一区二区在线免费观看| 不卡视频免费播放| 精品国产污污免费网站入口| 一区二区三区在线观看欧美| 国产一二精品视频| 欧美日韩一区二区三区四区| 国产精品污污网站在线观看 | 性欧美疯狂xxxxbbbb| 国产高清久久久久| 91麻豆精品国产| 亚洲美女视频在线观看| 国产91精品免费| 日韩一区二区电影网| 亚洲一区二区三区视频在线播放| 国产999精品久久久久久绿帽| 制服丝袜亚洲网站| 亚洲国产精品综合小说图片区| 国产精品乡下勾搭老头1| 欧美一区二区福利视频| 亚洲成人激情社区| 日本高清成人免费播放| 中文字幕国产一区| 国产成人av自拍| 337p日本欧洲亚洲大胆精品| 日本女人一区二区三区| 欧美无乱码久久久免费午夜一区| 综合色中文字幕| 国产福利一区二区三区| 亚洲精品在线免费观看视频| 免费高清视频精品| 欧美一区二区三区在| 日韩精品1区2区3区| 欧美日韩国产大片| 亚洲午夜影视影院在线观看| 91麻豆精东视频| 亚洲女人的天堂| 91麻豆精品视频| 亚洲乱码国产乱码精品精98午夜 | 日韩国产一区二| 欧美疯狂做受xxxx富婆| 亚洲成人久久影院| 欧美日韩亚洲综合在线 欧美亚洲特黄一级 | 欧美一区二区在线不卡| 日本欧美一区二区三区乱码| 欧美嫩在线观看| 日韩成人精品视频| 日韩午夜激情视频| 韩国一区二区视频| 久久日韩粉嫩一区二区三区| 国内精品国产成人国产三级粉色| 日韩欧美亚洲国产精品字幕久久久| 日韩avvvv在线播放| 日韩视频免费观看高清在线视频| 久久91精品国产91久久小草| 久久中文字幕电影| 粉嫩久久99精品久久久久久夜| 国产日韩精品久久久| fc2成人免费人成在线观看播放 | 亚洲6080在线| 91麻豆精品国产91久久久久久久久 | 国产精品黄色在线观看| 色哦色哦哦色天天综合| 亚洲一区二区不卡免费| 欧美一区二区三区四区久久| 国产在线精品一区二区| 1区2区3区精品视频| 欧美三级中文字幕| 精品午夜久久福利影院| 国产精品久久久久久久久果冻传媒|