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

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

?? huidubianhuandib.cpp

?? 灰度變換的實(shí)例程序
?? CPP
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
#include "stdafx.h"
#include "windowsx.h"
#include "math.h"
#include "HuiDuBianHuanDib.h"
#include "MainFrm.h"
#include "DynSplitView2.h"
 
HuiDuBianHuanDib::HuiDuBianHuanDib()
{
}
HuiDuBianHuanDib::~HuiDuBianHuanDib()
{
}

///***************************************************************/           
/*函數(shù)名稱:FanSeBianHuan()                                        
/*函數(shù)類型:void                                           
/*功能:對(duì)圖像進(jìn)行反色變換                            
/***************************************************************/
void HuiDuBianHuanDib::FanSeBianHuan()//對(duì)圖像進(jìn)行反色變換
{
	LPBYTE  p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長(zhǎng)、寬
	p_data=this->GetData ();     //取得原圖的數(shù)據(jù)區(qū)指針
	if(m_pBitmapInfoHeader->biBitCount<9)		
		wide=this->GetWidth ();
	else
		wide=this->GetDibWidthBytes();
	height=this->GetHeight ();
	for(int i=0;i<height*wide;i++)
	{
		unsigned char  temp;
		temp=*(p_data+i);
		*(p_data+i)=255- temp;
	}	
}

///***************************************************************/           
/*函數(shù)名稱:Fei0()												*/
/*函數(shù)類型:void												*/
/*功能:對(duì)圖像進(jìn)行非零取一運(yùn)算。								*/
/****************************************************************/
void HuiDuBianHuanDib::Fei0()//對(duì)圖像進(jìn)行非零取一運(yùn)算
{
	LPBYTE p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長(zhǎng)、寬
	p_data=this->GetData ();     //取得原圖的數(shù)據(jù)區(qū)指針
	if(m_pBitmapInfoHeader->biBitCount<9)		
		wide=this->GetWidth ();
	else
		wide=this->GetDibWidthBytes();
	height=this->GetHeight ();
	for(int j=0;j<height;j++)
	{
		for(int i=0;i<wide;i++)    //所有像素依次循環(huán)
		{
			if(*p_data!=0)          //若像素值不為0
				*p_data=255;         //將其置為255
			p_data++; 				 
		}
	}
}

/***************************************************************/           
/*函數(shù)名稱:GuDing(int YuZhi)                                  */      
/*函數(shù)類型:void											   */	
/*參數(shù)說(shuō)明:YuZhi 給定閾值                                     */       
/*功能:對(duì)圖像進(jìn)行固定閥值運(yùn)算。                               */
/***************************************************************/
void HuiDuBianHuanDib::GuDing(int YuZhi)//對(duì)圖像進(jìn)行固定閥值運(yùn)算
{
	LPBYTE  p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長(zhǎng)、寬
	p_data=this->GetData ();     //取得原圖的數(shù)據(jù)區(qū)指針
	if(m_pBitmapInfoHeader->biBitCount<9)		
		wide=this->GetWidth ();
	else
		wide=this->GetDibWidthBytes();
	height=this->GetHeight ();
	for(int j=0;j<height;j++)
	{
		for(int i=0;i<wide;i++)
		{
			if(*p_data>YuZhi)          //灰度值大于給定閾值,置為255
				*p_data=255;
			else
				*p_data=0;             //不大于置為0
			p_data++;
		}
	}
}

/***************************************************************/           
/*函數(shù)名稱:ShuangYu(int YuZhi1,int YuZhi2,int mode)          */
/*參數(shù):int YuZhi1:閾值1;int YuZhi2:閾值2;int mode:處理方式*/
/*函數(shù)類型:void                                              */
/*功能:對(duì)圖像使用雙固定閾值法進(jìn)行二值化。                     */
/***************************************************************/
void HuiDuBianHuanDib::ShuangYu(int YuZhi1,int YuZhi2,int mode)
{
	LPBYTE  p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長(zhǎng)、寬
	p_data=this->GetData ();
	if(m_pBitmapInfoHeader->biBitCount<9)		
		wide=this->GetWidth ();
	else
		wide=this->GetDibWidthBytes();
	height=this->GetHeight ();
	if(mode==0)    //0-255-0型
	{
		for(int j=0;j<height;j++)
			for(int i=0;i<wide;i++)
			{
				//若該像素的灰度值介于兩個(gè)閾值之間,這將其置為255
				if(*p_data>=YuZhi1&&*p_data<=YuZhi2)
					*p_data=255;
				else
					*p_data=0;     //否則置0
				p_data++; 			 		
			}	
	}
	if(mode==1)    //255-0-255型
	{
		for(int j=0;j<height;j++)
			for(int i=0;i<wide;i++)
			{
				//若該像素的灰度值介于兩個(gè)閾值之間,這將其置為0
				if(*p_data>=YuZhi1&&*p_data<=YuZhi2)
					*p_data=0;
				else
					*p_data=255;    //否則置255
				p_data++; 					
			}
	}			 
}

///***************************************************************/           
/*函數(shù)名稱:ZhiFangTu(float *tongji)                               
/*函數(shù)類型:void                                         
/*變量說(shuō)明:tongji  灰度分布密度統(tǒng)計(jì)                                                        
/*功能:對(duì)圖像進(jìn)行灰度直方圖統(tǒng)計(jì)。                     
/***************************************************************/
void HuiDuBianHuanDib::ZhiFangTu(float *tongji)
{
	// 循環(huán)變量
	int i;
	int j;
	// 灰度計(jì)數(shù)
	int huidu[256];    
	int wide,height;    //原圖長(zhǎng)、寬
	wide=this->GetWidth ();		 
	height=this->GetHeight ();
	// 變量初始化
	memset(huidu,0,sizeof(huidu));
	LPBYTE  temp1=new BYTE[wide*height];    //新圖像緩沖區(qū)
	//拷貝原圖像到緩存圖像
	memcpy(temp1,m_pData,wide*height );
	// 對(duì)各像素進(jìn)行灰度統(tǒng)計(jì)
	for (j = 0; j < height; j ++)
	{
		for (i = 0; i <wide; i ++)
		{
			unsigned char  temp = temp1[wide* j + i] ;
			// 灰度統(tǒng)計(jì)計(jì)數(shù)
			huidu[temp]++;
		}
	}
	// 計(jì)算灰度分布密度
	for(i=0;i<256;i++)
		tongji[i] = huidu[i] / (height * wide *1.0f);	
}

///***************************************************************/           
/*函數(shù)名稱:Zhexianbianhuan(BYTE bX1,BYTE bY1,BYTE bX2,BYTE bY2)                                           */
/*函數(shù)類型:void                                              */
/*變量說(shuō)明:bX1折點(diǎn)一的原始灰度;bX2bY1折點(diǎn)二的原始灰度
/*          bY1折點(diǎn)一的變換灰度;bY2折點(diǎn)二的變換灰度                                                       
/*功能:對(duì)圖像進(jìn)行分段線性變換。                      */
/***************************************************************/ 
void HuiDuBianHuanDib::Zhexianbianhuan(BYTE bX1, BYTE bY1, BYTE bX2, BYTE bY2)
{ 
	// 循環(huán)變量
	int i;
	int j;
	int wide;
	int height;
	LPBYTE  p_data;
	p_data=this->GetData ();     //取得原圖的數(shù)據(jù)區(qū)指針
	wide=this->GetWidth ();
	height=this->GetHeight ();
	LPBYTE temp=new BYTE[wide*height];    //新圖像緩沖區(qū)
	//拷貝原圖像到緩存圖像
	memcpy(temp,p_data,wide*height);
	// 灰度映射表
	BYTE	bMap[256];
	// 計(jì)算灰度映射表
	for (i = 0; i <= bX1; i++)	//[0 —— X1]
	{
		// 判斷bX1是否大于0(防止分母為0)
		if (bX1 > 0)
		{
			// 線性變換
			bMap[i] = (BYTE) bY1 * i / bX1;
		}
		else
		{
			// 直接賦值為0
			bMap[i] = 0;
		}
	}
	for (; i <= bX2; i++)		//(X1 —— X2]
	{
		// 判斷bX1是否等于bX2(防止分母為0)
		if (bX2 != bX1)
		{
			// 線性變換
			bMap[i] = bY1 + (BYTE) ((bY2 - bY1) * (i - bX1) / (bX2 - bX1));
		}
		else
		{
			// 直接賦值為bY1
			bMap[i] = bY1;
		}
	}
	for (; i < 256; i++)		//(X2 —— 256)
	{
		// 判斷bX2是否等于255(防止分母為0)
		if (bX2 != 255)
		{
			// 線性變換
			bMap[i] = bY2 + (BYTE) ((255 - bY2) * (i - bX2) / (255 - bX2));
		}
		else
		{
			// 直接賦值為255
			bMap[i] = 255;
		}
	}
	if  (m_pBitmapInfoHeader->biBitCount<9)		//灰度圖像
	{
		// 對(duì)各像素進(jìn)行灰度轉(zhuǎn)換
		for (i = 0; i < height; i ++)
		{
			for (j = 0; j < wide; j ++)
			{
				// 對(duì)像素進(jìn)行灰度映射處理
				unsigned char T = temp[ wide * i + j];
				temp[ wide * i + j] = bMap[T];			 
			}
		}
        memcpy(p_data, temp,height*wide); 
	}
	else		//24位彩色
	{
		wide=this->GetDibWidthBytes();
		temp=new BYTE[wide*height]; 
		memcpy(temp,p_data,wide*height);
		// 對(duì)各像素進(jìn)行灰度轉(zhuǎn)換
		for (i = 0; i < height; i ++)
		{
			for (j = 0; j < wide; j ++)
			{
				// 對(duì)像素進(jìn)行灰度映射處理
				unsigned char T = temp[ wide * i + j];
				temp[ wide * i + j] = bMap[T];			 
			}
		}
		memcpy(p_data, temp,height*wide);
	}
}

///***************************************************************/           
/*函數(shù)名稱:Chuangkoubianhuan(BYTE blow,BYTE bup)                                      
/*函數(shù)類型:void                                          
/*變量說(shuō)明:blow窗口下界 bup窗口上界                                                               
/*功能:對(duì)圖像進(jìn)行窗口變換。                    
/***************************************************************/  
void HuiDuBianHuanDib::Chuangkoubianhuan(BYTE bLow, BYTE bUp)
{
    // 循環(huán)變量
	int i;
	int j;
	int wide,height;    //原圖長(zhǎng)、寬
	// 指向源圖像的指針
	LPBYTE	lpSrc;
	// 指向DIB象素指針
	LPBYTE  p_data;
	p_data=this->GetData ();     //取得原圖的數(shù)據(jù)區(qū)指針
	if (m_pBitmapInfoHeader->biBitCount<9)		
		wide=this->GetWidth ();
	else
		wide=this->GetDibWidthBytes();
	height=this->GetHeight ();
	// 對(duì)各像素進(jìn)行灰度轉(zhuǎn)換
	for(i = 0; i < height; i++)
	{
		// 每列
		for(j = 0; j < wide; j++)
		{
			// 指向DIB第i行,第j個(gè)象素的指針
			lpSrc = (LPBYTE)p_data + wide * (height- 1 - i) + j;
			// 判斷是否超出范圍
			if ((*lpSrc) < bLow)
			{
				// 直接賦值為0
				*lpSrc = 0;
			}
			else if ((*lpSrc) > bUp)
			{
				// 直接賦值為255
				*lpSrc = 255;
			}
		}
	}
}

///***************************************************************/           
/*函數(shù)名稱:Fenbujunhenghua()                                           
/*函數(shù)類型:void                                          
/*變量說(shuō)明:無(wú)                                                               
/*功能:對(duì)圖像進(jìn)行灰度分布均衡化處理。                   
/***************************************************************/  
void HuiDuBianHuanDib::Fenbujunhenghua( )
{	
	// 循環(huán)變量
	LONG i;
	LONG j;
	//圖像的寬和高
	LONG wide;
	LONG height;
	// 灰度分布密度
	float fPs_R[256],fPs_G[256],fPs_B[256];
	// 中間變量
	float temp_r[256],temp_g[256],temp_b[256];
	int nNs_R[256],nNs_G[256],nNs_B[256];
	// 初始化
	memset(temp_r, 0, sizeof(temp_r));
	memset(temp_g, 0, sizeof(temp_g));
	memset(temp_b, 0, sizeof(temp_b));
	// 指向DIB象素指針
	LPBYTE p_data;
	// 找到DIB圖像象素起始位置
	p_data = this->GetData();
	wide=this->GetWidth ();	
	// DIB的高度
	height = GetHeight();
	if(m_pBitmapInfoHeader->biBitCount<9)		//灰度圖像
	{
		// 獲取圖像的灰度分布密度
		ZhiFangTu(fPs_R);
		// 進(jìn)行均衡化處理 
		for(i = 0; i < 256; i++)
		{
			if(i == 0)
			{
				temp_r[0] = fPs_R[0];	 
			}
			else
			{
				temp_r[i] = temp_r[i-1] + fPs_R[i];	 
			}
			nNs_R[i] = (int)(255.0f * temp_r[i] + 0.5f);
		}
	}
	else		//24位彩色
	{
		// 獲取圖像的灰度分布密度
		ZhiFangTu(fPs_R,fPs_G,fPs_B);
		// 進(jìn)行均衡化處理 
		for(i = 0; i < 256; i++)
		{
			if(i == 0)
			{
				temp_r[0] = fPs_R[0];
				temp_g[0] = fPs_G[0];
				temp_b[0] = fPs_B[0];
			}
			else
			{
				temp_r[i] = temp_r[i-1] + fPs_R[i];	
				temp_g[i] = temp_g[i-1] + fPs_G[i];	
				temp_b[i] = temp_b[i-1] + fPs_B[i];	
			}
			nNs_R[i] = (int)(255.0f * temp_r[i] + 0.5f);
			nNs_G[i] = (int)(255.0f * temp_g[i] + 0.5f);
			nNs_B[i] = (int)(255.0f * temp_b[i] + 0.5f);
		}
	}
	if (m_pBitmapInfoHeader->biBitCount<9)		//灰度圖像
	{ 
		// 對(duì)各像素進(jìn)行灰度轉(zhuǎn)換
		for (j = 0; j < height; j ++)
		{
			for (i = 0; i < wide; i ++)
			{
				// 將轉(zhuǎn)換后的灰度分布寫(xiě)入DIB圖像
				unsigned char temp = *((unsigned char *)p_data + wide * j + i);
				*((unsigned char *)p_data + wide * j + i) = nNs_R[temp];			
			}
		}
	}
	else		//24位彩色
	{
		// 對(duì)各像素進(jìn)行灰度轉(zhuǎn)換
		for (j = 0; j < height; j ++)
		{
			for (i = 0; i < wide; i ++)
			{
				// 將轉(zhuǎn)換后的灰度分布寫(xiě)入DIB圖像
				unsigned char temp1= *((unsigned char *)p_data + wide * j*3 + i*3);
				*((unsigned char *)p_data + wide * j*3 + i*3) = nNs_R[temp1];
				unsigned char temp2 = *((unsigned char *)p_data + wide * j*3 + i*3+1);
				*((unsigned char *)p_data + wide * j*3 + i*3+1) = nNs_G[temp2];	
				unsigned char temp3 = *((unsigned char *)p_data + wide * j*3 + i*3+2);
				*((unsigned char *)p_data + wide * j*3 + i*3+2) = nNs_B[temp3];	
			}
		}
	}
}

int HuiDuBianHuanDib::GetWidth()
{
	return CDib::GetWidth();
}

///***************************************************************/           
/*函數(shù)名稱:Pipeibianhuan(BYTE bNum,int *npNu,float*fpPu)                                            */
/*函數(shù)類型:void                                              */
/*變量說(shuō)明:bNum規(guī)定直方圖灰度級(jí) npNu 直方圖映射關(guān)系
/*          fpPu灰度分布概率                                                             
/*功能:對(duì)圖像進(jìn)行灰度匹配變換。                       */
/***************************************************************/  
void HuiDuBianHuanDib::Pipeibianhuan(BYTE bNum, int *npNu, float *fpPu)
{
	// 循環(huán)變量
	LONG i;
	LONG j;
    LONG wide;
	LONG height;
	// 灰度分布密度
	int midu[256],midu2[256],midu3[256];
	// 灰度分布概率
	float gailu[256],gailu2[256],gailu3[256];
	// 中間臨時(shí)變量
	float temp[256],temp2[256],temp3[256];
	// 指向DIB象素指針
	LPBYTE p_data;
	// 找到DIB圖像象素起始位置
	p_data = this->GetData();
	wide=this->GetWidth ();    
	// DIB的高度
	height = GetHeight(); 	
    if (m_pBitmapInfoHeader->biBitCount<9)		//灰度圖像
	{   
		// 對(duì)灰度密度分布進(jìn)行統(tǒng)計(jì)	
		Midufenbu(midu);
		// 對(duì)灰度分布概率進(jìn)行統(tǒng)計(jì)
		ZhiFangTu(gailu);
		
		// 計(jì)算原始累計(jì)直方圖
		for (i = 0; i < 256; i++)
		{
			if (i == 0)
			{
				temp[0] = gailu[0];			 
			}
			else
			{
				temp[i] = temp[i-1] + gailu[i];			 

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜精品成人在线视频| 国产精品99久久久久久久vr| 2023国产精品| 欧美在线视频全部完| 国产成人午夜电影网| 五月婷婷久久综合| 日韩毛片视频在线看| 久久亚洲综合色| 欧美视频第二页| www.欧美日韩| 国产黄色精品网站| 麻豆精品视频在线观看免费| 亚洲精品中文字幕乱码三区| 亚洲国产精品精华液2区45| 欧美一二三区在线观看| 欧美影视一区二区三区| av一区二区不卡| 国产乱妇无码大片在线观看| 麻豆精品新av中文字幕| 天堂午夜影视日韩欧美一区二区| 日韩理论片中文av| 国产精品美女久久久久久久网站| 精品国产凹凸成av人网站| 欧美日韩成人激情| 在线观看av一区二区| 91最新地址在线播放| 国产成人精品综合在线观看| 国产一区二区三区最好精华液 | 一区二区三区91| 国产精品欧美综合在线| 欧美精品一区二区三区在线| 日韩欧美精品在线| 欧美一级理论片| 日韩一区二区三| 欧美一级国产精品| 一区二区在线观看免费| 国产精品亲子乱子伦xxxx裸| 国产精品拍天天在线| 国产精品久久久久久户外露出| 国产欧美一二三区| 中文在线一区二区| 国产精品国产三级国产| 中文字幕日韩一区| 亚洲激情图片一区| 亚洲成a人片在线观看中文| 亚洲成a人片在线观看中文| 午夜久久久久久久久久一区二区| 亚洲福利视频导航| 日本不卡的三区四区五区| 日本美女一区二区三区| 久久精品国产99久久6| 国产精品综合一区二区| 丰满亚洲少妇av| 高清视频一区二区| www..com久久爱| 色94色欧美sute亚洲线路二| 欧美日本韩国一区| 精品国产欧美一区二区| 亚洲国产精品成人综合| 国产精品激情偷乱一区二区∴| 亚洲欧美综合在线精品| 亚洲国产一区二区视频| 日本午夜精品视频在线观看| 国内精品视频666| 成人黄色在线看| 在线欧美日韩精品| 欧美一区二区在线看| 久久―日本道色综合久久 | 日韩电影在线观看电影| 韩国女主播一区| 99久久精品国产观看| 欧美体内she精视频| 精品黑人一区二区三区久久| 国产精品每日更新在线播放网址| 亚洲午夜影视影院在线观看| 精品午夜一区二区三区在线观看| 成人深夜福利app| 欧美日韩五月天| 国产三级一区二区三区| 亚洲男人天堂av| 久久国产综合精品| 99v久久综合狠狠综合久久| 91精品欧美综合在线观看最新 | 99久久99久久精品国产片果冻| 在线一区二区三区四区| 精品国产一区二区精华| 亚洲精品福利视频网站| 国产一区二区三区视频在线播放| 91福利精品第一导航| 久久综合中文字幕| 亚洲一二三四在线观看| 国产精品主播直播| 在线成人高清不卡| 久久久国产精华| 五月天激情综合网| www.亚洲在线| 精品少妇一区二区三区在线播放 | 日韩制服丝袜av| k8久久久一区二区三区| 日韩一区二区在线看| 亚洲人妖av一区二区| 国内精品写真在线观看| 欧美日韩一区成人| 国产精品毛片高清在线完整版 | 国产精品一区二区三区四区| 精品视频1区2区| 中文字幕在线一区免费| 国产剧情av麻豆香蕉精品| 欧美猛男男办公室激情| 136国产福利精品导航| 国产一区二区福利| 日韩一区二区在线观看| 亚洲一区二区视频| 91在线视频官网| 欧美国产欧美亚州国产日韩mv天天看完整 | 91久久线看在观草草青青| 久久久久久亚洲综合影院红桃| 日韩国产精品久久| 欧美日精品一区视频| 日韩理论片在线| 26uuu国产一区二区三区 | 成人ar影院免费观看视频| 精品黑人一区二区三区久久| 日韩国产欧美三级| 欧美日韩黄色一区二区| 一区二区成人在线视频| 色香色香欲天天天影视综合网| 国产精品伦一区| 成人美女视频在线看| 中文字幕免费观看一区| 国产成人丝袜美腿| 国产精品视频九色porn| 成人爽a毛片一区二区免费| 欧美激情一区二区在线| 懂色av一区二区三区免费看| 国产亚洲综合色| 国产iv一区二区三区| 国产精品视频麻豆| 不卡区在线中文字幕| 亚洲三级电影网站| 在线观看91视频| 婷婷国产v国产偷v亚洲高清| 91精品国产综合久久福利| 秋霞影院一区二区| 日韩精品一区在线观看| 国产一区二区三区蝌蚪| 国产婷婷色一区二区三区四区 | 中文字幕在线不卡一区| 色综合久久天天综合网| 亚洲二区在线视频| 欧美日韩mp4| 久久91精品国产91久久小草| 久久亚洲精品国产精品紫薇| 成人av电影在线播放| 亚洲精品国产a| 欧美日韩国产中文| 久久99蜜桃精品| 欧美激情资源网| 91麻豆精品一区二区三区| 亚洲最大成人网4388xx| 欧美精品 国产精品| 国产一区二区看久久| 日韩码欧中文字| 欧美一区二区三区影视| 欧美一区二区三区日韩| 极品少妇xxxx精品少妇| 国产精品美女久久久久久久久久久 | 日韩精品一区二区三区中文精品| 国产成a人无v码亚洲福利| 亚洲激情网站免费观看| 日韩精品中午字幕| 成人精品gif动图一区| 亚洲第一福利视频在线| 久久先锋影音av| 91热门视频在线观看| 蜜臀精品一区二区三区在线观看| 亚洲国产成人在线| 欧美浪妇xxxx高跟鞋交| 国产一区二区按摩在线观看| 一区二区三区.www| 久久精品人人做人人综合| 欧美伊人精品成人久久综合97| 经典一区二区三区| 亚洲最快最全在线视频| 久久免费美女视频| 欧美日韩在线播放三区| 国产乱码一区二区三区| 亚洲综合色区另类av| 久久久久久麻豆| 欧美男同性恋视频网站| 国产ts人妖一区二区| 日韩国产欧美在线播放| 亚洲欧洲美洲综合色网| 日韩欧美国产1| 欧美在线视频你懂得| 丁香六月综合激情| 六月丁香综合在线视频| ...av二区三区久久精品| 久久亚洲精品国产精品紫薇| 欧美三区在线观看|