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

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

?? dibprcs.cpp

?? 經典編著《Visual C++數字圖像處理典型算法及實現》光盤源程序。
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
/*************************************************************************
 * 文件DIBPrcs.cpp用來存放有關DIB的操作函數
 * 文件頭存放在GlobalApi.h中
 *************************************************************************
 */

#include "GlobalApi.h"
#include "stdafx.h"
#include "cdib.h"



/*************************************************************************
 *
 * \函數名稱:
 *   GetSystemPalette()
 *
 * \輸入參數:
 *   無
 *
 * \返回值:
 *   HPALETTE				- 系統調色板句柄
 *
 * \說明:
 *   該函數獲得當前正在使用的系統調色板的句柄
 *
 *************************************************************************
 */
HPALETTE GetSystemPalette() 
{ 
	// 設備上下文
	HDC hDC;                

	// 聲明調色板句柄、指針等臨時變量
	static HPALETTE hPal = NULL;   
	HANDLE hLogPal;         
	LPLOGPALETTE lpLogPal;  

	// 當前系統調色板的顏色數
	int nColors;            
 
    	// 獲得當前系統設備上下文
	hDC = GetDC(NULL); 
	if (!hDC) 
		return NULL; 
 
	// 獲得當前系統調色板的顏色數目
	nColors = ( 1 << (GetDeviceCaps(hDC, BITSPIXEL) * GetDeviceCaps(hDC, PLANES)));
    
	// 給調色板分配內存
	hLogPal = GlobalAlloc(GHND, sizeof(LOGPALETTE) + nColors * 
		sizeof(PALETTEENTRY)); 
	if (!hLogPal) 
		return NULL; 
 
	// 得到調色板內存指針
	lpLogPal = (LPLOGPALETTE)GlobalLock(hLogPal); 
 
	// 設置調色板信息
	lpLogPal->palVersion = 0x300; 
	lpLogPal->palNumEntries = nColors; 
 
	// 將系統的調色板拷貝到當前的邏輯調色板中
	GetSystemPaletteEntries(hDC, 0, nColors, 
            (LPPALETTEENTRY)(lpLogPal->palPalEntry)); 
 
	// 創建Windows調色板
	hPal = CreatePalette(lpLogPal); 
 
	// 釋放已分配內存并刪除臨時對象
	GlobalUnlock(hLogPal); 
	GlobalFree(hLogPal); 
	ReleaseDC(NULL, hDC); 
 
	// 返回
	return hPal; 
} 
 

/*************************************************************************
 *
 * \函數名稱:
 *   CopyPalette
 *
 * \輸入參數:
 *   HPALETTE	hPalSrc			- 需要拷貝的源調色板句柄
 *
 * \返回值:
 *   HPALETTE				- 如果操作成功,則返回拷貝的調色板句柄
 *
 * \說明:
 *   該函數將創建一個新的調色板,并從指定的調色板拷貝調色板內容
 *
 *************************************************************************
 */
HPALETTE CopyPalette(HPALETTE hPalSrc)
{
	// 調色板指針,臨時變量
	PLOGPALETTE     plogPal;

	// 聲明一個調色板句柄和一個臨時句柄
	HPALETTE        hPalette;
	HANDLE		hTemp;

	// 調色板表項數
	int             iNumEntries=0;
    
	// 獲取調色板中的表項數
	iNumEntries = GetPaletteEntries(hPalSrc, 0, iNumEntries, NULL);
	if (iNumEntries == 0) 
		return (HPALETTE) NULL;

	// 分配調色板內存,得到句柄
	hTemp = GlobalAlloc(GHND, sizeof(DWORD) + sizeof(PALETTEENTRY)*iNumEntries);
	if (! hTemp)
		return (HPALETTE) NULL;

	// 得到調色板的指針
	plogPal = (PLOGPALETTE)GlobalLock(hTemp);
	if (! plogPal) 
		return (HPALETTE) NULL;

	// 設置調色板的信息
	plogPal->palVersion = 0x300;
	plogPal->palNumEntries = (WORD) iNumEntries;
    
	// 獲取邏輯調色板中指定范圍的調色板表項
	GetPaletteEntries(hPalSrc, 0, iNumEntries, plogPal->palPalEntry);

	// 創建一個Windows調色板
	hPalette = CreatePalette(plogPal);

	// 釋放以分配的內存
	GlobalUnlock( hTemp );
	GlobalFree  ( hTemp );

	return hPalette;
}
 



/*************************************************************************
 *
 * \函數名稱:
 *   ReadDIB
 *
 * \輸入參數:
 *   CFile*			pFile		- 需要打開的DIB文件
 *   LPBITMAPINFOHEADER*	pLpBMIH		- DIB信息頭指針的指針
 *   LPBYTE*			pLpImage	- DIB位圖數據塊指針的指針
 *
 * \返回值:
 *   BOOL				- 如果操作成功,則返回TRUE
 *
 * \說明:
 *   該函數將指定文件中的DIB文件載入,其中信息頭和調色板放在*pLpBMIH中
 *   圖象數據存放到*pLpImage中。
 *
 *************************************************************************
 */
 BOOL ReadDIB(CFile* pFile, LPBITMAPINFOHEADER* pLpBMIH, LPBYTE* pLpImage)
 {
	 // 臨時存放信息的變量
 	int nCount, nSize;
	BITMAPFILEHEADER bmfh;

	// 信息頭指針
	//LPBITMAPINFOHEADER lpBMIH;

	// DIB圖象數據指針
	//LPBYTE lpImage;

	// 進行讀操作
	try 
	{
		// 讀取文件頭
		nCount = pFile->Read((LPVOID) &bmfh, sizeof(BITMAPFILEHEADER));
		if(nCount != sizeof(BITMAPFILEHEADER)) {
			throw new CException;
		}

		// 如果文件類型部位"BM",則返回并進行相應錯誤處理
		if(bmfh.bfType != 0x4d42) {
			throw new CException;
		}

		// 計算信息頭加上調色板的大小,并分配相應的內存
		nSize = bmfh.bfOffBits - sizeof(BITMAPFILEHEADER);
		*pLpBMIH = (LPBITMAPINFOHEADER) new char[nSize];

		// 讀取信息頭和調色板
		nCount = pFile->Read(*pLpBMIH, nSize); 

		// 計算圖象數據大小并設置調色板指針
		if((*pLpBMIH)->biSize != sizeof(BITMAPINFOHEADER)) {
			TRACE("Not a valid Windows bitmap -- probably an OS/2 bitmap\n");
			throw new CException;
		}

		// 如果圖象數據內存大小為0,則重新計算
		if((*pLpBMIH)->biSizeImage == 0) {
			DWORD dwBytes = ((DWORD) (*pLpBMIH)->biWidth * (*pLpBMIH)->biBitCount) / 32;
			if(((DWORD) (*pLpBMIH)->biWidth * (*pLpBMIH)->biBitCount) % 32) {
				dwBytes++;
			}
			dwBytes *= 4;
			(*pLpBMIH)->biSizeImage = dwBytes * (*pLpBMIH)->biHeight;	
		}
		
		// 分配圖象數據內存,并從文件中讀取圖象數據
		*pLpImage = (LPBYTE) new char[(*pLpBMIH)->biSizeImage];
		nCount = pFile->Read((*pLpImage), (*pLpBMIH)->biSizeImage); 
	}

	// 錯誤處理
	catch(CException* pe) 
	{
		AfxMessageBox("Read error");
		pe->Delete();
		return FALSE;
	}

	// 將指針賦值

	// 返回
	return TRUE;


 }


 /*************************************************************************
 *
 * \函數名稱:
 *   MakeDIBPalette()
 *
 * \輸入參數:
 *   LPVOID		lpvColorTable	- 顏色表指針
 *   LPBITMAPINFOHEADER lpBMIH		- DIB信息頭指針
 *
 * \返回值:
 *   HPALETTE				- 如果成功,則調色板句柄
 *
 * \說明:
 *   該函數將讀取顏色表,并創建一個Windows調色板,并返回此調色板的句柄
 *
 ************************************************************************
 */
HPALETTE MakeDIBPalette(LPVOID lpvColorTable,  LPBITMAPINFOHEADER lpBMIH)
{
	// 調色板句柄
	HPALETTE hPalette = NULL;				

	// 顏色表顏色數
	int nColorTableEntries;
	
	// 設置DIB中的調色板指針
	// lpvColorTable = (LPBYTE) lpBMIH + sizeof(BITMAPINFOHEADER);

	// 計算調色板的表項數
	if(lpBMIH->biClrUsed == 0) {
		switch(lpBMIH->biBitCount) {
			case 1:
				nColorTableEntries = 2;
				break;
			case 4:
				nColorTableEntries = 16;
				break;
			case 8:
				nColorTableEntries = 256;
				break;
			case 16:
			case 24:
			case 32:
				nColorTableEntries = 0;
				break;
			default:
				break;
		}
	}

	// 否則調色板的表項數就是用到的顏色數目
	else {
		nColorTableEntries = lpBMIH->biClrUsed;
	}

	ASSERT((nColorTableEntries >= 0) && (nColorTableEntries <= 256)); 

	// 如果不存在調色板,則返回FALSE
	if(nColorTableEntries == 0) return FALSE;

	// 給邏輯調色板分配內存
	LPLOGPALETTE pLogPal = (LPLOGPALETTE) new char[2 * sizeof(WORD) +
		nColorTableEntries * sizeof(PALETTEENTRY)];

	// 設置邏輯調色板的信息
	pLogPal->palVersion = 0x300;
	pLogPal->palNumEntries = nColorTableEntries;

	// 拷貝DIB中的顏色表到邏輯調色板
	LPRGBQUAD pDibQuad = (LPRGBQUAD) lpvColorTable;
	for(int i = 0; i < nColorTableEntries; i++) {
		pLogPal->palPalEntry[i].peRed = pDibQuad->rgbRed;
		pLogPal->palPalEntry[i].peGreen = pDibQuad->rgbGreen;
		pLogPal->palPalEntry[i].peBlue = pDibQuad->rgbBlue;
		pLogPal->palPalEntry[i].peFlags = 0;
		pDibQuad++;
	}

	// 創建邏輯調色板
	hPalette = ::CreatePalette(pLogPal);

	// 刪除臨時變量
	delete pLogPal;

	// 返回調色板句柄
	return hPalette;
}	

 /*************************************************************************
 *
 * \函數名稱:
 *   PaintDIB()
 *
 * \輸入參數:
 *   CDC*	pDC			- 指向將要接收DIB圖象的設備上下文指針 
 *   LPBITMAPINFOHEADER lpBMIH		- DIB信息頭指針
 *   LPBYTE		lpImage;	- DIB位圖數據塊地址 
 *   CPoint	origin			- 顯示DIB的邏輯坐標
 *   CSize	size			- 顯示矩形的寬度和高度
 *   HPALETTE	hPalette		- 指向DIB的調色板句柄
 *
 * \返回值:
 *   BOOL				- 如果成功,則返回TRUE
 *
 * \說明:
 *   該函數將DIB圖象進行顯示
 *
 ************************************************************************
 */
BOOL PaintDIB(CDC* pDC, LPBITMAPINFOHEADER lpBMIH, LPBYTE lpImage, CPoint origin, CSize size, HPALETTE hPalette)
{
	if(lpBMIH == NULL) return FALSE;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区三区四区在线观看| 成人国产电影网| 欧美精品色一区二区三区| 蜜桃久久久久久久| 国产精品无码永久免费888| 色婷婷av一区二区三区之一色屋| 日韩高清不卡一区| 1区2区3区欧美| 日韩免费成人网| 在线观看视频一区二区| 韩国女主播一区| 亚洲高清免费观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 51精品秘密在线观看| 国产伦精品一区二区三区免费| 亚洲天堂2016| 久久精品视频一区二区三区| 欧美乱妇23p| 欧美一区二区性放荡片| 精品欧美乱码久久久久久| 欧美视频一区二| 91香蕉视频mp4| 国产精品911| 国内精品免费**视频| 国产suv一区二区三区88区| 免费成人av在线播放| 亚洲第一久久影院| 一区二区在线观看视频在线观看| 国产欧美日韩另类一区| 欧美一级二级在线观看| 欧美精品vⅰdeose4hd| 欧美一区二区黄色| 中文字幕一区二区三中文字幕| 亚洲一区二区三区自拍| 亚洲激情在线激情| 麻豆免费精品视频| 91片黄在线观看| 精品国产一区二区三区四区四 | 国产欧美精品一区| 亚洲一区在线免费观看| 精品无人码麻豆乱码1区2区| 美女视频一区在线观看| 成人动漫精品一区二区| 7777精品伊人久久久大香线蕉| 亚洲国产精品传媒在线观看| 久久久.com| 日韩专区一卡二卡| 欧美bbbbb| 日本高清免费不卡视频| 欧美天堂一区二区三区| 国产欧美视频在线观看| 蜜臀av一区二区在线免费观看| 成人动漫在线一区| 精品久久久久久久久久久院品网| 一区二区高清在线| 亚洲123区在线观看| 97久久精品人人做人人爽50路| 91在线观看视频| 国产日本一区二区| 老鸭窝一区二区久久精品| 国产精品亚洲а∨天堂免在线| 欧美日韩精品电影| 日韩午夜av电影| 亚洲一区在线播放| 一本到不卡免费一区二区| 国产亚洲欧美激情| 国产一区二区三区| 日韩精品一区二区三区在线| 亚洲一区二区av在线| 99久久精品免费看国产免费软件| 久久精品亚洲精品国产欧美kt∨ | 精品少妇一区二区三区在线播放| 午夜精品一区二区三区电影天堂| 麻豆国产91在线播放| 欧美日韩激情一区| 五月天亚洲精品| 欧美一卡2卡三卡4卡5免费| 亚洲一区免费视频| 欧美日韩国产123区| 日韩av高清在线观看| 3d成人动漫网站| 美女视频黄a大片欧美| 精品粉嫩超白一线天av| 国产精品亚洲成人| 国产精品美女久久福利网站 | 亚洲综合在线五月| 欧美亚洲国产一区二区三区va| 亚洲图片欧美综合| 欧美一级黄色大片| 国产一区二区三区四区五区入口 | 在线国产电影不卡| 亚洲成人在线观看视频| 日韩美女在线视频| 国产在线精品一区在线观看麻豆| 欧美精品一区在线观看| 成人一区二区三区中文字幕| 欧美成人一区二区三区片免费| 国产一区二区三区观看| 亚洲婷婷综合色高清在线| 色噜噜狠狠色综合欧洲selulu| 亚洲一区二区三区四区五区黄| 欧美一级免费观看| 国产91精品欧美| 亚洲小说欧美激情另类| 精品国产一区二区三区久久影院| 成熟亚洲日本毛茸茸凸凹| 亚洲一区二区三区国产| 精品乱码亚洲一区二区不卡| 成人av一区二区三区| 午夜精品免费在线| 中文字幕免费一区| 欧美日本在线一区| 成人国产精品免费观看| 日韩精品1区2区3区| 国产精品麻豆网站| 日韩色视频在线观看| 91亚洲资源网| 国模套图日韩精品一区二区| 一区二区三区在线免费| 久久综合久久99| 福利一区福利二区| 日韩一区精品视频| 亚洲欧美色图小说| 欧美做爰猛烈大尺度电影无法无天| 蜜桃在线一区二区三区| 亚洲靠逼com| 久久久五月婷婷| 波多野结衣亚洲| 一区二区三区四区在线免费观看 | 成人黄色a**站在线观看| 五月婷婷久久综合| 亚洲人午夜精品天堂一二香蕉| 久久综合色鬼综合色| 欧美日韩不卡视频| 日本精品一区二区三区四区的功能| 国产一区二区三区不卡在线观看 | 久久99精品久久久久| 亚洲一区二区欧美激情| 中文字幕色av一区二区三区| 久久久www成人免费毛片麻豆| 欧美一区在线视频| 欧美午夜电影在线播放| 91丨porny丨国产入口| 福利视频网站一区二区三区| 韩国v欧美v日本v亚洲v| 久久精品免费看| 蜜臀国产一区二区三区在线播放| 亚洲成人久久影院| 亚洲图片欧美综合| 亚洲成人动漫精品| 一区二区三区四区蜜桃| 一区二区三区资源| 亚洲精品一二三| 亚洲一区二区三区激情| 亚洲国产一区二区视频| 亚洲自拍另类综合| 亚洲成av人综合在线观看| 亚洲国产毛片aaaaa无费看 | 日韩精品专区在线| 日韩欧美久久久| 久久综合久久综合久久| 久久精品男人天堂av| 国产精品亲子伦对白| 日韩毛片在线免费观看| 一区二区三区欧美日| 视频一区欧美精品| 精品在线播放免费| 国产91丝袜在线播放九色| 99国产精品久久久久| 91国偷自产一区二区使用方法| 欧美性感一类影片在线播放| 欧美日韩一区二区在线视频| 国产精品69久久久久水密桃| 国产69精品久久777的优势| 成人avav影音| 欧美在线免费观看亚洲| 欧美一区二区免费观在线| 欧美电影免费观看高清完整版| 国产亚洲婷婷免费| 亚洲摸摸操操av| 日本美女视频一区二区| 国产乱色国产精品免费视频| 91最新地址在线播放| 欧美日韩三级一区二区| 亚洲精品在线电影| 亚洲欧洲成人av每日更新| 亚洲永久免费视频| 国产综合久久久久影院| 99在线精品免费| 日韩欧美色电影| 综合电影一区二区三区| 老司机精品视频线观看86| 99久久精品国产一区| 91精品国产综合久久精品性色| 2023国产精品自拍| 亚洲高清三级视频| 成人av在线观| 精品国产91洋老外米糕| 亚洲国产精品天堂| 99国产精品久久久久|