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

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

?? huidubianhuandib.cpp

?? 圖像處理算法相關(guān)VC程序 VC++圖像處理程序設(shè)計配套光盤
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#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                                           
/*功能:對圖像進行反色變換                            
/***************************************************************/
void HuiDuBianHuanDib::FanSeBianHuan()//對圖像進行反色變換
{
	LPBYTE  p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長、寬
	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												*/
/*功能:對圖像進行非零取一運算。								*/
/****************************************************************/
void HuiDuBianHuanDib::Fei0()//對圖像進行非零取一運算
{
	LPBYTE p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長、寬
	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ù)說明:YuZhi 給定閾值                                     */       
/*功能:對圖像進行固定閥值運算。                               */
/***************************************************************/
void HuiDuBianHuanDib::GuDing(int YuZhi)//對圖像進行固定閥值運算
{
	LPBYTE  p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長、寬
	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                                              */
/*功能:對圖像使用雙固定閾值法進行二值化。                     */
/***************************************************************/
void HuiDuBianHuanDib::ShuangYu(int YuZhi1,int YuZhi2,int mode)
{
	LPBYTE  p_data;     //原圖數(shù)據(jù)區(qū)指針
	int wide,height;    //原圖長、寬
	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++)
			{
				//若該像素的灰度值介于兩個閾值之間,這將其置為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++)
			{
				//若該像素的灰度值介于兩個閾值之間,這將其置為0
				if(*p_data>=YuZhi1&&*p_data<=YuZhi2)
					*p_data=0;
				else
					*p_data=255;    //否則置255
				p_data++; 					
			}
	}			 
}

///***************************************************************/           
/*函數(shù)名稱:ZhiFangTu(float *tongji)                               
/*函數(shù)類型:void                                         
/*變量說明:tongji  灰度分布密度統(tǒng)計                                                        
/*功能:對圖像進行灰度直方圖統(tǒng)計。                     
/***************************************************************/
void HuiDuBianHuanDib::ZhiFangTu(float *tongji)
{
	// 循環(huán)變量
	int i;
	int j;
	// 灰度計數(shù)
	int huidu[256];    
	int wide,height;    //原圖長、寬
	wide=this->GetWidth ();		 
	height=this->GetHeight ();
	// 變量初始化
	memset(huidu,0,sizeof(huidu));
	LPBYTE  temp1=new BYTE[wide*height];    //新圖像緩沖區(qū)
	//拷貝原圖像到緩存圖像
	memcpy(temp1,m_pData,wide*height );
	// 對各像素進行灰度統(tǒng)計
	for (j = 0; j < height; j ++)
	{
		for (i = 0; i <wide; i ++)
		{
			unsigned char  temp = temp1[wide* j + i] ;
			// 灰度統(tǒng)計計數(shù)
			huidu[temp]++;
		}
	}
	// 計算灰度分布密度
	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                                              */
/*變量說明:bX1折點一的原始灰度;bX2bY1折點二的原始灰度
/*          bY1折點一的變換灰度;bY2折點二的變換灰度                                                       
/*功能:對圖像進行分段線性變換。                      */
/***************************************************************/ 
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];
	// 計算灰度映射表
	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)		//灰度圖像
	{
		// 對各像素進行灰度轉(zhuǎn)換
		for (i = 0; i < height; i ++)
		{
			for (j = 0; j < wide; j ++)
			{
				// 對像素進行灰度映射處理
				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);
		// 對各像素進行灰度轉(zhuǎn)換
		for (i = 0; i < height; i ++)
		{
			for (j = 0; j < wide; j ++)
			{
				// 對像素進行灰度映射處理
				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                                          
/*變量說明:blow窗口下界 bup窗口上界                                                               
/*功能:對圖像進行窗口變換。                    
/***************************************************************/  
void HuiDuBianHuanDib::Chuangkoubianhuan(BYTE bLow, BYTE bUp)
{
    // 循環(huán)變量
	int i;
	int j;
	int wide,height;    //原圖長、寬
	// 指向源圖像的指針
	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 ();
	// 對各像素進行灰度轉(zhuǎn)換
	for(i = 0; i < height; i++)
	{
		// 每列
		for(j = 0; j < wide; j++)
		{
			// 指向DIB第i行,第j個象素的指針
			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                                          
/*變量說明:無                                                               
/*功能:對圖像進行灰度分布均衡化處理。                   
/***************************************************************/  
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);
		// 進行均衡化處理 
		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);
		// 進行均衡化處理 
		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)		//灰度圖像
	{ 
		// 對各像素進行灰度轉(zhuǎn)換
		for (j = 0; j < height; j ++)
		{
			for (i = 0; i < wide; i ++)
			{
				// 將轉(zhuǎn)換后的灰度分布寫入DIB圖像
				unsigned char temp = *((unsigned char *)p_data + wide * j + i);
				*((unsigned char *)p_data + wide * j + i) = nNs_R[temp];			
			}
		}
	}
	else		//24位彩色
	{
		// 對各像素進行灰度轉(zhuǎn)換
		for (j = 0; j < height; j ++)
		{
			for (i = 0; i < wide; i ++)
			{
				// 將轉(zhuǎn)換后的灰度分布寫入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                                              */
/*變量說明:bNum規(guī)定直方圖灰度級 npNu 直方圖映射關(guān)系
/*          fpPu灰度分布概率                                                             
/*功能:對圖像進行灰度匹配變換。                       */
/***************************************************************/  
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];
	// 中間臨時變量
	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)		//灰度圖像
	{   
		// 對灰度密度分布進行統(tǒng)計	
		Midufenbu(midu);
		// 對灰度分布概率進行統(tǒng)計
		ZhiFangTu(gailu);
		
		// 計算原始累計直方圖
		for (i = 0; i < 256; i++)
		{
			if (i == 0)
			{
				temp[0] = gailu[0];			 
			}
			else
			{
				temp[i] = temp[i-1] + gailu[i];			 

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久国产精品麻豆ai换脸| 日韩欧美国产小视频| 国产福利一区在线| 国产精品自产自拍| 韩国成人精品a∨在线观看| 美日韩一区二区| 国精品**一区二区三区在线蜜桃 | 国产精一区二区三区| 麻豆精品国产传媒mv男同| 美国十次了思思久久精品导航| 久久福利资源站| 高清国产一区二区| www.日韩av| 欧美日韩1区2区| 精品区一区二区| 国产精品国模大尺度视频| 亚洲图片自拍偷拍| 美国十次了思思久久精品导航| 国产成人综合网| av中文字幕不卡| 欧美丰满一区二区免费视频| 国产精品嫩草影院av蜜臀| 中文文精品字幕一区二区| 亚洲日本免费电影| 日韩高清不卡一区二区三区| 精品一区二区三区香蕉蜜桃| 高清国产一区二区| 欧美精品在欧美一区二区少妇| 日韩欧美123| 亚洲欧洲精品天堂一级 | 欧美精品在线一区二区三区| 日韩一级片网站| 成人欧美一区二区三区小说| 日本欧美一区二区在线观看| 国产精品系列在线观看| 欧美日韩中文字幕一区| 久久一留热品黄| 亚洲成av人片在www色猫咪| 国产乱国产乱300精品| 欧美色偷偷大香| 国产精品久久久久影视| 日韩一区精品视频| 一道本成人在线| 久久男人中文字幕资源站| 亚洲成a人v欧美综合天堂| 国产精品1区2区3区在线观看| 欧美无砖专区一中文字| 国产精品区一区二区三| 日本va欧美va精品| 欧美私模裸体表演在线观看| 中文字幕va一区二区三区| 亚洲一区二区偷拍精品| www亚洲一区| 91精品国产综合久久精品麻豆| 麻豆成人久久精品二区三区红| 成人激情动漫在线观看| 欧美日本高清视频在线观看| 18成人在线观看| 成人午夜av影视| 久久综合久久综合亚洲| 免费成人av资源网| 欧美一卡二卡在线| 亚洲成人av中文| 欧美中文字幕一区二区三区 | 国产大片一区二区| 欧美一卡二卡在线| 奇米影视一区二区三区小说| 欧美精品自拍偷拍| 午夜精品视频一区| 欧美日韩1234| 青青草国产精品97视觉盛宴 | 韩国三级在线一区| 日韩欧美电影一二三| 久久精品国产在热久久| 欧美一二区视频| 久热成人在线视频| 日韩片之四级片| 激情深爱一区二区| 日韩一区二区在线播放| 日韩高清在线不卡| 国产欧美一区二区精品性| 国产成人综合视频| 久久精品欧美日韩精品| 丁香六月综合激情| 中文字幕亚洲区| 在线观看亚洲成人| 日韩电影在线免费看| 日韩美女在线视频| 国产一区二区导航在线播放| 欧美激情在线免费观看| 色综合咪咪久久| 丝袜亚洲另类欧美综合| 欧美www视频| 99久久免费精品高清特色大片| 亚洲色图色小说| 91精品国产麻豆国产自产在线| 蜜臀av国产精品久久久久| 久久久电影一区二区三区| 93久久精品日日躁夜夜躁欧美| 亚洲女人****多毛耸耸8| 欧美日韩精品电影| 国产毛片精品一区| 一区二区三区中文字幕| 欧美一二三四在线| 99riav久久精品riav| 日韩av中文在线观看| 国产欧美日韩三级| 欧美日韩一级二级| 国产.欧美.日韩| 日韩精品电影在线| 国产精品美女久久福利网站| 欧美日韩视频在线一区二区| 国产成人精品三级麻豆| 亚洲午夜久久久久久久久电影网 | 91在线精品一区二区| 日韩影院在线观看| 亚洲免费观看在线视频| 欧美videofree性高清杂交| 91在线播放网址| 国产自产高清不卡| 日韩精品国产欧美| 日本三级亚洲精品| 中文字幕va一区二区三区| 91精品国产一区二区三区蜜臀 | 国产酒店精品激情| 日日夜夜一区二区| 亚洲综合偷拍欧美一区色| 久久久久久久久久久久久夜| 欧美视频一区二区三区在线观看| 国产激情一区二区三区四区| 亚洲第一福利视频在线| 日韩美女久久久| 中文字幕av在线一区二区三区| 日韩精品中文字幕一区二区三区| 色婷婷av一区二区三区大白胸 | 亚洲第一搞黄网站| 亚洲人亚洲人成电影网站色| 久久久久9999亚洲精品| 在线综合亚洲欧美在线视频| 色狠狠色噜噜噜综合网| 成人精品小蝌蚪| 国产一区中文字幕| 精品系列免费在线观看| 视频一区免费在线观看| 亚洲成人av一区| 日韩毛片高清在线播放| 国产精品女同一区二区三区| 国产欧美精品在线观看| 国产校园另类小说区| 国产亚洲欧美日韩在线一区| 亚洲精品日日夜夜| 中文字幕在线不卡一区| 精品国产在天天线2019| 欧美tickling挠脚心丨vk| 欧美成人video| 日韩精品自拍偷拍| 日韩一级片在线观看| 久久久五月婷婷| 国产精品女上位| 亚洲视频中文字幕| 亚洲电影一区二区三区| 日韩精品免费专区| 久久精品国产999大香线蕉| 国产一区二区三区日韩| 成人深夜福利app| 一本色道综合亚洲| 欧美日韩不卡一区| 亚洲精品一区二区三区精华液| 精品国产污污免费网站入口 | 欧美视频一区二区三区| 91精品国产综合久久小美女| 精品国产乱码久久久久久图片 | 99精品1区2区| 在线观看亚洲成人| 日韩视频在线你懂得| 国产日韩欧美电影| 亚洲精品网站在线观看| 丝袜诱惑亚洲看片| 国产iv一区二区三区| 91国产丝袜在线播放| 日韩精品一区二区三区中文精品| 久久亚洲免费视频| 一区二区三区四区五区视频在线观看 | 99热精品一区二区| 91精品中文字幕一区二区三区| 日韩欧美成人一区二区| 精品sm捆绑视频| 亚洲制服丝袜av| 国产美女久久久久| 色哟哟国产精品| 亚洲精品在线电影| 亚洲一区国产视频| 国产成人免费xxxxxxxx| 欧美无人高清视频在线观看| 精品日韩欧美一区二区| 亚洲精品乱码久久久久久| 国产激情一区二区三区四区| 欧美日韩黄色一区二区| 久久精品免视看| 免费亚洲电影在线|