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

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

?? dib.cpp

?? 有用的MATLAB圖像處理程序
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
{
	int nBitCount;

	// 對于Windows的DIB, 實際顏色的數目可以比象素的位數要少。
	// 對于這種情況,則返回一個近似的數值。
	
	// 判斷是否是WIN3.0 DIB
	if (IS_WIN30_DIB(lpbi))
	{
		// 讀取dwClrUsed值
		DWORD dwClrUsed = ((LPBITMAPINFOHEADER)lpbi)->biClrUsed;
		
		if (dwClrUsed != 0)
		{
			// 如果dwClrUsed(實際用到的顏色數)不為0,直接返回該值
			return (WORD)dwClrUsed;
		}
	}

	// 讀取象素的位數
	if (IS_WIN30_DIB(lpbi))
	{
		// 讀取biBitCount值
		nBitCount = ((LPBITMAPINFOHEADER)lpbi)->biBitCount;
	}
	else
	{
		// 讀取biBitCount值
		nBitCount = ((LPBITMAPCOREHEADER)lpbi)->bcBitCount;
	}
	
	// 按照象素的位數計算顏色數目
	switch (nBitCount)
	{
		case 1:
			return 2;

		case 4:
			return 16;

		case 8:
			return 256;
		default:
			return 0;
	}
}


/*************************************************************************
 *
 * 函數名稱:
 *   DIBBitCount()
 *
 * 參數:
 *   LPBYTE lpbi        - 指向DIB對象的指針
 *
 * 返回值:
 *   WORD               - 返回調色板中顏色的種數
 *
 * 說明:
 *   該函數返回DIBBitCount。
 *
 ************************************************************************/

WORD CDIB::DIBBitCount(LPBYTE lpbi)
{
	int nBitCount;

	// 讀取象素的位數
	if (IS_WIN30_DIB(lpbi))
	{
		// 讀取biBitCount值
		nBitCount = ((LPBITMAPINFOHEADER)lpbi)->biBitCount;
	}
	else
	{
		// 讀取biBitCount值
		nBitCount = ((LPBITMAPCOREHEADER)lpbi)->bcBitCount;
	}
	
	// 返回nBitCount
	return nBitCount;
}


/*************************************************************************
 *
 * 函數名稱:
 *   CopyHandle()
 *
 * 參數:
 *   HGLOBAL h          - 要復制的內存區域
 *
 * 返回值:
 *   HGLOBAL            - 復制后的新內存區域
 *
 * 說明:
 *   拷貝內存塊
 *
 ************************************************************************/

HGLOBAL CDIB::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保存到指定文件中
 *
 *************************************************************************/

BOOL CDIB::SaveDIB(HDIB hDib, CFile& file)
{
	// Bitmap文件頭
	BITMAPFILEHEADER bmfHdr;
	
	// 指向BITMAPINFOHEADER的指針
	LPBITMAPINFOHEADER lpBI;

	if (hDib == NULL)
	{
		// 如果DIB為空,返回FALSE
		return FALSE;
	}

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

	// 填充文件頭

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

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

		// 更新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((LPBYTE)lpBI);

	// 嘗試寫文件
	TRY
	{
		// 寫文件頭
		file.Write((LPBYTE)&bmfHdr, sizeof(BITMAPFILEHEADER));
		
		// 寫DIB頭和象素
		file.WriteHuge(lpBI, dwDIBSize);
	}
	CATCH (CFileException, e)
	{
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDib);
		
		// 拋出異常
		THROW_LAST();
	}
	END_CATCH
	
	// 解除鎖定
	::GlobalUnlock((HGLOBAL) hDib);
	
	// 返回TRUE
	return TRUE;
}


/*************************************************************************
 *
 * 函數名稱:
 *   ReadDIBFile()
 *
 * 參數:
 *   CFile& file        - 要讀取得文件文件CFile
 *
 * 返回值:
 *   HDIB               - 成功返回DIB的句柄,否則返回NULL。
 *
 * 說明:
 *   重指定文件中讀取DIB對象
 *
 *************************************************************************/

HDIB CDIB::ReadDIBFile(CFile& file)
{
	BITMAPFILEHEADER bmfHeader;
	HDIB hDIB;
	LPBYTE lpDIB;

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

	// 嘗試讀取DIB文件頭
	if (file.Read((LPBYTE)&bmfHeader, sizeof(bmfHeader)) != sizeof(bmfHeader))
	{
		// 大小不對,返回NULL。
		return NULL;
	}

	// 判斷是否是DIB對象,檢查頭兩個字節是否是"BM"
	if (bmfHeader.bfType != DIB_HEADER_MARKER)
	{
		// 非DIB對象,返回NULL。
		return NULL;
	}

	// 為DIB分配內存
	hDIB = (HDIB) ::GlobalAlloc(GMEM_MOVEABLE | GMEM_ZEROINIT, dwBitsSize);
	if (hDIB == 0)
	{
		// 內存分配失敗,返回NULL。
		return NULL;
	}
	
	// 鎖定
	lpDIB = (LPBYTE) ::GlobalLock((HGLOBAL) hDIB);

	// 讀象素
	if (file.ReadHuge(lpDIB, dwBitsSize - sizeof(BITMAPFILEHEADER)) !=
		dwBitsSize - sizeof(BITMAPFILEHEADER) )
	{
		// 大小不對。
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDIB);
		
		// 釋放內存
		::GlobalFree((HGLOBAL) hDIB);
		
		// 返回NULL。
		return NULL;
	}
	
	// 解除鎖定
	::GlobalUnlock((HGLOBAL) hDIB);
	 
	// 返回DIB句柄
	return hDIB;
}


/*************************************************************************
 *
 * 函數名稱:
 *   SetRgnColor()
 *
 * 參數:	
 *   HDIB hDIB			- 要讀取的文件
 *	 CRect rect			- 設置的矩形區
 *	 COLORREF col		- 填充的顏色
 *
 * 返回值:
 *   無返回值
 *
 * 說明:
 *   該函數用指定的顏色填充指定的區域
 *
 *************************************************************************/

void CDIB::SetRgnColor(HDIB hDIB, CRect rect, COLORREF col)
{
	// 循環變量
	LONG i;
	LONG j;

	// 指向DIB的指針
	LPBYTE lpDIB;
	
	// 指向DIB象素指針
	LPBYTE lpDIBBits;
	
	// 鎖定DIB
	lpDIB = (LPBYTE) ::GlobalLock((HGLOBAL) hDIB);

	// 找到DIB圖像象素起始位置
	lpDIBBits = FindDIBBits(lpDIB);

	// DIB的寬度
	LONG lWidth = DIBWidth(lpDIB);
	
	// DIB的高度
	LONG lHeight = DIBHeight(lpDIB);
	
	// 計算圖像每行的字節數
	LONG lLineBytes = WIDTHBYTES(lWidth * 24);

	// 對區域進行顏色填充
	for (i = lHeight - rect.bottom; i < lHeight - rect.top; i++)
	{
		for (j = rect.left * 3; j < rect.right * 3; j++)
		{
			*(unsigned char *)(lpDIBBits + lLineBytes * i + j) = GetBValue(col);
			j++;
			*(unsigned char *)(lpDIBBits + lLineBytes * i + j) = GetGValue(col);
			j++;
			*(unsigned char *)(lpDIBBits + lLineBytes * i + j) = GetRValue(col);
		}
	}

	// 解除鎖定
	::GlobalUnlock((HGLOBAL) hDIB);
}


/*************************************************************************
 *
 * 函數名稱:
 *   SetCircleColor()
 *
 * 參數:	
 *   HDIB hDIB			- 要讀取的文件
 *	 CRect rect			- 設置的矩形區
 *	 COLORREF col		- 填充的顏色
 *
 * 返回值:
 *   無返回值
 *
 * 說明:
 *   該函數用指定的顏色填充指定的圓形區域
 *
 *************************************************************************/

void CDIB::SetCircleColor(HDIB hDIB, CRect rect, COLORREF col)
{
	// 循環變量
	LONG i;
	LONG j;

	// 指向DIB的指針
	LPBYTE lpDIB;
	
	// 指向DIB象素指針
	LPBYTE lpDIBBits;
	
	// 鎖定DIB
	lpDIB = (LPBYTE) ::GlobalLock((HGLOBAL) hDIB);

	// 找到DIB圖像象素起始位置
	lpDIBBits = FindDIBBits(lpDIB);

	// DIB的寬度
	LONG lWidth = DIBWidth(lpDIB);
	
	// DIB的高度
	LONG lHeight = DIBHeight(lpDIB);
	
	// 計算圖像每行的字節數
	LONG lLineBytes = WIDTHBYTES(lWidth * 24);

	// 中間變量
	int cx, cy, dr;

	// 對圓形區域進行顏色填充
	for (i = lHeight - rect.bottom; i < lHeight - rect.top; i++)
	{
		for (j = rect.left; j < rect.right; j ++)
		{
			cx = abs(j - rect.left - 8);
			cy = abs(i - lHeight + rect.bottom - 8);
			dr = cx * cx + cy * cy;
			if (dr > 64 || i < 0 || i > lHeight || j < 0 || j > lWidth)
				continue;
			*(unsigned char *)(lpDIBBits + lLineBytes * i + j * 3) = GetBValue(col);
			*(unsigned char *)(lpDIBBits + lLineBytes * i + j * 3 + 1) = GetGValue(col);
			*(unsigned char *)(lpDIBBits + lLineBytes * i + j * 3 + 2) = GetRValue(col);
		}
	}

	// 解除鎖定
	::GlobalUnlock((HGLOBAL) hDIB);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人av免费在线| 日韩精品在线一区| 日韩久久精品一区| 亚洲欧美日韩电影| 韩国中文字幕2020精品| 色8久久人人97超碰香蕉987| 久久久噜噜噜久久中文字幕色伊伊| 一区二区三区在线视频免费 | 亚洲黄色在线视频| 蜜桃视频一区二区三区| 色婷婷综合激情| 中文字幕一区免费在线观看| 精品一二三四在线| 91精品欧美一区二区三区综合在| 亚洲欧美另类久久久精品| 国产成人在线免费观看| 欧美电影影音先锋| 亚洲成人免费在线观看| 91老司机福利 在线| 国产欧美一区二区三区网站| 久久99国产精品免费网站| 欧美日韩国产免费| 亚洲一区av在线| 91电影在线观看| 亚洲精品久久久蜜桃| jlzzjlzz欧美大全| 亚洲欧洲av在线| 成a人片国产精品| 国产精品白丝在线| 99精品国产热久久91蜜凸| 欧美激情一区二区三区在线| 国产+成+人+亚洲欧洲自线| 久久免费看少妇高潮| 九九在线精品视频| 日韩欧美一区二区不卡| 麻豆精品视频在线观看视频| 欧美另类videos死尸| 婷婷久久综合九色综合伊人色| 欧美在线免费视屏| 亚洲一卡二卡三卡四卡无卡久久| 99riav久久精品riav| 最新久久zyz资源站| 不卡视频一二三| 一区二区三区四区乱视频| 欧美最猛性xxxxx直播| 石原莉奈在线亚洲三区| 日韩欧美国产一区二区三区 | 狠狠色丁香九九婷婷综合五月| 欧美不卡视频一区| 成人深夜视频在线观看| 亚洲精品高清在线观看| 7777精品久久久大香线蕉| 精品在线观看视频| 国产精品久久久久影院| 欧洲激情一区二区| 免费观看日韩av| 久久精品人人做人人综合| 99国产一区二区三精品乱码| 亚洲国产wwwccc36天堂| 日韩精品一区二区三区老鸭窝| 国产99久久久国产精品| 亚洲男帅同性gay1069| 欧美卡1卡2卡| 成人性视频免费网站| 亚洲自拍与偷拍| 久久噜噜亚洲综合| 欧美午夜精品免费| 国产精品69毛片高清亚洲| 1区2区3区精品视频| 欧美一区二区三区四区在线观看| 成熟亚洲日本毛茸茸凸凹| 亚洲va韩国va欧美va| 欧美激情一区二区三区在线| 欧美久久一二三四区| 成人激情免费电影网址| 麻豆精品视频在线观看| 亚洲欧美视频在线观看| 久久一区二区三区四区| 欧美视频你懂的| 成人99免费视频| 久久国产精品99久久久久久老狼| 亚洲乱码国产乱码精品精小说| 精品蜜桃在线看| 欧美无砖专区一中文字| 东方aⅴ免费观看久久av| 青青草原综合久久大伊人精品优势| 国产精品伦理一区二区| 精品久久久久久久久久久院品网| 欧美性猛交一区二区三区精品 | 中文字幕在线一区| 日韩美女一区二区三区| 色国产精品一区在线观看| 国产伦精品一区二区三区免费迷 | 成人国产在线观看| 男男成人高潮片免费网站| 夜夜嗨av一区二区三区| 中文成人av在线| 精品久久久久99| 欧美一二三四区在线| 欧美日韩高清一区二区不卡| 一本大道久久a久久精二百| 国产精品77777| 国产乱人伦偷精品视频不卡| 蜜桃视频一区二区| 日本aⅴ免费视频一区二区三区| 一区二区三区成人| 中文字幕制服丝袜成人av| 中文幕一区二区三区久久蜜桃| 国产亚洲综合在线| wwwwww.欧美系列| 精品国产露脸精彩对白 | 国产很黄免费观看久久| 久久99久久99精品免视看婷婷 | 精品久久一区二区三区| 欧美一区二区三区四区高清| 日韩一区二区在线观看视频播放| 欧美丰满一区二区免费视频| 欧美三区在线视频| 欧美三区免费完整视频在线观看| 欧美视频精品在线观看| 91精品欧美综合在线观看最新 | 亚洲美女淫视频| 亚洲男同性恋视频| 亚洲国产欧美另类丝袜| 日韩av成人高清| 久久精品国产免费看久久精品| 精品在线亚洲视频| 国产一区二区91| 99久久久久免费精品国产| 欧美亚洲一区二区在线| 在线91免费看| 26uuu国产电影一区二区| 国产欧美日本一区视频| 国产精品视频麻豆| 亚洲精品日韩综合观看成人91| 午夜欧美在线一二页| 久久91精品久久久久久秒播| 国产精品一区二区在线观看网站 | 国产**成人网毛片九色| 色综合久久中文综合久久97| 欧美精品三级日韩久久| 久久精品一区二区三区不卡牛牛| 国产精品色在线观看| 亚洲国产毛片aaaaa无费看 | 日韩中文字幕1| 国产真实精品久久二三区| www.欧美日韩国产在线| 欧美性一二三区| 精品国产91洋老外米糕| 亚洲视频一区二区在线| 久久激五月天综合精品| 91香蕉视频黄| 欧美一区午夜精品| 国产精品久久久久影院色老大| 午夜精品免费在线| 国产伦精品一区二区三区免费| 欧美专区日韩专区| 国产日产欧美一区二区视频| 亚洲国产欧美另类丝袜| 成人美女在线观看| 欧美一三区三区四区免费在线看 | 91电影在线观看| 久久婷婷成人综合色| 亚洲一区在线播放| 成人高清免费观看| 日韩欧美久久久| 亚洲国产一区二区在线播放| 成人久久久精品乱码一区二区三区 | 亚洲综合成人在线视频| 精品一区二区三区免费播放| 91国偷自产一区二区三区成为亚洲经典 | 午夜亚洲福利老司机| 成人免费毛片app| 日韩欧美国产小视频| 亚洲福利一二三区| 波多野结衣在线一区| 久久这里只有精品视频网| 亚洲国产成人av| 色综合天天综合网天天狠天天| 国产香蕉久久精品综合网| 麻豆精品一区二区三区| 欧美精品免费视频| 亚洲激情中文1区| 91视视频在线观看入口直接观看www | 欧美日韩在线一区二区| 亚洲日本在线观看| 99久久精品费精品国产一区二区| 亚洲精品一区二区在线观看| 老司机一区二区| 制服丝袜国产精品| 亚洲福利一二三区| 欧美视频一区在线| 亚洲一区二区免费视频| 在线视频你懂得一区二区三区| 亚洲丝袜美腿综合| 91小视频免费观看| 亚洲色图都市小说| a级高清视频欧美日韩| 欧美激情在线看| 北条麻妃国产九九精品视频|