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

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

?? dib.cpp

?? 人臉檢測系統(tǒng)---可以較好的實現(xiàn)人臉定位
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
		}
		GlobalUnlock(hDIB);
		return true;
		}
		else AfxMessageBox("Can't find the corresponding point!");
	GlobalUnlock(hDIB);
	return false;
}
//比較兩張圖片的相似度




BOOL DIB::IsScaterPoint(int x, int y, int width, int height, LPBYTE lpData,WORD wBytesPerLine,  int threshold,bool lab[m_HEIGHT][m_WIDTH])
{
	long lOffset;
	//得到數(shù)據(jù)的偏移
	lOffset = this->PixelOffset(y,x,wBytesPerLine);
	//判斷該點是否為白色以及是否計算過了
	if(*(lpData+lOffset) == 255 && lab[y][x] == false)
	{	
		//鏈長度加一
		this->lenth++;
		//更改標志位
		lab[y][x] = true;
		//如果鏈長度達到臨界值則返回真
	if(this->lenth >= threshold)
		return true;
	//對右邊點的邊界判斷以及標志位判斷
	if(x+1<width && lab[y][x+1] == false)
	{	
		//遞歸調(diào)用本函數(shù),對右邊的點進行判斷
		IsScaterPoint(x+1,y,width,height,lpData,wBytesPerLine,threshold,lab);
		if(this->lenth>=threshold)
			return true;
		
	}
	//處理左邊的點
	if(x-1>=0 && lab[y][x-1] == false)
	{
		(IsScaterPoint(x-1,y,width,height,lpData,wBytesPerLine,threshold,lab));
		if(this->lenth>=threshold)
			return true;
		
	}
	//處理上面的點
	if(y-1>=0 && lab[y-1][x]==false)
	{
		(IsScaterPoint(x,y-1,width,height,lpData,wBytesPerLine,threshold,lab));
		if(this->lenth>=threshold)
			return true;
		
	}
	//處理下面的點
	if(y+1<height && lab[y+1][x]==false)
	{	(IsScaterPoint(x,y+1,width,height,lpData,wBytesPerLine,threshold,lab));
			if(this->lenth>=threshold)
			return true;
			
	}
	//處理右下的點
	if(y+1<height  && x+1 <width && lab[y+1][x+1]==false)
	{	(IsScaterPoint(x+1,y+1,width,height,lpData,wBytesPerLine,threshold,lab));
			if(this->lenth>=threshold)
			return true;
			
	}
	//處理左下的點
	if(y+1<height && x-1 >=0 && lab[y+1][x-1]==false)
	{	(IsScaterPoint(x-1,y+1,width,height,lpData,wBytesPerLine,threshold,lab));
			if(this->lenth>=threshold)
			return true;
			
	}
	//處理左上的點
	if(y-1>=0 && x-1 >=0 &&lab[y-1][x-1]==false)
	{	(IsScaterPoint(x-1,y-1,width,height,lpData,wBytesPerLine,threshold,lab));
			if(this->lenth>=threshold)
			return true;
			
	}
	//處理右上的點
	if(y-1<height && x+1<width && lab[y+1][x]==false)
	{	(IsScaterPoint(x+1,y-1,width,height,lpData,wBytesPerLine,threshold,lab));
			if(this->lenth>=threshold)
			return true;
			
	}
	}	
		//如果遞歸結(jié)束,長度達不到臨界值,返回假
		return false;
}



BOOL DIB::LightingCompensate(HANDLE hDIB)
{
	if(!hDIB)
		return FALSE;
	LPBITMAPINFOHEADER lpbi;
	int width,height;
	LPBYTE lpData;
	WORD wBytesPerLine;
	lpbi = (LPBITMAPINFOHEADER)GlobalLock(hDIB);
	//得到圖片寬和高
	width = lpbi->biWidth;
	height = lpbi->biHeight;
	//得到圖片數(shù)據(jù)區(qū)
	lpData = this->FindDIBBits(hDIB);
	//得到圖片每行的象素所占字節(jié)個數(shù)
	wBytesPerLine = this->BytePerLine(hDIB);
	//比例系數(shù)
	const float thresholdco = 0.05;
	//象素個數(shù)的臨界常數(shù)
	const int thresholdnum = 100;
	//灰度級數(shù)組
	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++)
		{	
			//得到象素數(shù)據(jù)的偏移
			lOffset = this->PixelOffset(i,j,wBytesPerLine);
			//得到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;
		//下面的循環(huán)得到滿足系數(shù)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;
		//得到光線補償?shù)南禂?shù)
		float co = 255.0/(float)averagegray;
		//下面的循環(huán)對圖象進行光線補償
		for(i =0;i<height;i++)
			for(int j=0;j<width;j++)
			{	
				//得到數(shù)據(jù)便宜
				lOffset = this->PixelOffset(i,j,wBytesPerLine);
				//得到藍色分量
				colorb = *(lpData+lOffset);
				//調(diào)整
				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;
}

BOOL DIB::FaceModeling(int Cr,int Cb)
{	
	//Cb的系數(shù)常量
	const float cx = 114.38;
	//cr的系數(shù)常量
	const float cy = 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軸數(shù)值
	float  x = cos(theta)*(Cb-cx)+sin(theta)*(Cr-cy);
	//y軸數(shù)值
	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;

}

LPBYTE DIB::YcctoRgb(LPBYTE lpYcc,WORD wBytesPerLine,int height,int width)
{
	LPBYTE lpRGB;
	//申請內(nèi)存
	lpRGB = new BYTE[wBytesPerLine*height];
	//檢查內(nèi)容分配
	if(lpRGB == NULL)
	{
		AfxMessageBox("not enought memory");
		return NULL;
	}
	long lOffset;
	//下面的循環(huán)實現(xiàn)從ycc到rgb的轉(zhuǎn)換
	for(int i=0;i<height;i++)
		for(int j=0;j<width;j++)
		{	
			//得到數(shù)據(jù)便宜
			lOffset = PixelOffset(i,j,wBytesPerLine);
			//得到y(tǒng),Cr,Cb的數(shù)值
			int Y = *(lpYcc+lOffset);
			int Cr = *(lpYcc+lOffset+1);
			int Cb = *(lpYcc+lOffset+2);
			//利用公式進行計算,并把結(jié)果保存到動態(tài)數(shù)組里面
			*(lpRGB+lOffset+2) = (1164*(Y-16)+1596*(Cr-128))/1000;
			*(lpRGB+lOffset+1) = (1164*(Y-16) - 813*(Cr-128) - 392*(Cb-128))/1000;
			*(lpRGB+lOffset)   = (1164*(Y-16) +2017*(Cb-128))/1000;
		}
	return lpRGB;
}


int DIB::_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 DIB::_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 DIB::_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 DIB:: _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 DIB::YccTransform(LPBYTE lpYcc,WORD wBytesPerLine,int height,int width)
{	
	int Y,Cr,Cb;
	long lOffset;
	//下面的循環(huán)實現(xiàn)ycc色彩空間的非線性轉(zhuǎn)換
	for(int i=0;i<height;i++)
		for(int j=0;j<width;j++)
		{	
			//得到數(shù)據(jù)偏移
			lOffset = PixelOffset(i,j,wBytesPerLine);
			//得到y(tǒng),Cr,Cb數(shù)值
			Y = *(lpYcc+lOffset);
			Cr = *(lpYcc+lOffset+1);
			Cb = *(lpYcc+lOffset+2);
			//如果y數(shù)值在兩個臨界值之間,保持不變
			if(Y>=Kl && Y<=Kh)
				continue;
			//調(diào)用非線性轉(zhuǎn)換函數(shù)調(diào)整Cr,Cb的數(shù)值
			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 DIB::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 = PixelOffset(i,j,wBytesPerLine);
			//得到Cr,Cb數(shù)值
			Cr = *(lpYcc+lOffset+1);
			Cb = *(lpYcc+lOffset+2);
			//人臉顏色建模
			if(FaceModeling(Cr,Cb))
			{	
				//修改標志位
				flag[i][j] = true;
			}
		}
	
}

void  DIB::FaceLocate(HANDLE hDIB, CRect faceLocation[10], int &faceNum)
{	

	HANDLE hDIBTemp;
	//保存當前數(shù)據(jù)
	hDIBTemp = this->CopyHandle(hDIB);
	LPBITMAPINFOHEADER lpbi;
	LPBYTE lpData;
	WORD wBytesPerLine;
	int height;
	int width;
	long lOffset;
	//得到圖象的基本信息
	lpbi = (LPBITMAPINFOHEADER)GlobalLock(hDIB);
	height = lpbi->biHeight;
	width  = lpbi->biWidth;
	lpData = FindDIBBits(hDIB);
	wBytesPerLine = BytePerLine(hDIB);

	//人臉數(shù)目初始化為0
	faceNum =0;
	for(int k=0; k<10; k++)
	{	
		//初始化區(qū)域
		faceLocation[k].bottom = -1;
		faceLocation[k].top = height;
		faceLocation[k].right = -1;
		faceLocation[k].left = width;
	}

	for(int i=0; i<height; i++)
		for (int j=0; j<width; j++)
		{	
			//偏移
			lOffset = PixelOffset(i,j,wBytesPerLine);
			int num;
			//當前點的數(shù)值
			num = *(lpData + lOffset);
			if (num !=0)//不是黑色
			{	
				//遞歸計算
				RecursiveLocateRect(lpData, wBytesPerLine, i, j, num, faceLocation[faceNum]);
				faceNum++;
			}
		}
	GlobalUnlock(hDIB);
	GlobalFree(hDIB);
	//數(shù)值還原
	hDIB = this->CopyHandle(hDIBTemp);
	lpData = FindDIBBits(hDIB);
	wBytesPerLine = BytePerLine(hDIB);
	for (i=0; i<faceNum; i++)
		for (int j=faceLocation[i].top; j<faceLocation[i].bottom; j++)
		{	
			//把得到的人臉區(qū)域用綠色矩形標注,處理豎直的兩條邊
			lOffset = this->PixelOffset(j, faceLocation[i].left, wBytesPerLine);
			*(lpData + lOffset++) = 0;
			*(lpData + lOffset++) = 255;
			*(lpData + lOffset++) = 0;
			lOffset = this->PixelOffset(j, faceLocation[i].right, wBytesPerLine);
			*(lpData + lOffset++) = 0;
			*(lpData + lOffset++) = 255;
			*(lpData + lOffset++) = 0;

		}

		for (i=0; i<faceNum; i++)
		for (int j=faceLocation[i].left; j<faceLocation[i].right; j++)
		{	
			//處理水平的兩天矩形邊
			lOffset = this->PixelOffset(faceLocation[i].top, j, wBytesPerLine);
			*(lpData + lOffset++) = 0;
			*(lpData + lOffset++) = 255;
			*(lpData + lOffset++) = 0;
			lOffset = this->PixelOffset(faceLocation[i].bottom, j, wBytesPerLine);
			*(lpData + lOffset++) = 0;
			*(lpData + lOffset++) = 255;
			*(lpData + lOffset++) = 0;

		}
	
		
	
	GlobalFree(hDIBTemp);	
	GlobalUnlock(hDIB);
}

void DIB::RecursiveLocateRect(LPBYTE lpData,WORD wBytesPerLine, int y, int x, int num, CRect &faceRect)
{	
	long lOffset;
	//得到偏移
	lOffset = PixelOffset(y,x,wBytesPerLine);
	//數(shù)值判斷
	if(*(lpData + lOffset) == num)
	{	
		//更改顏色為黑色
		*(lpData + lOffset++) = 0;
		*(lpData + lOffset++) = 0;
		*(lpData + lOffset++) = 0;
		//修改矩形的上下左右四個點位置
		if(faceRect.bottom < y)
		{
			faceRect.bottom = y;
		}

		if(faceRect.top > y)
		{
			faceRect.top = y;
		}

		if(faceRect.right < x)
		{
			faceRect.right = x;
		}

		if(faceRect.left > x)
		{
			faceRect.left = x;
		}
		//上下左右調(diào)用本函數(shù)進行區(qū)域判定
		RecursiveLocateRect(lpData, wBytesPerLine, y-1, x, num,faceRect);
		RecursiveLocateRect(lpData, wBytesPerLine, y+1, x, num, faceRect);
		RecursiveLocateRect(lpData, wBytesPerLine, y, x-1, num, faceRect);
		RecursiveLocateRect(lpData, wBytesPerLine, y, x+1, num, faceRect);
	}
	
}

void DIB::EyeMapC(LPBYTE lpRgb, const LPBYTE lpYcc,  WORD wBytesPerLine, CRect faceLocation)
{
	long lOffset;
	int cr;
	int cb;
	//根據(jù)傳進來的矩形區(qū)域進行眼睛的色度匹配
	for(int i=faceLocation.top; i<=faceLocation.bottom; i++)
		for (int j=faceLocation.left; j<=faceLocation.right; j++)
		{	
			//得到Cr,Cb數(shù)值
			lOffset = PixelOffset(i, j, wBytesPerLine);
			cr = *(lpYcc + lOffset +1);
			cb = *(lpYcc + lOffset +2);
			//標志
			bool lab;
			//判斷Cb分量的數(shù)值,并修改標志
			int cmap = cb -116 ;
			if(cmap >-1 && cmap <4)
				lab = true;
			else
				lab = false;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线欧美日韩精品| 欧美视频在线一区| 午夜精品久久久久| 国产偷v国产偷v亚洲高清 | 91在线观看视频| 美女视频一区二区三区| 亚洲伦理在线精品| 国产日韩欧美制服另类| 911精品国产一区二区在线| 成人午夜视频在线观看| 青青草原综合久久大伊人精品 | 成人ar影院免费观看视频| 午夜精品久久久久久不卡8050| 中文字幕免费观看一区| 91精品国产综合久久蜜臀| 91丨porny丨国产入口| 国产精品888| 免费视频最近日韩| 亚洲午夜影视影院在线观看| 国产精品国产三级国产a | 91精品国产综合久久精品性色| 99久久国产免费看| 国产精品乡下勾搭老头1| 美女一区二区三区在线观看| 亚洲bt欧美bt精品777| 亚洲精品欧美二区三区中文字幕| 国产日韩欧美制服另类| 久久综合狠狠综合久久激情| 日韩一区二区电影在线| 欧美日韩在线直播| 在线观看三级视频欧美| 91丨九色丨黑人外教| 成人精品鲁一区一区二区| 国产精品996| 国产美女娇喘av呻吟久久| 激情久久五月天| 麻豆国产精品一区二区三区| 日韩不卡手机在线v区| 亚洲综合另类小说| 亚洲国产乱码最新视频 | 欧美岛国在线观看| 日韩欧美国产一区二区三区| 欧美精品99久久久**| 欧美日韩精品一区二区三区蜜桃| 在线观看91视频| 在线观看不卡一区| 欧美日韩www| 日韩精品一区二区三区中文不卡| 欧美精品日韩综合在线| 在线不卡一区二区| 欧美一区二区在线视频| 日韩欧美国产小视频| 久久久久国产精品厨房| 中文字幕不卡三区| 国产精品久久久久aaaa| 亚洲男女一区二区三区| 亚洲综合免费观看高清完整版| 亚洲国产视频在线| 奇米影视一区二区三区小说| 美女www一区二区| 国产精品一区二区久久精品爱涩 | eeuss国产一区二区三区| 99精品欧美一区二区三区综合在线| 成人黄色国产精品网站大全在线免费观看| 国产成人精品免费一区二区| www.日韩精品| 欧美视频自拍偷拍| 精品精品国产高清一毛片一天堂| 久久久精品影视| 亚洲精品免费电影| 日韩av中文字幕一区二区三区| 韩国一区二区在线观看| av在线一区二区| 欧美日韩高清影院| 欧美精品一区二区三区四区| 亚洲欧洲精品一区二区精品久久久| 亚洲视频图片小说| 日本不卡一二三区黄网| 粉嫩蜜臀av国产精品网站| 91成人免费在线视频| 日韩免费性生活视频播放| 国产欧美一区二区精品性| 亚洲综合男人的天堂| 久草在线在线精品观看| 成人av网站在线观看| 欧美色图第一页| 久久色.com| 亚洲一区国产视频| 国产真实精品久久二三区| 日本精品免费观看高清观看| 日韩欧美色综合| 亚洲视频每日更新| 久久99在线观看| 91豆麻精品91久久久久久| 精品欧美乱码久久久久久| 国产精品久久久久久久久免费丝袜| 亚洲一区精品在线| 粉嫩嫩av羞羞动漫久久久| 777午夜精品免费视频| 国产精品色婷婷久久58| 日本亚洲一区二区| 色婷婷激情综合| 国产网站一区二区| 蜜臀av性久久久久蜜臀aⅴ四虎| av综合在线播放| 精品国产一区二区三区av性色| 亚洲最大成人综合| 国产成人高清在线| 欧美大片在线观看一区二区| 亚洲精品v日韩精品| 国产精品1区2区3区| 91精品国产综合久久久久久 | 欧美精品777| 日韩理论片中文av| 国产99久久久久久免费看农村| 91精品国产综合久久精品麻豆| 亚洲天堂久久久久久久| 国产一区二区精品久久91| 日韩一区和二区| 亚洲一区二区综合| 91麻豆视频网站| 国产精品乱码人人做人人爱| 国产自产视频一区二区三区| 777午夜精品免费视频| 亚洲综合一区在线| 一本一道久久a久久精品| 国产精品沙发午睡系列990531| 国产在线精品国自产拍免费| 精品少妇一区二区三区在线播放| 日韩高清在线电影| 3d动漫精品啪啪| 五月天国产精品| 欧美日韩亚洲另类| 亚洲一区在线免费观看| 欧美影视一区在线| 一区av在线播放| 色激情天天射综合网| 亚洲免费三区一区二区| 99久久er热在这里只有精品15 | 99国内精品久久| 国产精品成人免费在线| 99国产精品久久久久久久久久| 欧美国产97人人爽人人喊| 国产91精品一区二区麻豆亚洲| 国产亚洲欧美日韩日本| 成人免费视频视频| 中文字幕一区三区| 欧美在线免费观看视频| 天堂成人国产精品一区| 538在线一区二区精品国产| 麻豆精品新av中文字幕| 久久众筹精品私拍模特| 国产suv一区二区三区88区| 日本一区免费视频| 91免费版在线| 亚洲国产精品久久人人爱 | 最新日韩在线视频| 91成人在线精品| 日本午夜精品一区二区三区电影| 日韩视频在线你懂得| 国产一区二区三区观看| 国产精品美女久久久久久久久久久 | 激情六月婷婷综合| 国产精品久线在线观看| 在线观看免费成人| 久久国产视频网| 欧美激情一区二区三区四区| 91天堂素人约啪| 日韩精品国产精品| 久久精品视频网| 91视频你懂的| 亚洲大型综合色站| 制服丝袜在线91| 国产夫妻精品视频| 一区二区三区欧美日韩| 欧美zozo另类异族| 91蝌蚪国产九色| 热久久免费视频| 日本一区二区三区国色天香| 欧美在线一区二区| 久久精品国内一区二区三区| 国产精品久久三| 91精品国产综合久久福利| 国产成人亚洲综合色影视| 亚洲一区二区av电影| 日韩欧美国产成人一区二区| 99精品国产99久久久久久白柏| 男女男精品网站| ...av二区三区久久精品| 日韩免费视频一区| 欧美亚洲综合在线| 国产精品一区三区| 亚洲777理论| 中文字幕精品三区| 日韩一级片网址| 色婷婷av一区二区| 国产精品一区二区三区99| 丝袜国产日韩另类美女| 亚洲婷婷在线视频| 国产色婷婷亚洲99精品小说|