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

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

?? dibprcs.cpp

?? 用VC ++編寫的canny邊緣檢測算子!很不錯的!希望大家下載學習!
?? 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一区二区三区免费野_久草精品视频
亚洲一区二区五区| 99久久婷婷国产综合精品| 老司机午夜精品| 不卡的电影网站| 精品国产一区二区三区av性色 | 国产精品美女久久久久久久久久久 | 五月激情六月综合| 成人妖精视频yjsp地址| 91精品国产综合久久久久久| 亚洲色图视频网| 成人综合婷婷国产精品久久蜜臀| 欧美日本韩国一区| 亚洲综合在线电影| 不卡的av在线| 欧美极品另类videosde| 久草在线在线精品观看| 欧美乱熟臀69xxxxxx| 亚洲午夜久久久久久久久电影网| 国产99久久久久| 国产婷婷一区二区| 韩国女主播一区二区三区| 日韩一区二区三区高清免费看看| 亚洲高清免费观看| 在线观看www91| 亚洲精品免费在线播放| 色综合婷婷久久| 久久66热偷产精品| 欧美一区二区二区| 午夜日韩在线电影| 欧美群妇大交群中文字幕| 亚洲自拍欧美精品| 欧美日韩免费视频| 一区二区不卡在线视频 午夜欧美不卡在| 成人自拍视频在线观看| 国产精品久久久久久久久久久免费看 | 国产麻豆精品视频| 欧美变态tickle挠乳网站| 人人狠狠综合久久亚洲| 日韩一区二区三区高清免费看看 | 91精品麻豆日日躁夜夜躁| 午夜av电影一区| 日韩欧美中文一区| 国产在线精品一区二区| 国产日产亚洲精品系列| 欧美一区二区日韩一区二区| 欧美影视一区二区三区| 在线免费观看一区| 亚洲午夜精品网| 欧美日韩国产高清一区二区三区 | 国产河南妇女毛片精品久久久 | 亚洲欧美另类小说| 色狠狠综合天天综合综合| 亚洲一区欧美一区| 日韩一区二区在线看| 国产一区二区三区av电影| 亚洲国产成人私人影院tom| 成人av电影在线播放| 一区二区三区四区不卡在线| 欧美日本不卡视频| 国产伦精一区二区三区| 中文字幕一区二区三区在线播放| 日本久久一区二区三区| 日韩av电影一区| 欧美国产一区在线| 欧美在线一二三四区| 美女网站色91| 亚洲日本va午夜在线影院| 欧美午夜在线观看| 国产九色精品成人porny| 亚洲日本在线视频观看| 日韩女同互慰一区二区| av电影在线观看完整版一区二区| 天天色天天爱天天射综合| 久久久久亚洲蜜桃| 欧美性色黄大片| 91美女福利视频| 国产黑丝在线一区二区三区| 一级女性全黄久久生活片免费| 日韩欧美亚洲一区二区| 9色porny自拍视频一区二区| 国产精一区二区三区| 亚洲一区二区偷拍精品| 国产女主播视频一区二区| 欧美日韩高清一区二区三区| 国产91精品精华液一区二区三区| 日韩电影在线观看电影| 亚洲精品成人在线| 国产亚洲综合在线| 日韩欧美国产一区二区三区 | 欧美一区三区二区| 91色porny| 成人午夜视频网站| 美女脱光内衣内裤视频久久网站| 亚洲男人的天堂在线aⅴ视频| www久久久久| 欧美一区二区大片| 欧美另类久久久品| 91碰在线视频| 99在线精品视频| 国产.精品.日韩.另类.中文.在线.播放| 图片区小说区国产精品视频| 亚洲视频一二三区| 中文字幕一区在线观看| 国产日韩欧美精品在线| 久久综合色综合88| 精品国产乱码久久久久久图片 | 美女一区二区久久| 亚洲成人精品影院| 亚洲综合色丁香婷婷六月图片| 国产精品激情偷乱一区二区∴| 久久精品网站免费观看| 精品第一国产综合精品aⅴ| 日韩欧美国产不卡| 日韩一级大片在线观看| 欧美大片在线观看一区二区| 欧美一区二区三区色| 91精品国产综合久久久久| 欧美精品日韩一本| 日韩欧美久久久| 精品日韩av一区二区| 2022国产精品视频| 久久久久久久久久电影| 欧美激情在线观看视频免费| 欧美国产日韩a欧美在线观看 | 日韩精品一区二区三区蜜臀| 日韩一区二区三区视频在线观看| 欧美一区二区三区在线观看| 日韩欧美国产三级电影视频| 久久久久一区二区三区四区| 中文字幕国产精品一区二区| 亚洲视频一区在线观看| 亚洲成av人片在www色猫咪| 视频一区视频二区中文字幕| 久久精品国产精品亚洲综合| 国产精品中文字幕一区二区三区| 成人视屏免费看| 欧美怡红院视频| 日韩一区二区电影在线| 国产欧美日韩在线看| 亚洲免费av观看| 日本成人超碰在线观看| 国产精品99久久久久| 色噜噜夜夜夜综合网| 欧美一级精品在线| 中文字幕不卡的av| 五月天欧美精品| 国产激情一区二区三区桃花岛亚洲| www..com久久爱| 成人免费在线观看入口| 亚洲成人综合网站| 国产精品18久久久久久久久| 91福利在线看| 久久久久久电影| 亚洲444eee在线观看| 国产精品 日产精品 欧美精品| 一本高清dvd不卡在线观看| 欧美成人r级一区二区三区| 日韩理论片在线| 久久精品国产亚洲高清剧情介绍 | 日韩高清在线一区| 成人综合在线视频| 在线成人小视频| 亚洲欧美一区二区不卡| 精品亚洲成a人在线观看| 在线中文字幕一区| 久久午夜老司机| 婷婷开心久久网| 91在线码无精品| 国产亚洲精品7777| 奇米亚洲午夜久久精品| 色网站国产精品| 亚洲国产精品v| 美女脱光内衣内裤视频久久影院| 色婷婷激情综合| 亚洲国产成人私人影院tom| 男人的天堂久久精品| 在线免费观看一区| 中文字幕一区二区三区视频| 国内精品久久久久影院薰衣草| 欧美高清视频一二三区 | 成人在线一区二区三区| 亚洲三级电影全部在线观看高清| 精品一区二区国语对白| 欧美日韩国产综合视频在线观看 | 亚洲精品国产一区二区三区四区在线| 经典一区二区三区| 91精品国产综合久久久蜜臀图片| 亚洲一区二区三区在线播放| 99这里只有久久精品视频| 一区二区欧美国产| 欧美另类videos死尸| 免费高清不卡av| 欧美三级三级三级| 亚洲视频免费在线观看| 风间由美一区二区三区在线观看| 日韩免费视频一区二区| 美女性感视频久久| 欧美不卡一区二区| 国产一区免费电影| 国产日韩欧美不卡在线|