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

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

?? pointpro.cpp

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

#include "stdafx.h"
#include "PointPro.h"
#include "math.h"

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

IMPLEMENT_DYNCREATE(CPointPro, CObject)

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

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

/***********************************************************************
*                                                                      *
*                               點處理                                 *
*                                                                      *
***********************************************************************/

////////////////////////////////////////////////////////////////////////
//CPointPro()   
//----------------------------------------------------------------------
//基本功能:構造CPointPro類對象。由于此構造函數沒有
//			CDibObject類,所以必須為其他所用到的CPointPro函
//			數提供一個CDibObject構造器。
//----------------------------------------------------------------------
//參數說明:無
//----------------------------------------------------------------------
//返    回:無
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
CPointPro::CPointPro()
{
}

////////////////////////////////////////////////////////////////////////
//CPointPro(CDibObject *pDibObject)   
//----------------------------------------------------------------------
//基本功能:構造CPointPro類對象。由于此構造函數有一個
//			CDibObject類,所以無須為其他所用到的CPointPro函
//			數提供一個CDibObject構造器
//----------------------------------------------------------------------
//參數說明:無
//----------------------------------------------------------------------
//返    回:無
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
CPointPro::CPointPro( CDibObject *pDibObject )
{

	m_pDibObject = pDibObject;

}

////////////////////////////////////////////////////////////////////////
//BOOL MakeGray256(BYTE mGrayType, CDibObject *pDibObject)   
//----------------------------------------------------------------------
//基本功能:本函數將傳入的CDibObject對象中的圖像從彩色轉換為灰度圖像。
//			如果進行此調整之前沒有指定一個CDibObject對象指針,則必須在
//			調整時加以指定。
//----------------------------------------------------------------------
//參數說明:BYTE mGrayType  0:Y=0.3R+0.59G+0.11B 
//							1: Y=R 
//							2: Y=G
//							3: Y=B					
//			CDibObject *pDibObject, 默認為NULL。
//----------------------------------------------------------------------
//返    回:成功返回TRUE,失敗返回FALSE。
//----------------------------------------------------------------------
////////////////////////////////////////////////////////////////////////
BOOL CPointPro::MakeGray256(BYTE mGrayType, 
									CDibObject *pDibObject )
{
	//CDibObject對象指針
	if( pDibObject != NULL ) m_pDibObject = pDibObject;
	//若未指定 CDibObject 對象指針返回FALSE
	if( m_pDibObject == NULL ) return( FALSE );
	//低于8位的圖像不進行處理
	if( m_pDibObject->GetNumBits() < 8 ) return( FALSE );


	//獲取原圖像字節寬度和轉換后的8位256色灰度圖像的字節寬度
	int nOldWidthBytes, nNewWidthBytes;
	char *pBuffer = (char *) m_pDibObject->GetDIBPointer( &nOldWidthBytes, 8, &nNewWidthBytes );
	if( pBuffer == NULL ) return( FALSE );

	//定義變量
	BITMAPINFOHEADER *pOldBIH, *pNewBIH;
	BITMAPFILEHEADER *pOldBFH, *pNewBFH;
	RGBQUAD *pOldRGBPalette, *pNewRGBPalette;
	unsigned char *pOldBits, *pNewBits, *pTemp, *pNewTemp;
	int nNumColors, nNumNewColors;

	//獲取文件頭指針
	pOldBFH = (BITMAPFILEHEADER *) pBuffer;
	//獲取信息頭指針
	pOldBIH = (BITMAPINFOHEADER *) &pBuffer[sizeof(BITMAPFILEHEADER)];
	//獲取調色板指針
	pOldRGBPalette = (RGBQUAD *) &pBuffer[sizeof(BITMAPFILEHEADER)+
									sizeof(BITMAPINFOHEADER)];
	//原圖像顏色數
	nNumColors = m_pDibObject->GetNumColors();
	//新圖像顏色數
	nNumNewColors = 256;
	//獲取原圖像數據指針
	pOldBits = (unsigned char *) &pBuffer[sizeof(BITMAPFILEHEADER)
		+sizeof(BITMAPINFOHEADER)+nNumColors*sizeof(RGBQUAD)];

	//為新圖像分配內存
	HGLOBAL hGlobal;
	//新圖像總字節數
	DWORD dwSize;
	dwSize = sizeof( BITMAPFILEHEADER ) + sizeof( BITMAPINFOHEADER ) +
			256 * sizeof( RGBQUAD ) + 
			m_pDibObject->GetHeight() * nNewWidthBytes;
	hGlobal = ::GlobalAlloc( GMEM_MOVEABLE | GMEM_ZEROINIT, dwSize );
	if( hGlobal == NULL )
	{
		::GlobalUnlock( m_pDibObject->GetDib() );
		return( FALSE );
	}

	pBuffer = (char *) ::GlobalLock( hGlobal );
	if( pBuffer == NULL )
	{
		::GlobalFree( hGlobal );
		::GlobalUnlock( m_pDibObject->GetDib() );
		return( FALSE );
	}

	//獲得新圖像的文件頭指針
	pNewBFH = (BITMAPFILEHEADER *) pBuffer;
	//獲得新圖像的信息頭指針
	pNewBIH = (BITMAPINFOHEADER *) &pBuffer[sizeof(BITMAPFILEHEADER)];
	//獲得新圖像的調色板指針
	pNewRGBPalette = (RGBQUAD *) &pBuffer[sizeof(BITMAPFILEHEADER)
						+sizeof(BITMAPINFOHEADER)];
	//復制原圖像文件頭數據到新圖像文件頭
	*pNewBFH = *pOldBFH;
	//復制原圖像信息頭數據到新圖像信息頭
	*pNewBIH = *pOldBIH;

	//循環變量定義
	int i, j = 256, x, y;

	pNewBIH->biBitCount = 8;
	pNewBIH->biSizeImage = nNewWidthBytes * m_pDibObject->GetHeight();
	pNewBIH->biClrUsed = 256;
	pNewBFH->bfSize =	sizeof( BITMAPFILEHEADER ) + 
						sizeof( BITMAPINFOHEADER ) + 
						256 * sizeof( RGBQUAD ) + 
						pNewBIH->biSizeImage;
	pNewBFH->bfOffBits =	sizeof( BITMAPFILEHEADER ) + 
							sizeof( BITMAPINFOHEADER ) + 
							nNumNewColors * sizeof( RGBQUAD );
	pNewBits = (unsigned char *) &pBuffer[sizeof(BITMAPFILEHEADER) +
		sizeof(BITMAPINFOHEADER) + 256 * sizeof(RGBQUAD)];
	m_pDibObject->SetPaletteBytes( 256 * sizeof( RGBQUAD ));
	
	//創建256色灰度調色板
	for( i = 0; i < j; i++ )
	{
		pNewRGBPalette[i].rgbRed = i;
		pNewRGBPalette[i].rgbGreen = i;
		pNewRGBPalette[i].rgbBlue = i;
	}


	unsigned char *pLookup;	//調色板查找表
	DWORD dwGray;	//灰度級別

	switch( m_pDibObject->GetNumBits() )
	{
	case 8:		//256色圖像
		pLookup = new unsigned char [256];
		if( pLookup == NULL ) break;
		memset( pLookup, 0, 256 );	//調色板查找表清0(256項)
		switch( mGrayType)
		{
		case 0:	//按亮度Y=0.3R+0.59G+0.11B將彩色圖像轉換為灰度圖像
			for( i=0; i<256; i++ )
			{
				dwGray = ( (DWORD) pOldRGBPalette[i].rgbRed * 30 +
					(DWORD) pOldRGBPalette[i].rgbGreen * 59 +
					(DWORD) pOldRGBPalette[i].rgbBlue * 11 ) / 100;
				pLookup[i] = (unsigned char) dwGray;
			}
			break;
		case 1:	//按亮度Y=R將彩色圖像轉換為灰度圖像
			for( i=0; i<256; i++ )
			{
				dwGray =  (DWORD) pOldRGBPalette[i].rgbRed;
				pLookup[i] = (unsigned char) dwGray;
			}
			break;
		case 2:	//按亮度Y=G將彩色圖像轉換為灰度圖像
			for( i=0; i<256; i++ )
			{
				dwGray = (DWORD) pOldRGBPalette[i].rgbGreen;
				pLookup[i] = (unsigned char) dwGray;
			}
			break;
		case 3:	//按亮度Y=B將彩色圖像轉換為灰度圖像
			for( i=0; i<256; i++ )
			{
				dwGray =(DWORD) pOldRGBPalette[i].rgbBlue;
				pLookup[i] = (unsigned char) dwGray;
			}
			break;
		}
		for( y = 0; y < pOldBIH->biHeight; y++ )
		{
			pTemp = pOldBits;	//位圖數據起始指針
			pTemp += y * nOldWidthBytes;	//位圖數據下一行起始指針
			//轉換成灰度索引
			for( x = 0; x < pOldBIH->biWidth; x++ ) pTemp[x] = pLookup[pTemp[x]];
		}
		delete [] pLookup;	//釋放pLookup查找表所占內存
		
		memcpy( pNewBits, pOldBits, nNewWidthBytes * m_pDibObject->GetHeight());
		
		break;
	case 16:	//16位色真彩色圖像
		unsigned char ucRed, ucGreen, ucBlue;
		for( y=0; y<pOldBIH->biHeight; y++ )
		{
			//位圖數據起始指針
			pTemp = pOldBits;	
			pNewTemp = pNewBits;
			//位圖數據下一行起始指針
			pTemp += y * nOldWidthBytes;	
			pNewTemp += y * nNewWidthBytes;
			switch( mGrayType )
			{
			case 0:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					GETRGB555( ucRed, ucGreen, ucBlue, &pTemp[x*2] );
					//按亮度Y=0.3R+0.59G+0.11B將彩色圖像轉換為灰度圖像
					dwGray = (ucRed * 30 + ucGreen * 59 +ucBlue * 11) / 100;
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 1:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					GETRGB555( ucRed, ucGreen, ucBlue, &pTemp[x*2] );
					//按亮度Y=R將彩色圖像轉換為灰度圖像
					dwGray = (ucRed * 30 + ucGreen * 59 +ucBlue * 11) / 100;
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 2:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					GETRGB555( ucRed, ucGreen, ucBlue, &pTemp[x*2] );
					//按亮度Y=G將彩色圖像轉換為灰度圖像
					dwGray = (ucRed * 30 + ucGreen * 59 +ucBlue * 11) / 100;
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 3:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					GETRGB555( ucRed, ucGreen, ucBlue, &pTemp[x*2] );
					//按亮度Y=B將彩色圖像轉換為灰度圖像
					dwGray = (ucRed * 30 + ucGreen * 59 +ucBlue * 11) / 100;
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			}
		}
		break;
	case 24:	//24位真彩色圖像
		for( y=0; y<pOldBIH->biHeight; y++ )
		{
			//位圖數據起始指針
			pTemp = pOldBits;	
			pNewTemp = pNewBits;
			//位圖數據下一行起始指針
			pTemp += y * nOldWidthBytes;	
			pNewTemp += y * nNewWidthBytes;
			switch( mGrayType )
			{
			case 0:	//按亮度Y=0.3R+0.59G+0.11B將彩色圖像轉換為灰度圖像
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					dwGray = ( (DWORD) pTemp[x*3+2] * 30	//紅色
						+(DWORD) pTemp[x*3+1] * 59		//綠色
						+(DWORD) pTemp[x*3] * 11		//蘭色
						) / 100;
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 1:	//按亮度Y=R將彩色圖像轉換為灰度圖像
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					dwGray =  (DWORD) pTemp[x*3+2]; //紅色
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 2:	//按亮度Y=G將彩色圖像轉換為灰度圖像
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					dwGray = (DWORD) pTemp[x*3+1] ;	//綠色
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 3:	//按亮度Y=B將彩色圖像轉換為灰度圖像
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					dwGray =(DWORD) pTemp[x*3];	//蘭色
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			}
		}
		break;
	case 32:	//32位真彩色圖像
		for( y=0; y<pOldBIH->biHeight; y++ )
		{
			//位圖數據起始指針
			pTemp = pOldBits;	
			pNewTemp = pNewBits;
			//位圖數據下一行起始指針
			pTemp += y * nOldWidthBytes;	
			pNewTemp += y * nNewWidthBytes;
			switch( mGrayType )
			{
			case 0:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					//按亮度Y=0.3R+0.59G+0.11B將彩色圖像轉換為灰度圖像
					dwGray = ( (DWORD) pTemp[x*4] * 30 //紅色
						+(DWORD) pTemp[x*4+1] * 59	//綠色
						+(DWORD) pTemp[x*4+2] * 11 //蘭色
						) / 100;
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 1:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					//按亮度Y=R將彩色圖像轉換為灰度圖像
					dwGray =  (DWORD) pTemp[x*4];//紅色
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 2:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					//按亮度Y=G將彩色圖像轉換為灰度圖像
					dwGray = (DWORD) pTemp[x*4+1] ;	//綠色
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			case 3:
				for( x=0; x<pOldBIH->biWidth; x++ )
				{
					//按亮度Y=B將彩色圖像轉換為灰度圖像
					dwGray =(DWORD) pTemp[x*4+2] ; //蘭色
					//給新圖像數據賦值
					pNewTemp[x] = (unsigned char)dwGray;
				}
				break;
			}
		}
		break;
	}
			
	::GlobalUnlock( m_pDibObject->GetDib() );
	::GlobalFree( m_pDibObject->GetDib() );
	::GlobalUnlock( hGlobal );
	m_pDibObject->SetDib( hGlobal );

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产91综合一区在线观看| 欧美熟乱第一页| 午夜av电影一区| 一区二区三区在线免费播放 | 精品国产在天天线2019| 亚洲人成7777| 日韩欧美国产精品一区| 大桥未久av一区二区三区中文| 自拍偷拍国产精品| 欧美日韩在线播放三区四区| 国产乱码一区二区三区| 一区二区三区日韩欧美| 久久精品欧美日韩精品| 欧美三级一区二区| eeuss鲁一区二区三区| 精品一区二区三区久久久| 亚洲综合色成人| 国产精品久久久久久久久快鸭 | 亚洲欧洲另类国产综合| 91国偷自产一区二区三区成为亚洲经典| 精品欧美黑人一区二区三区| 丁香婷婷深情五月亚洲| 日韩精品色哟哟| 欧美国产欧美综合| 91精品国产综合久久久蜜臀图片 | av网站一区二区三区| 亚洲成人一区二区在线观看| 欧美成人vps| 欧美三区在线观看| 91在线视频18| 日本午夜一本久久久综合| 亚洲综合免费观看高清完整版 | 免费欧美在线视频| 亚洲成av人影院| 欧美激情在线一区二区三区| 5566中文字幕一区二区电影| 91成人免费在线| 91啦中文在线观看| 波多野结衣亚洲一区| 国产在线不卡视频| 国产午夜精品久久久久久久| 欧美一级搡bbbb搡bbbb| 欧美一三区三区四区免费在线看 | 狠狠色丁香久久婷婷综| 日本不卡不码高清免费观看| 香蕉久久夜色精品国产使用方法| 国产日本一区二区| 亚洲欧美视频在线观看| 一区二区三区久久久| 亚洲欧美精品午睡沙发| 亚洲综合免费观看高清完整版 | 91免费观看在线| 91免费精品国自产拍在线不卡| 色哟哟一区二区| 69p69国产精品| 国产欧美一区视频| 亚洲一区二区三区在线| 免费人成网站在线观看欧美高清| 国产精品一级黄| 欧美亚洲另类激情小说| 欧美精品一区二区高清在线观看| 亚洲欧洲一区二区在线播放| 亚洲综合免费观看高清完整版在线 | 成人av网站免费| 91精品国产麻豆国产自产在线| 91精品国产乱| 亚洲欧美另类久久久精品| 麻豆91在线看| 99视频精品全部免费在线| 久久成人免费日本黄色| 欧美午夜精品电影| 国产精品对白交换视频 | 丰满放荡岳乱妇91ww| 精品视频一区三区九区| 久久久久久久久一| 国产在线视频一区二区三区| 国产精品911| 国产亚洲精品超碰| 精品一区二区三区视频在线观看| 在线这里只有精品| 亚洲美女在线国产| 成人动漫视频在线| 久久久久久久久久久电影| 蜜桃视频在线观看一区二区| 欧美日韩国产小视频| 免费人成精品欧美精品 | 国产一区二区在线电影| 欧美日韩一区二区三区在线看| 亚洲蜜臀av乱码久久精品| 成人99免费视频| 国产精品国产三级国产a| 成人不卡免费av| 一区二区激情小说| 51精品视频一区二区三区| 免费成人小视频| 国产日韩v精品一区二区| 99r精品视频| 日韩中文字幕av电影| 日韩欧美精品在线视频| 不卡的av在线| 亚洲网友自拍偷拍| 欧美精品一区二区久久婷婷| 成人免费三级在线| 日韩高清国产一区在线| 中文字幕高清不卡| 91精品国产色综合久久ai换脸 | 日本一二三四高清不卡| 欧美天天综合网| 国精品**一区二区三区在线蜜桃| 国产精品久久看| 欧美tk—视频vk| 欧美性色黄大片| 99久久亚洲一区二区三区青草 | 精品处破学生在线二十三| 99久久99久久综合| 久久9热精品视频| 天堂在线亚洲视频| 一区二区三区欧美| 国产精品久久久久久久久免费樱桃 | 国产农村妇女毛片精品久久麻豆| 欧美一区二区日韩| 欧美三级在线播放| 欧美丰满高潮xxxx喷水动漫| 色综合咪咪久久| 成人v精品蜜桃久久一区| 丰满亚洲少妇av| 日本电影亚洲天堂一区| 色一情一伦一子一伦一区| 99久久国产综合精品色伊| 99re这里都是精品| 欧美色精品在线视频| 97精品国产露脸对白| 欧美午夜精品一区二区蜜桃 | 亚洲欧美一区二区三区久本道91| 中文字幕日韩av资源站| 亚洲免费伊人电影| 亚洲精品写真福利| 国产精品1区二区.| 欧美精品色综合| 中文字幕一区在线| 国产又粗又猛又爽又黄91精品| 色哟哟国产精品| 久久精品水蜜桃av综合天堂| 亚洲电影在线播放| 91视频国产资源| 亚洲国产精品激情在线观看| 亚洲一区二区av电影| 99免费精品在线观看| 久久久美女毛片| 美女www一区二区| 欧美日韩国产成人在线免费| 国产精品无遮挡| 成人黄色av网站在线| 久久蜜桃一区二区| 国产精品亚洲а∨天堂免在线| 在线综合视频播放| 亚洲mv在线观看| 欧美一卡二卡在线| 青娱乐精品视频| 欧美大白屁股肥臀xxxxxx| 日韩和欧美一区二区三区| 欧美日韩高清一区| 日韩二区在线观看| 久久蜜桃av一区精品变态类天堂| 久久不见久久见中文字幕免费| 欧美丰满一区二区免费视频 | 污片在线观看一区二区| 欧美日韩国产高清一区| 久久精品国产澳门| 国产欧美一区二区三区沐欲| k8久久久一区二区三区| 一区二区不卡在线播放| 欧美日韩中文精品| 久久www免费人成看片高清| 国产精品国产馆在线真实露脸 | 国产在线视频精品一区| 亚洲欧美日韩一区二区三区在线观看| 色又黄又爽网站www久久| 日本成人中文字幕在线视频| 国产精品视频第一区| 欧美三级视频在线观看| 国产91对白在线观看九色| 日韩成人dvd| 一区二区三区资源| 国产日产精品1区| 欧美一区日韩一区| 欧美三级蜜桃2在线观看| 福利一区二区在线观看| 久久精品国产澳门| 男人操女人的视频在线观看欧美| 最新日韩av在线| 欧美国产精品一区二区三区| 欧美一卡2卡3卡4卡| 91麻豆精品国产自产在线| 91免费看`日韩一区二区| 99久久精品国产一区二区三区| 精品一区二区三区av| 久久精品国产精品亚洲红杏| 夜夜精品视频一区二区| 依依成人综合视频|