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

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

?? areapro.cpp

?? VC++實際編程的源代碼 多種圖像邊緣檢測與分割處理
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
// AreaPro.cpp: implementation of the CAreaPro class.
//
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "AreaPro.h"

IMPLEMENT_DYNCREATE(CAreaPro, CObject)

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

//Diagnostics and dump member functions, overridden
#ifdef _DEBUG
void CAreaPro::Dump(CDumpContext &dc) const
{
	//call base class function first
	CObject::Dump(dc);
}
#endif

#ifdef _DEBUG
void CAreaPro::AssertValid() const
{
	//call inherited AssertValid first
	CObject::AssertValid();
	//Check CDibObject members...
	ASSERT(m_pDibObject != NULL);	//Must exist
}
#endif

/***********************************************************************
*                                                                      *
*                               區處理類                               *
*                                                                      *
***********************************************************************/

////////////////////////////////////////////////////////////////////////
//構造函數CAreaPro()    
//----------------------------------------------------------------------
//基本功能:構造一個CAreaPro類的對象,如不傳入CDibObject對象。第一次調   
//			用某一個處理函數時必須給出一個CDibObject對象指針。
//----------------------------------------------------------------------
//參數說明:無
//----------------------------------------------------------------------
//返    回:無
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////

CAreaPro::CAreaPro()
{

}

////////////////////////////////////////////////////////////////////////
//構造函數CAreaPro()    
//----------------------------------------------------------------------
//基本功能:構造一個CAreaPro類的對象并傳入CDibObject對象。所有的操作都
//			針對該對象,直到另一個對象作為參數被傳給圖像處理函數。
//----------------------------------------------------------------------
//參數說明:CDibObject *pDibObject
//----------------------------------------------------------------------
//返    回:無
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
CAreaPro::CAreaPro(CDibObject *pDibObject)
{
	m_pDibObject = pDibObject;
}

//析構函數
CAreaPro::~CAreaPro()
{

}

////////////////////////////////////////////////////////////////////////
//void SetDibObjectClass(CDibObject *pDibObject)   
//----------------------------------------------------------------------
//基本功能:本函數為CAreaPro類對象指定一個CDibObject對象指針
//----------------------------------------------------------------------
//參數說明:CDibObject *pDibObject, 默認為NULL。
//----------------------------------------------------------------------
//返    回:無。
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
void CAreaPro::SetDibObjectClass( CDibObject *pDibObject )
{
	m_pDibObject = pDibObject;
}

////////////////////////////////////////////////////////////////////////
//int *GetHistogram()   
//----------------------------------------------------------------------
//基本功能:本函數獲得傳入的m_pDibObject對象中圖像直方圖。如果進行此調
//			整之前沒有指定一個CDibObject對象指針,則必須在調整時加以指
//			定。任何未傳入的坐標值或默認的-1坐標值都將被置為圖像的最大值
//			或最大植。變量nX1和nY1將被置為0,nX2將被置為圖像寬度減1,nY2
//			將被置為圖像高度減1。想要在整個圖像上進行操作時,最好的方法
//			是不傳入nX1、nY1、nX2和nY2值。這樣它們會被默認為整個圖像。
//----------------------------------------------------------------------
//參數說明:int	nX1, 默認為-1
//			int	nY1, 默認為-1
//			int	nX2, 默認為-1
//			int	nY2, 默認為-1
//----------------------------------------------------------------------
//返    回:直方圖數組指針*pBuffer其中:
//			nHistogramBuffer[]		存儲亮度直方圖數據
//			nHistogramBuffer[256]	存儲紅色直方圖數據
//			nHistogramBuffer[512]	存儲綠色直方圖數據
//			nHistogramBuffer[768]	存儲藍直方圖數據
//----------------------------------------------------------------------
//注    意:此函數聲明為保護型,只能在CAreaPro類中使用
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
int *CAreaPro::GetHistogram( int nX1, int nY1, int nX2, int nY2)
{
	//無CDibObject對象, 返回FALSE
	if( m_pDibObject == NULL ) return( FALSE );

	//坐標規整化
	m_pDibObject->NormalizeCoordinates( &nX1, &nY1, &nX2, &nY2 );

	//定義變量
	unsigned char *pBuffer, *pBits;
	RGBQUAD *pPalette;
	int nWidthBytes, nNumColors;

	//獲得圖像指針
	pBuffer = (unsigned char *) m_pDibObject->GetDIBPointer( &nWidthBytes, 
		                                       m_pDibObject->GetNumBits() );
	if( pBuffer == NULL ) return( NULL );

	//獲得顏色數
	nNumColors = m_pDibObject->GetNumColors();
	//獲得調色板指針
	pPalette = (RGBQUAD *) &pBuffer[sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER)];
	//獲得位圖數據指針
	pBits = (unsigned char *) &pBuffer[sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER)
		                               + nNumColors * sizeof(RGBQUAD)];

	//創建直方圖數據
	int *nHistogramBuffer = CreateHistogram(nX1, nY1, nX2, nY2, pBits,
		                                    pPalette, nWidthBytes);

	::GlobalUnlock(m_pDibObject->GetDib());

	return(nHistogramBuffer);

}

////////////////////////////////////////////////////////////////////////
//int *CreateHistogram()   
//----------------------------------------------------------------------
//基本功能:本函數創建傳入m_pDibObject對象中圖像的直方圖。如果進行此調
//			整之前沒有指定一個CDibObject對象指針,則必須在調整時加以指
//			定。任何未傳入的坐標值或默認的-1坐標值都將被置為圖像的最大值
//			或最大植。變量nX1和nY1將被置為0,nX2將被置為圖像寬度減1,nY2
//			將被置為圖像高度減1。想要在整個圖像上進行操作時,最好的方法
//			是不傳入nX1、nY1、nX2和nY2值。這樣它們會被默認為整個圖像。
//----------------------------------------------------------------------
//參數說明:int	nX1					默認為-1
//			int	nY1					默認為-1
//			int	nX2					默認為-1
//			int	nY2					默認為-1
//			unsigned char *pData	圖像位圖數據指針
//			RGBQUAD *pPalette		圖像調色板指針
//			int nWidthBytes			圖像字節寬度
//----------------------------------------------------------------------
//返    回:直方圖數組指針*pBuffer其中:
//			pBuffer[]		存儲亮度直方圖數據
//			pBuffer[256]	存儲紅色直方圖數據
//			pBuffer[512]	存儲綠色直方圖數據
//			pBuffer[768]	存儲藍直方圖數據
//----------------------------------------------------------------------
//注    意:此函數聲明為保護型,只能在CAreaPro類中使用
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
int *CAreaPro::CreateHistogram(int nX1, int nY1, int nX2, int nY2, 
							   unsigned char *pData, 
							   RGBQUAD *pPalette, 
							   int nWidthBytes)
{
	//圖像指針為空,無法操作返回
	if(m_pDibObject == NULL) return(FALSE);

	//分配直方圖數據緩存區(數組)
	int *pBuffer = new int [256 * 4];
	//分配直方圖數據緩存區失敗
	if(pBuffer == NULL) return( NULL );

	//直方圖數據緩存區清零
	memset(pBuffer, 0, (256 * 4) * sizeof(int));

	//變量定義
	DWORD dwGray;
	int x, y;
	unsigned char *pTemp, ucRed, ucGreen, ucBlue;

	//圖像的高度
	int nHeight = m_pDibObject->GetHeight();

	switch(m_pDibObject->GetNumBits())
	{
	case 1:				//每像素位數為1,不處理
		break;
	case 4:				//每像素位數為4,不處理
		break;
	case 8:				//每像素位數為8		
		for( y = nY1; y <= nY2; y++ )
		{
			//數據指針定位到圖像數據起始位置
			pTemp = pData;
			//數據指針定位到圖像數據每行的起始零位置
			pTemp += ((nHeight - 1 - y) * nWidthBytes);
			//數據指針定位到圖像數據每行的起始nX1位置
			pTemp += nX1;
			for(x = nX1; x <= nX2; x++)
			{
				//pTemp[x]為當前像素值,以此為調色板項的索引值,
				//取出調色板項的相應紅綠藍分量值。
				ucRed   = pPalette[pTemp[x]].rgbRed;
				ucGreen = pPalette[pTemp[x]].rgbGreen;
				ucBlue  = pPalette[pTemp[x]].rgbBlue;

				//按關系L=0.3R+0.59G+0.11B,得到亮度值
				dwGray  = ((DWORD) ucRed * 30 +
					        (DWORD) ucGreen * 59 +
					        (DWORD) ucBlue * 11) / 100;
				dwGray &= 0x000000ff;

				//亮度直方圖數據
				pBuffer[dwGray]++;
				//紅色直方圖數據
				pBuffer[256 + ucRed]++;
				//綠色直方圖數據
				pBuffer[512 + ucGreen]++;
				//藍色直方圖數據
				pBuffer[768 + ucBlue]++;

			}
		}
		break;
	case 16:				//每像素位數為16
		for(y = nY1; y <= nY2; y++)
		{
			//數據指針定位到圖像數據起始位置
			pTemp = pData;
			//數據指針定位到圖像數據每行的起始零位置
			pTemp += (( nHeight - 1 - y) * nWidthBytes);
			//數據指針定位到圖像數據每行的起始nX1位置
			pTemp += (nX1 * 2);
			for(x = nX1; x <= nX2; x++)
			{
				//調用GETRGB555宏獲取三原色分量
				GETRGB555(ucRed, ucGreen, ucBlue, pTemp);

				//按關系L=0.3R+0.59G+0.11B,得到亮度值
				dwGray = ((DWORD) ucRed * 30 +
					       (DWORD) ucGreen * 59 +
					       (DWORD) ucBlue * 11) / 100;
				dwGray &= 0x000000ff;

				//亮度直方圖數據
				pBuffer[dwGray]++;
				//紅色直方圖數據
				pBuffer[256 + ucRed]++;
				//綠色直方圖數據
				pBuffer[512 + ucGreen]++;
				//藍色直方圖數據
				pBuffer[768 + ucBlue]++;

				//數據指針加2
				pTemp += 2;
			}
		}
		break;
	case 24:				//每像素位數為24
		for(y = nY1; y < nY2; y++)
		{
			//數據指針定位到圖像數據起始位置
			pTemp = pData;
			//數據指針定位到圖像數據每行的起始零位置
			pTemp += (( nHeight - 1 - y) * nWidthBytes);
			//數據指針定位到圖像數據每行的起始nX1位置
			pTemp += (nX1 * 3);

			for(x=nX1; x<=nX2; x++)
			{
				//獲取像素顏色的三原色。
				ucRed   = pTemp[x * 3 + 2];
				ucGreen = pTemp[x * 3 + 1];
				ucBlue  = pTemp[x * 3];

				//按關系L=0.3R+0.59G+0.11B,得到亮度值
				dwGray  = ((DWORD) ucRed * 30 +
					        (DWORD) ucGreen * 59 +
					        (DWORD) ucBlue * 11) / 100;
				dwGray &= 0x000000ff;

				//亮度直方圖數據
				pBuffer[dwGray]++;
				//紅色直方圖數據
				pBuffer[256 + ucRed]++;
				//綠色直方圖數據
				pBuffer[512 + ucGreen]++;
				//藍色直方圖數據
				pBuffer[768 + ucBlue]++;

				//數據指針加3
				pTemp += 3;
			}
		}
		break;
	case 32:				//每像素位數為24
		for(y = nY1; y <= nY2; y++)
		{
			//數據指針定位到圖像數據起始位置
			pTemp = pData;
			//數據指針定位到圖像數據每行的起始零位置
			pTemp += (( nHeight - 1 - y) * nWidthBytes);
			//數據指針定位到圖像數據每行的起始nX1位置
			pTemp += (nX1 * 4);

			for(x = nX1; x <= nX2; x++)
			{
				//調用GETRGB888宏獲取像素顏色的三原色。
				GETRGB888(ucRed, ucGreen, ucBlue, pTemp);

				//按關系L=0.3R+0.59G+0.11B,得到亮度值
				dwGray = ((DWORD) ucRed * 30 +
					       (DWORD) ucGreen * 59 +
					       (DWORD) ucBlue * 11) / 100;

				dwGray &= 0x000000ff;

				//亮度直方圖數據
				pBuffer[dwGray]++;
				//紅色直方圖數據
				pBuffer[256 + ucRed]++;
				//綠色直方圖數據
				pBuffer[512 + ucGreen]++;
				//藍色直方圖數據
				pBuffer[768 + ucBlue]++;

				//數據指針加4
				pTemp += 4;
			}
		}
		break;
	}
	
	return( pBuffer );
}

////////////////////////////////////////////////////////////////////////
//BOOL Convolution()   
//----------------------------------------------------------------------
//基本功能:本函數對指定的兩個數組進行卷積運算。
//----------------------------------------------------------------------
//參數說明:float *fpData		被執行卷積的數組
//			float *fpKernel		卷積核數組
//			float fCoef			卷積系數
//			int nSize			卷積尺寸
//			unsigned char *nResult		卷積結果
//----------------------------------------------------------------------
//返    回:無。
//----------------------------------------------------------------------
//注    意:此函數聲明為私有型,只能在CAreaPro類中使用
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
void CAreaPro::Convolution(float *fpData, float *fpKernel, float fCoef, 
						   int nSize, unsigned char *nResult)
{

	int i;
	float Sum = 0, fResult;

	//計算卷積
	for(i = 0; i < nSize; i++)
	{
		Sum += fpData[i] * fpKernel[i];
	}

	//執行卷積后的結果
	fResult = Sum / fCoef;

	//求絕對值
	fResult = (float)fabs(fResult);
	
	//判斷是否超過255
	if(fResult > 255.0 )
	{
		// 直接賦值為255
		fResult = 255.0;
	}
	
	//對卷積結果四舍五入,并轉換成unsigned char類型作為最后返回結果
	*nResult = (unsigned char) (fResult + 0.5);			
}

////////////////////////////////////////////////////////////////////////

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品国产精品网麻豆系列| www.一区二区| 精品福利av导航| 国内外精品视频| 欧美mv日韩mv亚洲| 国产一区二区精品久久| 欧美国产精品v| 97久久精品人人爽人人爽蜜臀| 亚洲人妖av一区二区| 91国偷自产一区二区三区成为亚洲经典| 成人欧美一区二区三区视频网页| 99这里都是精品| 亚洲自拍与偷拍| 欧美成人一区二区| 懂色av中文字幕一区二区三区 | 夜夜精品视频一区二区 | 琪琪一区二区三区| 久久女同精品一区二区| 99国产欧美久久久精品| 一区二区三区.www| 精品va天堂亚洲国产| 成人一级视频在线观看| 一区二区三区四区高清精品免费观看| 在线观看日韩av先锋影音电影院| 日韩在线卡一卡二| 国产日韩一级二级三级| 色狠狠一区二区| 美女视频黄免费的久久| 国产精品人妖ts系列视频| 欧美优质美女网站| 精品亚洲国内自在自线福利| 最新中文字幕一区二区三区| 欧美一级午夜免费电影| 91网上在线视频| 国产在线播放一区| 亚洲国产精品视频| 国产精品久久一卡二卡| 日韩一区二区电影| 91福利国产成人精品照片| 国产一区二区不卡在线| 午夜电影久久久| 国产精品电影院| 欧美大片日本大片免费观看| 色播五月激情综合网| 国产麻豆91精品| 午夜伦欧美伦电影理论片| 国产精品久久二区二区| 日韩一级黄色大片| 在线观看欧美黄色| 岛国一区二区三区| 精品一区二区成人精品| 天天色天天爱天天射综合| 亚洲私人黄色宅男| 久久久久久影视| 日韩精品专区在线影院重磅| 在线免费观看日韩欧美| 99久久国产综合精品女不卡| 国产精品1区2区3区在线观看| 视频一区欧美日韩| 亚洲一区国产视频| 亚洲人成电影网站色mp4| 欧美激情综合网| 久久免费国产精品| 日韩欧美国产电影| 欧美日韩视频在线第一区| av高清久久久| 成人福利视频在线看| 国产尤物一区二区在线| 久久疯狂做爰流白浆xx| 午夜精品久久久久久久久久久| 亚洲人亚洲人成电影网站色| 国产精品毛片无遮挡高清| 国产午夜精品久久久久久免费视| 欧美精品一区二区三区蜜桃| 欧美精品乱码久久久久久按摩| 欧美色区777第一页| 在线观看欧美黄色| 欧美日韩www| 欧美精品一二三| 欧美一区二区三区四区久久| 欧美日韩在线播| 欧美午夜在线观看| 欧美三级日本三级少妇99| 91在线观看成人| 99视频国产精品| 五月综合激情网| 蜜臀av一区二区三区| 精品一区二区影视| 精东粉嫩av免费一区二区三区| 国内成人精品2018免费看| 韩国v欧美v日本v亚洲v| 国产白丝精品91爽爽久久| 不卡一卡二卡三乱码免费网站| 成人sese在线| 色综合视频一区二区三区高清| 91视频观看免费| 色综合色综合色综合色综合色综合| 91在线精品一区二区三区| 色噜噜狠狠色综合欧洲selulu| 色噜噜狠狠成人中文综合| 欧美亚洲国产一区二区三区va | 欧美日本视频在线| 91精品国产综合久久精品| 精品成人一区二区| 日本一区二区电影| 亚洲成人福利片| 国产在线一区观看| 91免费国产在线| 欧美一级专区免费大片| 亚洲国产精品精华液ab| 亚洲在线观看免费| 韩国午夜理伦三级不卡影院| 播五月开心婷婷综合| 欧美日韩一区不卡| 久久久精品人体av艺术| 亚洲视频免费在线| 首页国产欧美久久| 国产精品1区二区.| 在线影院国内精品| 欧美电影免费观看高清完整版在线观看 | 2021国产精品久久精品| 国产精品另类一区| 婷婷久久综合九色国产成人| 国产精品亚洲成人| 一本色道久久综合狠狠躁的推荐 | www.成人在线| 欧美日韩不卡一区二区| 国产日韩在线不卡| 舔着乳尖日韩一区| 成人一区在线观看| 欧美精品一级二级| 亚洲少妇中出一区| 国产一区久久久| 欧美唯美清纯偷拍| 国产成人在线视频网站| 99精品国产99久久久久久白柏| 国产性色一区二区| 亚洲在线视频一区| 欧美视频在线一区| av男人天堂一区| 欧美不卡在线视频| 亚洲在线视频网站| 成人综合激情网| 精品理论电影在线观看| 午夜影院久久久| 99久久久久久| 欧美韩国日本不卡| 久久97超碰色| 日韩区在线观看| 午夜影视日本亚洲欧洲精品| 99精品在线观看视频| 欧美激情综合五月色丁香| 国产专区欧美精品| 日韩欧美一二三四区| 五月婷婷综合网| 欧美色图天堂网| 亚洲综合色网站| 色老头久久综合| 亚洲日本电影在线| 色综合视频在线观看| 日韩伦理电影网| 91在线观看地址| 久久一二三国产| 日韩午夜电影在线观看| 亚洲精品国产高清久久伦理二区| av在线不卡电影| 亚洲特级片在线| 91在线视频播放地址| 亚洲人成影院在线观看| 97se亚洲国产综合自在线不卡| 国产精品人妖ts系列视频| 国产suv精品一区二区883| 欧美激情一区二区三区不卡| 成人午夜碰碰视频| 最新中文字幕一区二区三区| 91蜜桃视频在线| 一区二区欧美在线观看| 精品视频在线看| 午夜av区久久| 日韩欧美国产一区在线观看| 国精产品一区一区三区mba视频| 久久亚洲精品小早川怜子| 国产成人av电影在线观看| 国产精品美女久久久久aⅴ| 色哟哟精品一区| 亚洲va欧美va国产va天堂影院| 91精品欧美久久久久久动漫 | 日韩一二三四区| 激情文学综合插| 国产精品久久网站| 91久久线看在观草草青青| 亚洲成人tv网| 欧美刺激脚交jootjob| 国产精品一二三区| 自拍偷拍欧美激情| 91精品国产黑色紧身裤美女| 精品中文av资源站在线观看| 中文欧美字幕免费| 欧美午夜精品一区二区蜜桃| 精品无人码麻豆乱码1区2区|