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

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

?? makecolordib.cpp

?? VC++圖像處理程序設計課本和代碼.
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
// MakeColorDib.cpp: implementation of the MakeColorDib class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "DSplit.h"
#include "MakeColorDib.h"
#include "MainFrm.h"
#include "math.h"
#define BOUND(x,a,b) (((x) < (a)) ? (a) : (((x) > (b)) ? (b) : (x)))
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

MakeColorDib::MakeColorDib()
{

}

MakeColorDib::~MakeColorDib()
{

}

/***************************************************************/
/*函數名稱:MakegGray()                                        */
/*函數類型:void                                               */
/*功能:真彩色轉化成256色灰度圖像。                            */
/***************************************************************/
void MakeColorDib::MakegGray()    //灰度變化
{
	BYTE *p_data;     //原圖數據區指針
	int wide,height,DibWidth;    //原圖長、寬、字節寬
	p_data=this->GetData ();   //取得原圖的數據區指針
    wide=this->GetWidth ();   //取得原圖的數據區寬度
    height=this->GetHeight ();   //取得原圖的數據區高度
	DibWidth=this->GetDibWidthBytes();   //取得原圖的每行字節數
	for(int j=0;j<height;j++)	// 每行
		for(int i=0;i<DibWidth;i+=3)	// 每列
		{
			BYTE* pbyBlue = p_data++;   //得到藍色值
			BYTE* pbyGreen = p_data++;  //得到綠色值
			BYTE* pbyRed = p_data++;    //得到紅色值
			BYTE r = *pbyRed;
			BYTE g = *pbyGreen;
			BYTE b = *pbyBlue;
			//取到原r,g,b中的最大值作為像素三分量值的新值
			int gray=0;
			if(r>g)
				gray=r;
			else 
				gray=g;
			if(gray<b)
				gray=b;			
       		*pbyBlue = gray;     //將取到的最大值賦給像素的藍分量
			*pbyGreen = gray;    //將取到的最大值賦給像素的綠分量
			*pbyRed = gray;	     //將取到的最大值賦給像素的紅分量
		}
}

/***************************************************************/
/*函數名稱:LightAlter(int m_Light)                            */
/*函數類型:void                                               */
/*參數:int m_Light,用戶給定的閾值                            */
/*功能:對圖像使用閾值法進行亮度調整。                         */
/***************************************************************/
void MakeColorDib::LightAlter(int m_Light)    //亮度調整
{
	BYTE *p_data;     //原圖數據區指針
	int wide,height,DibWidth;    //原圖長、寬、字節寬
	p_data=this->GetData ();   //取得原圖的數據區指針
    wide=this->GetWidth ();  //取得原圖的數據區寬度
    height=this->GetHeight ();    //取得原圖的數據區高度
	DibWidth=this->GetDibWidthBytes();   //取得原圖的每行字節數
	for(int j=0;j<height;j++)	// 每行
	for(int i=0;i<DibWidth;i++)	// 每列
	{   
		int a=0;
		a=int(*p_data*m_Light/100);   //調整當前點的亮度
		*p_data=a;
		//判斷范圍,取得合理的值
		if(a<0) 
			*p_data=0;  
	    if(a>255)
			*p_data=255;
        p_data++;   //指向下一指針
	}
}

/***************************************************************/
/*函數名稱:LightReverse()                                     */
/*函數類型:void                                               */
/*功能:圖像的亮度取反。                                       */
/***************************************************************/
void MakeColorDib::LightReverse()    //亮度取反
{
	BYTE *p_data;     //原圖數據區指針
	int wide,height,DibWidth;    //原圖長、寬、字節寬
	p_data=this->GetData ();   //取得原圖的數據區指針
    wide=this->GetWidth ();  //取得原圖的數據區寬度
    height=this->GetHeight ();   //取得原圖的數據區高度
	DibWidth=this->GetDibWidthBytes();   //取得原圖的每行字節數
	for(int j=0;j<height;j++)	// 每行
		for(int i=0;i<DibWidth;i++)	// 每列
		{
			int a=*p_data;   //取得當前點的值
			*p_data=255-a;    //取反
			p_data++;  //指向下一指針  
		}
}

/***************************************************************/
/*函數名稱:ContrastAlter(int m_Increment)                     */
/*函數類型:void                                               */
/*參數:int m_Increment,用戶給定的閾值                        */
/*功能:對圖像使用閾值法調整對比度處理。                       */
/***************************************************************/
void MakeColorDib::ContrastAlter(int m_Increment)   ///對比度處理
{
	int nHigh = 255 - m_Increment;
	//對于極端情況加以處理
	if(nHigh < m_Increment)
	{
		nHigh = 127;
		m_Increment = 120;
	}
	if(m_Increment < -127)
		m_Increment = -120;
	//擴展或壓縮區間的長度
	int nStretch = 255;
	if(m_Increment >= 0)
		nStretch = 255 - 2 * m_Increment;
	else
		nStretch = 255 + 2 * m_Increment;
	BYTE *p_data;     //原圖數據區指針
	int wide,height,DibWidth;    //原圖長、寬、字節寬
	p_data=this->GetData ();   //取得原圖的數據區指針
    wide=this->GetWidth ();  //取得原圖的數據區寬度
    height=this->GetHeight ();   //取得原圖的數據區高度
	DibWidth=this->GetDibWidthBytes();   //取得原圖的每行字節數
	if(m_Increment >= 0)   // m_Increment>=0時
	{
		for(int j=0;j<height;j++)	// 每行
			for(int i=0;i<DibWidth-3;i+=3)	// 每列
			{   
				//取得當前點(藍色)的值,調整
				BYTE* pbyBlue = p_data++;    
				if(*pbyBlue<=m_Increment)
					*pbyBlue=0;
				else if(*pbyBlue>nHigh)
					*pbyBlue=255;
				else
					*pbyBlue=(BYTE)((((int)*pbyBlue - m_Increment) * 255) / nStretch );
				//取得當前點(綠色)的值,調整
				BYTE* pbyGreen = p_data++;
				if(*pbyGreen<=m_Increment)
					*pbyGreen=0;
				else if(*pbyGreen>nHigh)
					*pbyGreen=255;
				else
					*pbyGreen=(BYTE)((((int)*pbyGreen - m_Increment) * 255) / nStretch );
				//取得當前點(紅色)的值,調整
				BYTE* pbyRed = p_data++;
				if(*pbyRed<=m_Increment)
					*pbyRed=0;
				else if(*pbyRed>nHigh)
					*pbyRed=255;
				else
					*pbyRed=(BYTE)((((int)*pbyRed - m_Increment) * 255) / nStretch );
			}
			
	}
	else  // m_Increment < 0 時
	{
		for(int j=0;j<height;j++)
			for(int i=0;i<DibWidth-3;i+=3)
			{	//取得當前點(藍色)的值,調整
				BYTE* pbyBlue = p_data++;
				*pbyBlue = (BYTE)((((int)(*pbyBlue) * nStretch) / 255) - m_Increment);
				//取得當前點(紅色)的值,調整
				BYTE* pbyGreen = p_data++;
				*pbyGreen = (BYTE)((((int)(*pbyGreen) * nStretch) / 255) - m_Increment);
				//取得當前點(紅色)的值,調整
				BYTE* pbyRed = p_data++;
				*pbyRed = (BYTE)((((int)(*pbyRed) * nStretch) / 255) - m_Increment);				
			}
	}
}

/***************************************************************/
/*函數名稱:Exposal()                                          */
/*函數類型:void                                               */
/*功能:圖像曝光處理。                                         */
/***************************************************************/
void MakeColorDib::Exposal() //曝光處理
{
	BYTE *p_data;     //原圖數據區指針
	int wide,height,DibWidth;    //原圖長、寬、字節寬
	p_data=this->GetData ();   //取得原圖的數據區指針
    wide=this->GetWidth ();  //取得原圖的數據區寬度
    height=this->GetHeight ();   //取得原圖的數據區高度
	DibWidth=this->GetDibWidthBytes();   //取得原圖的每行字節數
	for(int j=0;j<height;j++)	// 每行
		for(int i=0;i<DibWidth;i++)	// 每列
		{
			BYTE* pbydata = p_data++;  //取得當前點的值
			BYTE a=*pbydata;   //傳給臨時變量
			*pbydata=(a>128)?a:(255-a);   //調整
		}
		
}

/***************************************************************/
/*函數名稱:PaintColor(int m_Red,int m_Green,int m_Blue)       */
/*函數類型:void                                               */
/*參數:int m_Red、m_Green、m_Blue,用戶給定的紅綠藍值         */
/*功能:對圖像使用閾值法進行著色處理。                         */
/***************************************************************/
void MakeColorDib::PaintColor(int m_Red,int m_Green,int m_Blue) //著色處理
{
	BYTE *p_data;     //原圖數據區指針
	int wide,height,DibWidth;    //原圖長、寬、字節寬
	p_data=this->GetData ();   //取得原圖的數據區指針
    wide=this->GetWidth ();  //取得原圖的數據區寬度
    height=this->GetHeight ();   //取得原圖的數據區高度
	DibWidth=this->GetDibWidthBytes();   //取得原圖的每行字節數
	for(int j=0;j<height;j++)	// 每行
		for(int i=0;i<DibWidth;i+=3)	// 每列
		{			
			BYTE* pbyBlue = p_data++;	//取得當前點(藍色)的值					
			BYTE* pbyGreen = p_data++;  //取得當前點(綠色)的值
			BYTE* pbyRed = p_data++;    //取得當前點(紅色)的值
			BYTE r = *pbyRed;
			BYTE g = *pbyGreen;
			BYTE b = *pbyBlue;
    		BYTE gray=(BYTE)(((WORD)r * 59 + (WORD)g * 30 + (WORD)b * 11) / 100);
			*pbyBlue = (BYTE)((m_Blue * gray) / 255);  
			*pbyGreen = (BYTE)((m_Green * gray) / 255);
			*pbyRed = (BYTE)((m_Red * gray) / 255);
		}
}

/***************************************************************/
/*函數名稱:NeonLight()                                        */
/*函數類型:void                                               */
/*功能:使圖像產生霓虹處理效果。                               */
/***************************************************************/
void MakeColorDib::NeonLight()   //霓虹處理
{

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看日韩国产| 久久综合色鬼综合色| 国产精品原创巨作av| 亚洲欧美成人一区二区三区| 欧美日韩日日摸| av在线免费不卡| 成人综合在线视频| 日韩不卡一二三区| 国产亚洲一区二区三区在线观看| 色综合中文综合网| 精品成人一区二区三区四区| 麻豆成人久久精品二区三区红| 国产无遮挡一区二区三区毛片日本 | 国产精品二三区| 国产精品私人自拍| 国产精品色在线观看| 久久九九久精品国产免费直播| 精品污污网站免费看| 成人av手机在线观看| 捆绑调教美女网站视频一区| 亚洲青青青在线视频| 精品捆绑美女sm三区| 樱桃国产成人精品视频| 亚洲福利一区二区三区| 日本欧美韩国一区三区| 久久疯狂做爰流白浆xx| 成人性视频免费网站| 欧美专区亚洲专区| 国产午夜精品理论片a级大结局| 欧美电影精品一区二区| 国产精品美女一区二区三区 | 亚洲人成7777| 欧美α欧美αv大片| 国产视频在线观看一区二区三区 | 一区二区三区小说| www.色综合.com| 91丝袜美女网| 日本一区二区免费在线| 国产欧美日韩麻豆91| 丝袜美腿一区二区三区| 欧美xxxx老人做受| 久久99精品国产.久久久久久 | 久久午夜色播影院免费高清| 激情综合一区二区三区| 欧美一级高清片在线观看| 国产一区二区三区精品视频| 国产精品色在线观看| 99re视频这里只有精品| 一区二区三区在线观看视频| 欧美日韩免费一区二区三区 | 国产乱码精品一区二区三| 国产精品久久午夜| 欧美一级日韩一级| 国产一区二区福利| 成人免费视频在线观看| 91国模大尺度私拍在线视频| 日韩av午夜在线观看| 91小视频在线观看| 一区二区三区四区在线免费观看| 欧美日韩精品一区视频| 国产精品一区二区果冻传媒| 亚洲精品欧美在线| 欧美成人福利视频| 欧美人xxxx| 成人av电影免费观看| 午夜精品一区在线观看| 中文字幕乱码亚洲精品一区| 欧洲av一区二区嗯嗯嗯啊| 精品中文字幕一区二区 | 久久91精品久久久久久秒播| 亚洲国产欧美在线| ●精品国产综合乱码久久久久| xfplay精品久久| 精品国产亚洲在线| 久久亚洲一区二区三区四区| 精品成人一区二区三区四区| 久久婷婷成人综合色| 日本一区二区三区国色天香| 欧美—级在线免费片| 国产精品国产三级国产aⅴ原创| 久久美女高清视频| 久久一区二区三区四区| 欧美成人video| 日韩欧美国产综合| 国产精品无码永久免费888| 国产喷白浆一区二区三区| 久久久国产午夜精品 | 精油按摩中文字幕久久| 色综合色狠狠综合色| 精品国产一区二区精华| 国产精品天天摸av网| 日本亚洲天堂网| 色狠狠桃花综合| 日韩三级在线观看| 亚洲欧美视频一区| 国产麻豆成人传媒免费观看| 91亚洲国产成人精品一区二区三| 欧美特级限制片免费在线观看| 欧美一区二区三区视频在线观看| 久久久久久一二三区| 亚洲精品中文字幕在线观看| 九九国产精品视频| 欧美午夜精品一区二区三区 | 精品播放一区二区| 一区二区三区精品在线| 狠狠狠色丁香婷婷综合激情| 91视频com| 国产精品毛片高清在线完整版| 日韩av一区二| 宅男在线国产精品| 成人欧美一区二区三区黑人麻豆| 日韩高清不卡一区二区三区| k8久久久一区二区三区| 精品久久久久久久久久久久久久久| 亚洲欧美日韩久久| 色婷婷综合久久久久中文 | 欧美日韩亚洲丝袜制服| 国产精品国产成人国产三级| 久久精品国产久精国产| 精品国产一二三| jizzjizzjizz欧美| 丝袜诱惑制服诱惑色一区在线观看| www.亚洲人| 五月天一区二区| 欧美mv日韩mv| 9l国产精品久久久久麻豆| ...av二区三区久久精品| 色8久久人人97超碰香蕉987| 亚洲免费在线观看视频| 日韩欧美久久久| 色久综合一二码| 国产乱人伦偷精品视频不卡 | 国产精品免费观看视频| 欧美日韩一区在线观看| 国产制服丝袜一区| 亚洲人成小说网站色在线| 在线看不卡av| 国产精品综合一区二区三区| 日韩美女久久久| 日韩精品一区二区三区蜜臀 | 日韩欧美一区二区免费| 国产麻豆精品在线| 午夜欧美2019年伦理| 国产精品三级av在线播放| 日韩欧美一级在线播放| 在线观看日韩一区| av电影天堂一区二区在线| 国产99久久久久久免费看农村| 蜜桃视频在线观看一区| 极品少妇xxxx精品少妇| 国产成人精品综合在线观看| 久久99精品一区二区三区三区| 婷婷六月综合网| 最好看的中文字幕久久| 国产亚洲成aⅴ人片在线观看 | 亚洲r级在线视频| 污片在线观看一区二区| 亚洲电影中文字幕在线观看| 亚洲乱码国产乱码精品精的特点| 亚洲男人的天堂在线aⅴ视频| 亚洲午夜精品17c| 精品一区二区三区在线观看国产 | 欧美日韩免费一区二区三区| 91网站最新地址| 91精品在线观看入口| 91免费视频大全| 日韩欧美第一区| 91精品国产日韩91久久久久久| 91精品国产免费久久综合| 欧美大片在线观看| 国产婷婷精品av在线| 综合精品久久久| 日韩国产成人精品| 福利视频网站一区二区三区| 成人激情文学综合网| 精品成人佐山爱一区二区| 香蕉加勒比综合久久| 成人午夜视频在线观看| 精品国产制服丝袜高跟| 五月天激情综合| 91免费在线看| 国产女主播视频一区二区| 亚洲成人免费在线观看| 色综合久久综合| 综合久久久久综合| 欧美在线999| 夜夜嗨av一区二区三区中文字幕| 韩国v欧美v亚洲v日本v| 欧美一级高清大全免费观看| 亚洲成人一区二区| 欧美在线免费观看视频| 亚洲另类在线一区| 欧美三日本三级三级在线播放| 亚洲成人免费看| 91麻豆精品91久久久久久清纯| 青青草国产精品97视觉盛宴| 精品国产一区二区三区四区四| 极品少妇一区二区| 国产亚洲成年网址在线观看| 国产成人精品免费视频网站|