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

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

?? dibimage.cpp

?? 經典編著《Visual C++數字圖像處理典型算法及實現》光盤源程序。
?? CPP
?? 第 1 頁 / 共 5 頁
字號:
		case 8:
			return 256;
			break;
		default:
			return 0;
			break;
	}
}

/*************************************************************************
 * 函數名稱:
 *   CopyHandle()
 * 參數:
 *   HGLOBAL h          - 要復制的內存區域
 * 返回值:
 *   HGLOBAL            - 復制后的新內存區域
 * 說明:
 *   該函數復制指定的內存區域。返回復制后的新內存區域,出錯時返回0。
 ************************************************************************/
HGLOBAL CDibImage::CopyHandle (HGLOBAL h)
{
	if (h == NULL)
	{
		return NULL;
	}
	
	DWORD dwLen = ::GlobalSize((HGLOBAL) h);	// 獲取指定內存區域大小
	HGLOBAL hCopy = ::GlobalAlloc(GHND, dwLen);	// 分配新內存空間	
	if (hCopy != NULL)							// 判斷分配是否成功
	{
		void* lpCopy = ::GlobalLock((HGLOBAL) hCopy);
		void* lp     = ::GlobalLock((HGLOBAL) h);
		
		memcpy(lpCopy, lp, dwLen);
		
		::GlobalUnlock(hCopy);
		::GlobalUnlock(h);
	}

	return hCopy;
}

/*************************************************************************
 * 函數名稱:
 *   SaveDIB()
 * 參數:
 *   HDIB hDib          - 要保存的DIB
 *   CFile& file        - 保存文件CFile
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE或者CFileException
 * 說明:
 *   該函數將指定的DIB對象保存到指定的CFile中。該CFile由調用程序打開和關閉。
 *************************************************************************/
BOOL CDibImage::SaveDIB(HDIB hDib, CFile& file)
{	
	BITMAPFILEHEADER bmfHdr;	// Bitmap文件頭	
	LPBITMAPINFOHEADER lpBI;	// 指向BITMAPINFOHEADER的指針
	DWORD dwDIBSize;			// DIB大小

	if (hDib == NULL)
	{
		return FALSE;
	}

	// 讀取BITMAPINFO結構,并鎖定
	lpBI = (LPBITMAPINFOHEADER) ::GlobalLock((HGLOBAL) hDib);	
	if (lpBI == NULL)
	{
		return FALSE;
	}
	
	// 判斷是否是WIN3.0 DIB
	if (!IS_WIN30_DIB(lpBI))
	{
		// 不支持其它類型的DIB保存
		::GlobalUnlock((HGLOBAL) hDib);
		return FALSE;
	}

	////////////////////////////////////////////////////////////////////////
	// 填充文件頭///////////////////////////////////////////////////////////	
	bmfHdr.bfType = DIB_HEADER_MARKER;		// 文件類型"BM"

	// 計算DIB大小時,最簡單的方法是調用GlobalSize()函數。但是全局內存大小并
	// 不是DIB真正的大小,它總是多幾個字節。這樣就需要計算一下DIB的真實大小。
	
	// 文件頭大小+顏色表大小
	// (BITMAPINFOHEADER和BITMAPCOREHEADER結構的第一個DWORD都是該結構的大小)
	dwDIBSize = *(LPDWORD)lpBI + PaletteSize((LPSTR)lpBI);
	
	// 計算圖像大小
	if ((lpBI->biCompression == BI_RLE8) || (lpBI->biCompression == BI_RLE4))
	{
		// 對于RLE位圖,沒法計算大小,只能信任biSizeImage內的值
		dwDIBSize += lpBI->biSizeImage;
	}
	else
	{		
		DWORD dwBmBitsSize;			// 象素的大小
		dwBmBitsSize = WIDTHBYTES((lpBI->biWidth)*((DWORD)lpBI->biBitCount)) 
			* lpBI->biHeight;		// 大小為Width * Height
		dwDIBSize += dwBmBitsSize;	// 計算出DIB真正的大小

		// 更新biSizeImage(很多BMP文件頭中biSizeImage的值是錯誤的)
		lpBI->biSizeImage = dwBmBitsSize;
	}

	// 計算文件大小:DIB大小+BITMAPFILEHEADER結構大小
	bmfHdr.bfSize = dwDIBSize + sizeof(BITMAPFILEHEADER);
	
	// 兩個保留字
	bmfHdr.bfReserved1 = 0;
	bmfHdr.bfReserved2 = 0;

	// 計算偏移量bfOffBits,它的大小為Bitmap文件頭大小+DIB頭大小+顏色表大小
	bmfHdr.bfOffBits = (DWORD)sizeof(BITMAPFILEHEADER) + lpBI->biSize
											  + PaletteSize((LPSTR)lpBI);

	/////////////////////////////////////////////////////////////////////////
	// 嘗試寫文件////////////////////////////////////////////////////////////
	TRY
	{		
		file.Write((LPSTR)&bmfHdr, sizeof(BITMAPFILEHEADER));	// 寫文件頭
		file.WriteHuge(lpBI, dwDIBSize);					// 寫DIB頭和象素
	}
	CATCH (CFileException, e)
	{
		::GlobalUnlock((HGLOBAL) hDib);
		THROW_LAST();
	}
	END_CATCH
	
	::GlobalUnlock((HGLOBAL) hDib);
	return TRUE;
}

/*************************************************************************
 * 函數名稱:
 *   ReadDIBFile()
 * 參數:
 *   CFile& file        - 要讀取得文件文件CFile
 * 返回值:
 *   HDIB               - 成功返回DIB的句柄,否則返回NULL。
 * 說明:
 *   該函數將指定的文件中的DIB對象讀到指定的內存區域中。除BITMAPFILEHEADER
 * 外的內容都將被讀入內存。
 *************************************************************************/
HDIB CDibImage::ReadDIBFile(CFile& file)
{
	BITMAPFILEHEADER bmfHeader;
	HDIB hDIB;
	LPSTR pDIB;
	DWORD dwBitsSize;

	dwBitsSize = file.GetLength();		// 獲取DIB(文件)長度(字節)

	// 嘗試讀取DIB文件頭
	if (file.Read((LPSTR)&bmfHeader, sizeof(bmfHeader)) != sizeof(bmfHeader))
	{
		return NULL;
	}
	// 判斷是否是DIB對象,檢查頭兩個字節是否是"BM"
	if (bmfHeader.bfType != DIB_HEADER_MARKER)
	{
		return NULL;
	}
	// 為DIB分配內存
	hDIB = (HDIB) ::GlobalAlloc(GMEM_MOVEABLE | GMEM_ZEROINIT, dwBitsSize);
	if (hDIB == 0)
	{
		return NULL;
	}
	
	pDIB = (LPSTR) ::GlobalLock((HGLOBAL) hDIB);
	if (file.ReadHuge(pDIB, dwBitsSize - sizeof(BITMAPFILEHEADER)) !=
		dwBitsSize - sizeof(BITMAPFILEHEADER) )		// 讀象素
	{
		::GlobalUnlock((HGLOBAL) hDIB);
		::GlobalFree((HGLOBAL) hDIB);
		return NULL;
	}

	::GlobalUnlock((HGLOBAL) hDIB);
	return hDIB;
}

//////////////////////////////////////////////////////////////////////
// 圖像點運算函數
//////////////////////////////////////////////////////////////////////

/*************************************************************************
 * 函數名稱:
 *   LinerTrans()
 * 參數:
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素數)
 *   LONG  lHeight      - 源圖像高度(象素數)
 *   FLOAT fA		    - 線性變換的斜率
 *   FLOAT fB           - 線性變換的截距
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 * 說明:
 *   該函數用來對圖像進行灰度的線性變換操作。
 ************************************************************************/
BOOL CDibImage::LinerTrans(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, 
						   FLOAT fA, FLOAT fB)
{		
	unsigned char*	lpSrc;		// 指向源圖像的指針
	LONG	i;					// 循環變量
	LONG	j;		
	LONG	lLineBytes;			// 圖像每行的字節數	
	FLOAT	fTemp;				// 中間變量	

	lLineBytes = WIDTHBYTES(lWidth * 8);	// 計算圖像每行的字節數
		
	for(i = 0; i < lHeight; i++)			// 每行
	{		
		for(j = 0; j < lWidth; j++)			// 每列
		{
			// 指向DIB第i行,第j個象素的指針
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;			
			fTemp = fA * (*lpSrc) + fB;		// 線性變換	
			
			if (fTemp > 255)				// 判斷是否超出范圍
			{
				*lpSrc = 255;
			}
			else if (fTemp < 0)
			{
				*lpSrc = 0;
			}
			else
			{				
				*lpSrc = (unsigned char) (fTemp + 0.5);	// 四舍五入
			}
		}
	}
	
	return TRUE;
}

/*************************************************************************
 * 函數名稱:
 *   ThresholdTrans()
 * 參數:
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素數)
 *   LONG  lHeight      - 源圖像高度(象素數)
 *   BYTE  bThre	    - 閾值
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 * 說明:
 *   該函數用來對圖像進行閾值變換。對于灰度值小于閾值的象素直接設置
 * 灰度值為0;灰度值大于閾值的象素直接設置為255。
 ************************************************************************/
BOOL CDibImage::ThresholdTrans(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, BYTE bThre)
{	
	unsigned char*	lpSrc;				// 指向源圖像的指針	
	LONG	i;							// 循環變量
	LONG	j;	
	LONG	lLineBytes;					// 圖像每行的字節數
		
	lLineBytes = WIDTHBYTES(lWidth * 8);// 計算圖像每行的字節數	
	
	for(i = 0; i < lHeight; i++)		// 每行
	{		
		for(j = 0; j < lWidth; j++)		// 每列
		{
			// 指向DIB第i行,第j個象素的指針
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;			
			
			if ((*lpSrc) < bThre)		// 判斷是否小于閾值
			{
				*lpSrc = 0;
			}
			else
			{
				*lpSrc = 255;
			}
		}
	}
	
	return TRUE;
}

/*************************************************************************
 * 函數名稱:
 *   WindowTrans()
 * 參數:
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素數)
 *   LONG  lHeight      - 源圖像高度(象素數)
 *   BYTE  bLow		    - 窗口下限
 *   BYTE  bUp          - 窗口上限
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 * 說明:
 *   該函數用來對圖像進行窗口變換。只有在窗口范圍內的灰度保持不變,
 * 小于下限的象素直接設置灰度值為0;大于上限的象素直接設置灰度值為255。
 ************************************************************************/
BOOL CDibImage::WindowTrans(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, 
							BYTE bLow, BYTE bUp)
{	
	unsigned char*	lpSrc;				// 指向源圖像的指針	
	LONG	i;							// 循環變量
	LONG	j;
	LONG	lLineBytes;					// 圖像每行的字節數
		
	lLineBytes = WIDTHBYTES(lWidth * 8);// 計算圖像每行的字節數	
	
	for(i = 0; i < lHeight; i++)		// 每行
	{	
		for(j = 0; j < lWidth; j++)		// 每列
		{
			// 指向DIB第i行,第j個象素的指針
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;			
			if ((*lpSrc) < bLow)		// 判斷是否超出范圍
			{
				*lpSrc = 0;
			}
			else if ((*lpSrc) > bUp)
			{
				*lpSrc = 255;
			}
		}
	}
	
	return TRUE;
}

/*************************************************************************
 * 函數名稱:
 *   GrayStretch()
 * 參數:
 *   LPSTR lpDIBBits    - 指向源DIB圖像指針
 *   LONG  lWidth       - 源圖像寬度(象素數)
 *   LONG  lHeight      - 源圖像高度(象素數)
 *   BYTE bX1			- 灰度拉伸第一個點的X坐標
 *   BYTE bY1			- 灰度拉伸第一個點的Y坐標
 *   BYTE bX2			- 灰度拉伸第二個點的X坐標
 *   BYTE bY2			- 灰度拉伸第二個點的Y坐標
 * 返回值:
 *   BOOL               - 成功返回TRUE,否則返回FALSE。
 * 說明:
 *   該函數用來對圖像進行灰度拉伸。
 ************************************************************************/
BOOL CDibImage::GrayStretch(LPSTR lpDIBBits, LONG lWidth, LONG lHeight, 
							BYTE bX1, BYTE bY1, BYTE bX2, BYTE bY2)
{	
	unsigned char*	lpSrc;				// 指向源圖像的指針
	LONG	i;							// 循環變量
	LONG	j;	
	BYTE	bMap[256];					// 灰度映射表	
	LONG	lLineBytes;					// 圖像每行的字節數
	
	lLineBytes = WIDTHBYTES(lWidth * 8);// 計算圖像每行的字節數
	
	// 計算灰度映射表
	for (i = 0; i <= bX1; i++)
	{		
		if (bX1 > 0)					// 判斷bX1是否大于0(防止分母為0)
		{
			bMap[i] = (BYTE) bY1 * i / bX1;
		}
		else
		{
			bMap[i] = 0;
		}
	}
	for (; i <= bX2; i++)
	{
		if (bX2 != bX1)					// 判斷bX1是否等于bX2(防止分母為0)
		{
			bMap[i] = bY1 + (BYTE) ((bY2 - bY1) * (i - bX1) / (bX2 - bX1));
		}
		else
		{
			bMap[i] = bY1;
		}
	}
	for (; i < 256; i++)
	{	
		if (bX2 != 255)					// 判斷bX2是否等于255(防止分母為0)
		{
			bMap[i] = bY2 + (BYTE) ((255 - bY2) * (i - bX2) / (255 - bX2));
		}
		else
		{
			bMap[i] = 255;
		}
	}
		
	for(i = 0; i < lHeight; i++)		// 每行
	{		
		for(j = 0; j < lWidth; j++)		// 每列
		{
			// 指向DIB第i行,第j個象素的指針
			lpSrc = (unsigned char*)lpDIBBits + lLineBytes * (lHeight - 1 - i) + j;			
			// 計算新的灰度值
			*lpSrc = bMap[*lpSrc];
		}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99精品久久久久久| 蜜臀国产一区二区三区在线播放| 国产精品一二三| 中文字幕精品一区 | 视频在线观看国产精品| 欧美三级午夜理伦三级中视频| 午夜视频一区二区| 日韩网站在线看片你懂的| 国产乱人伦精品一区二区在线观看| 欧美经典一区二区| 91女厕偷拍女厕偷拍高清| 亚洲男人电影天堂| 日韩一区二区视频| 高清不卡一二三区| 一区二区三区视频在线观看| 欧美一级欧美一级在线播放| 国产一区福利在线| 一区二区三区中文免费| 日韩一区二区免费电影| 成人国产精品免费观看动漫| 亚洲国产精品精华液网站| 日韩精品一区二区三区视频在线观看 | 麻豆精品一区二区三区| 欧美国产日本韩| 欧美三级电影在线观看| 精品无码三级在线观看视频| 椎名由奈av一区二区三区| 91精品国产乱码| 99久久精品国产观看| 美女视频一区二区| 亚洲美女在线一区| 久久嫩草精品久久久精品一| 在线日韩av片| 成人综合激情网| 日韩国产一二三区| 一区在线播放视频| 日韩精品一区二区三区中文精品 | 色狠狠一区二区| 国产另类ts人妖一区二区| 亚洲综合自拍偷拍| 国产精品丝袜一区| 日韩精品一区二| 欧美性视频一区二区三区| 成人在线综合网站| 久久国产精品免费| 天天影视色香欲综合网老头| 国产精品久久久久婷婷二区次| 欧美一区二区三区视频在线观看| 99久久国产综合色|国产精品| 久久99精品国产麻豆不卡| 亚洲国产精品影院| 国产精品白丝在线| 国产日韩欧美制服另类| 欧美mv日韩mv| 欧美电影一区二区三区| 在线免费亚洲电影| 91丨porny丨中文| 成人黄色在线看| 国产mv日韩mv欧美| 精品亚洲免费视频| 免费不卡在线视频| 三级欧美在线一区| 午夜精品久久久久久| 亚洲国产va精品久久久不卡综合| 亚洲欧洲在线观看av| 国产精品久久久久婷婷二区次| 精品国产99国产精品| 欧美成人伊人久久综合网| 欧美日韩成人高清| 欧美日韩精品系列| 欧美日韩不卡一区二区| 在线播放一区二区三区| 67194成人在线观看| 欧美性大战久久久久久久蜜臀| 91啦中文在线观看| 91美女在线视频| 色播五月激情综合网| 色视频一区二区| 在线视频国内自拍亚洲视频| 91久久精品一区二区三区| 欧洲精品在线观看| 欧美性猛交一区二区三区精品| 欧美色男人天堂| 在线不卡一区二区| 欧美大肚乱孕交hd孕妇| ww亚洲ww在线观看国产| 国产色产综合色产在线视频| 欧美色老头old∨ideo| 国产不卡视频在线播放| 亚洲一区二区在线观看视频| 久久疯狂做爰流白浆xx| 国产麻豆精品theporn| 欧美一级黄色片| 日本一区二区三区dvd视频在线| 国产精品电影一区二区三区| 美女一区二区三区在线观看| 日韩精品视频网| 蜜桃视频在线观看一区| 亚洲成人动漫一区| 激情文学综合插| 国精品**一区二区三区在线蜜桃| 日韩一区二区三区视频在线观看| 亚洲精品一区在线观看| 国产丝袜欧美中文另类| 亚洲影院久久精品| 蜜桃av噜噜一区| 国产精品欧美久久久久一区二区 | 欧美性受xxxx黑人xyx| 欧美精品高清视频| 久久久久久日产精品| 亚洲视频在线观看三级| 日韩专区中文字幕一区二区| 国产一区91精品张津瑜| 一本一本久久a久久精品综合麻豆 一本一道波多野结衣一区二区 | 亚洲精品午夜久久久| 男人的天堂久久精品| 懂色av一区二区三区免费观看| 色综合久久久久久久久久久| 91精品在线麻豆| 国产欧美日本一区二区三区| 婷婷综合另类小说色区| 高清成人在线观看| 日韩欧美在线观看一区二区三区| 国产精品电影一区二区| 麻豆精品久久精品色综合| 色综合久久中文综合久久97| 久久久不卡影院| 偷拍一区二区三区四区| 99re热这里只有精品视频| 日韩欧美精品在线视频| 一区二区三区在线高清| 国产成人在线视频免费播放| 91精品国产欧美一区二区| 亚洲精品日韩专区silk| 国产精一品亚洲二区在线视频| 欧美美女直播网站| 亚洲图片欧美激情| 国产成人一区在线| 日韩一级免费一区| 亚洲国产精品嫩草影院| 9色porny自拍视频一区二区| 日韩精品一区二区三区四区| 亚洲国产sm捆绑调教视频 | 久久综合成人精品亚洲另类欧美 | 久久久久一区二区三区四区| 日韩中文字幕av电影| 色综合天天狠狠| 欧美极品aⅴ影院| 国产一区欧美二区| 日韩一区二区三区视频在线观看| 亚洲v中文字幕| 欧美日韩一卡二卡三卡| 亚洲一区二区三区三| 成人免费视频caoporn| 国产日韩欧美一区二区三区乱码 | 国产在线精品不卡| 欧美成人一区二区三区片免费| 日韩中文字幕1| 欧美日韩国产天堂| 亚洲国产成人tv| 欧美日韩三级一区| 亚洲最新视频在线观看| 色偷偷一区二区三区| 亚洲免费在线看| 91国偷自产一区二区三区成为亚洲经典 | 欧美久久久一区| 日韩高清不卡一区二区| 宅男在线国产精品| 麻豆freexxxx性91精品| 日韩一区二区三区免费看 | 国产欧美日韩一区二区三区在线观看| 黑人巨大精品欧美一区| ww亚洲ww在线观看国产| 国产福利精品一区| 国产精品免费看片| 色综合激情久久| 午夜精品福利一区二区蜜股av | 欧美大度的电影原声| 国产又粗又猛又爽又黄91精品| 久久久久久久久一| 99久久综合精品| 亚洲一区成人在线| 91精品欧美一区二区三区综合在| 免费高清不卡av| 久久精品亚洲麻豆av一区二区| 成人国产在线观看| 亚洲国产综合91精品麻豆| 欧美一二三区精品| 国产成人在线电影| 亚洲美女屁股眼交| 日韩色在线观看| 成人开心网精品视频| 亚洲自拍偷拍av| 精品第一国产综合精品aⅴ| 风流少妇一区二区| 夜夜爽夜夜爽精品视频| 欧美一二三区精品| 99久久国产免费看| 日韩激情视频网站| 4438x成人网最大色成网站|