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

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

?? globalapi.cpp

?? 馬拉算法使用visual C++實現
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/*************************************************************************
 * 文件DIBPrcs.cpp用來存放有關DIB的操作函數
 * 文件頭存放在GlobalApi.h中
 *************************************************************************
 */

#include "GlobalApi.h"
#include "stdafx.h"
#include <math.h>
#include "Dib.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;

	// 如果調色板不為空,則將調色板選入設備上下文
	if(hPalette != NULL) {
		::SelectPalette(pDC->GetSafeHdc(), hPalette, TRUE);
	}

	// 設置顯示模式
	pDC->SetStretchBltMode(COLORONCOLOR);

	// 在設備的origin位置上畫出大小為size的圖象
	::StretchDIBits(pDC->GetSafeHdc(), origin.x, origin.y,size.cx,size.cy,
		0, 0, lpBMIH->biWidth, lpBMIH->biHeight,
		lpImage, (LPBITMAPINFO) lpBMIH, DIB_RGB_COLORS, SRCCOPY);

	// 返回
	return TRUE;
}


/*************************************************************************
 *
 * \函數名稱:
 *   ConvertDDBToDIB()
 *
 * \輸入參數:
 *   HBITMAP	hBitmap			- 指向源數據的BITMAP句柄
 *   CDib*	pDibDst			- 指向轉換目標的CDib對象指針
 *
 * \返回值:
 *   BOOL				- 如果操作成功,則返回TRUE
 *
 * \說明:
 *   該函數將源BITMAP類pDibSrc中的數據拷貝到pDibDst中,并對相應的數據成員賦值
 *
 *************************************************************************
 */

BOOL ConvertDDBToDIB(HBITMAP hBitmap, CDib* pDibDest, HPALETTE hPal)
{
	// 聲明一個BITMAP結構
	BITMAP bm;

	// 設備上下文
	HDC hDC;
	
	// 象素位數
	WORD biBitCount;
	
	// 調色板表項數
	int nColorTableEntries;

	// 如果hBitmap句柄無效,則返回
	if(!hBitmap){
		return FALSE;
	}

	// 填充圖象數據到bm中,其中最后一個參數表示接收這個指定的對象的指針
	if(!GetObject(hBitmap,sizeof(BITMAP),(LPBYTE)&bm)){
		return FALSE;
	}

	// 計算象素位數
	biBitCount=bm.bmPlanes*bm.bmBitsPixel;
	if(biBitCount<=1)
		biBitCount=1;
	else if(biBitCount<=4)
		biBitCount=4;
	else if(biBitCount<=8)
		biBitCount=8;
	else 
		biBitCount=24;

	// 計算調色板的尺寸
	// 如果biClrUsed為零,則用到的顏色數為2的biBitCount次方
	switch(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:
			ASSERT(FALSE);
	}	
	ASSERT((nColorTableEntries >= 0) && (nColorTableEntries <= 256)); 

	// 分配DIB信息頭和調色板的內存
	LPBITMAPINFOHEADER lpBMIH = (LPBITMAPINFOHEADER) new char
		[sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * nColorTableEntries];

	lpBMIH->biSize = sizeof(BITMAPINFOHEADER); 
	lpBMIH->biWidth = bm.bmWidth; 
	lpBMIH->biHeight = bm.bmHeight; 
	lpBMIH->biPlanes = 1; 
	lpBMIH->biBitCount = biBitCount; 
	lpBMIH->biCompression = BI_RGB; 
	lpBMIH->biSizeImage = 0; 
	lpBMIH->biXPelsPerMeter = 0; 
	lpBMIH->biYPelsPerMeter = 0; 
	lpBMIH->biClrUsed = nColorTableEntries;
	lpBMIH->biClrImportant = nColorTableEntries;	

	// 獲得設備上下文句柄
	hDC=GetDC(NULL);

	  // select and realize our palette 
 
	// 如果沒有指定調色板,則從系統中獲得當前的系統調色板
	if(hPal==NULL){
		hPal = GetSystemPalette();
	}
	hPal = SelectPalette(hDC, hPal, FALSE); 
	RealizePalette(hDC); 
 

	// 調用GetDIBits填充信息頭,并獲得圖象數據的尺寸。注意這里圖象數據指針為NULL
	GetDIBits( hDC, hBitmap, 0, (UINT)lpBMIH->biHeight, NULL, (LPBITMAPINFO)lpBMIH, DIB_RGB_COLORS);

	// 如果沒有正確的獲得圖象數據尺寸,則重新計算
	if( lpBMIH->biSizeImage == 0 ){
		lpBMIH->biSizeImage=(((bm.bmWidth*biBitCount) + 31) / 32 * 4)*bm.bmHeight;
	}

	// 分配存放圖象數據的內存
	LPBYTE lpImage = (LPBYTE) new char[lpBMIH->biSizeImage];

	// 調用GetDIBits加載圖象數據,注意這里給出了圖象數據指針

	// 如果加載圖象數據不成功,則釋放已經分配的內存,并返回FALSE
	if( GetDIBits( hDC, hBitmap, 0, (UINT)lpBMIH->biHeight, (LPBYTE)lpImage,
		(LPBITMAPINFO)lpBMIH, DIB_RGB_COLORS) == 0 ){
		//clean up and return NULL
		delete []lpImage;
		delete []lpBMIH;

		SelectPalette( hDC, hPal, TRUE );
		RealizePalette( hDC );

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲一区二区三区美女| 狠狠色狠狠色综合日日91app| 婷婷综合五月天| 国产成人鲁色资源国产91色综| 在线观看成人免费视频| 国产精品美女久久久久高潮| 蜜桃一区二区三区四区| 在线精品亚洲一区二区不卡| 欧美国产亚洲另类动漫| 美女视频免费一区| 欧美精品三级日韩久久| 亚洲国产精品精华液网站| 波多野结衣视频一区| 久久婷婷成人综合色| 日本在线不卡视频| 欧美另类高清zo欧美| 亚洲综合一二三区| 一本一道波多野结衣一区二区| 精品国精品国产尤物美女| 亚洲一区视频在线| 在线国产亚洲欧美| 一区二区三区自拍| 成人av影院在线| 国产午夜精品一区二区三区嫩草| 日本一不卡视频| 91麻豆精品国产自产在线| 一区二区三区四区激情| 色婷婷久久一区二区三区麻豆| 亚洲欧洲www| 91在线一区二区三区| 国产精品国产三级国产aⅴ无密码| 国内精品久久久久影院一蜜桃| 欧美一区二区三区精品| 免费成人你懂的| 日韩西西人体444www| 日本不卡的三区四区五区| 欧美一区二区三区视频免费播放| 日产精品久久久久久久性色| 在线综合视频播放| 精品一区二区久久久| 欧美成人aa大片| 国产福利电影一区二区三区| 国产精品天美传媒沈樵| 91在线国产福利| 一区二区三区波多野结衣在线观看 | 色综合视频一区二区三区高清| 亚洲欧美日韩久久| 欧美在线观看视频在线| 图片区小说区国产精品视频| 欧美精品自拍偷拍| 久草热8精品视频在线观看| 久久久精品黄色| 国产成人av电影在线播放| **性色生活片久久毛片| 在线视频国产一区| 麻豆久久久久久| 亚洲国产精品传媒在线观看| 97超碰欧美中文字幕| 天天影视色香欲综合网老头| 日韩欧美亚洲另类制服综合在线| 国产精品一区在线观看乱码| 综合在线观看色| 2020国产精品自拍| proumb性欧美在线观看| 亚洲va国产天堂va久久en| 精品日韩成人av| av影院午夜一区| 日韩成人一级大片| 欧美国产精品专区| 欧美日本免费一区二区三区| 国产一区不卡视频| 亚洲综合激情小说| 国产精品亲子乱子伦xxxx裸| 欧美伦理视频网站| 91伊人久久大香线蕉| 日本成人在线看| 亚洲人123区| 精品国产免费久久| 欧美日韩国产高清一区二区三区| 国产一区二区不卡| 五月天激情综合网| 日韩伦理免费电影| 精品国产乱子伦一区| 欧美视频在线不卡| 成人午夜电影网站| 久久99国产精品久久99果冻传媒| 亚洲黄色免费网站| 欧美国产欧美综合| 久久亚洲欧美国产精品乐播 | 日韩免费在线观看| 91久久精品一区二区三区| 国产麻豆成人传媒免费观看| 日韩激情在线观看| 亚洲一卡二卡三卡四卡无卡久久| 国产精品久久久久久久久快鸭 | 日韩欧美一二区| 欧美二区在线观看| 在线观看不卡视频| 91麻豆精品一区二区三区| 国产精品自拍网站| 精品影视av免费| 日本一不卡视频| 日本欧美在线观看| 午夜电影一区二区三区| 国产精品情趣视频| 国产精品天天摸av网| 中文字幕乱码日本亚洲一区二区 | 国产福利一区二区三区| 韩国成人精品a∨在线观看| 免费观看成人av| 捆绑紧缚一区二区三区视频| 日韩av一二三| 老司机精品视频一区二区三区| 丝袜诱惑亚洲看片| 天天综合网 天天综合色| 一区二区欧美精品| 五月天激情综合网| 轻轻草成人在线| 麻豆一区二区在线| 精品一区二区三区香蕉蜜桃| 久久99精品久久只有精品| 蜜臂av日日欢夜夜爽一区| 免费人成精品欧美精品 | 91在线你懂得| 91网上在线视频| 精品视频1区2区| 欧美日韩1区2区| 日韩欧美区一区二| 国产日韩欧美精品电影三级在线| 中文字幕成人av| 一区二区在线观看免费视频播放| 亚洲精品免费一二三区| 亚洲成av人片在www色猫咪| 日本女人一区二区三区| 精品一区二区在线视频| 国产成人免费视频一区| 一本色道久久综合亚洲91| 正在播放亚洲一区| 国产欧美精品一区aⅴ影院| 亚洲欧美国产三级| 蜜臀av一区二区在线免费观看 | 国内精品久久久久影院薰衣草| 国产激情91久久精品导航 | 555夜色666亚洲国产免| 日韩三级.com| 国产精品传媒视频| 亚洲第一成年网| 国产成人免费高清| 欧美日韩极品在线观看一区| 久久久综合九色合综国产精品| 亚洲精品视频一区| 久久不见久久见中文字幕免费| 成人的网站免费观看| 在线综合亚洲欧美在线视频| 国产亚洲美州欧州综合国| 亚洲最新在线观看| 国产一区二区三区四| 欧美体内she精视频| 久久久久久久久久久久久久久99 | 在线免费观看视频一区| 337p日本欧洲亚洲大胆精品| 一区二区高清视频在线观看| 精品制服美女久久| 欧美综合久久久| 欧美国产日本韩| 看电视剧不卡顿的网站| 欧美性受极品xxxx喷水| 国产亚洲精品bt天堂精选| 亚洲国产aⅴ天堂久久| av激情成人网| 国产亚洲成aⅴ人片在线观看| 日韩在线卡一卡二| 色哟哟一区二区在线观看| 国产亚洲欧美中文| 久久9热精品视频| 欧美系列一区二区| 中文字幕中文字幕一区二区| 久久精品国产免费看久久精品| 在线观看91视频| 日韩一区在线免费观看| 国产精品一区二区在线看| 777午夜精品免费视频| 亚洲午夜一区二区| av一区二区三区四区| 久久久精品tv| 国产呦萝稀缺另类资源| 精品福利一二区| 久久精品国内一区二区三区| 欧美久久一二区| 天天综合天天综合色| 欧美日韩高清在线| 亚洲一区成人在线| 欧美系列在线观看| 亚洲一二三四区| 欧美三级在线看| 亚洲成av人影院在线观看网| 欧美日韩高清在线| 日本成人在线视频网站| 精品乱人伦一区二区三区| 国产综合色产在线精品|