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

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

?? dib.cpp

?? 該源碼實現(xiàn)了對一256色灰度圖像的霍夫曼編碼輸出
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// Dib.cpp : implementation file
//

#include "stdafx.h"
#include <stdlib.h>
#include <time.h>
#include <math.h>
#include <windowsx.h>		// especially for GlobalAllocPtr

#include "Dib.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif


IMPLEMENT_SERIAL(CDib, CObject, 0)

////////////////////////////////////////////////////////////////////////////
CDib::CDib()
{
	m_hDib		= NULL;
	m_hBitmap   = NULL;
	m_pPalette  = NULL;
	m_pBitmap   = NULL;
}           
                                      
CDib::~CDib()
{
	Destroy();
	if (m_pBitmap != NULL)
	{
		delete m_pBitmap;
		m_pBitmap = NULL;
	}
	if (m_pPalette != NULL)
	{
		delete m_pPalette;
		m_pPalette = NULL;
	}
}

void CDib::Destroy()
{
	if (m_hDib != NULL)
	{
		DestroyDIB(m_hDib);
		m_hDib = NULL;
	}
}

BOOL CDib::Create(DWORD dwWidth, DWORD dwHeight)
{
	HDIB hDib = CreateDefaultDIB(dwWidth, dwHeight);
	if (! hDib)
		return FALSE;

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(DWORD dwWidth, DWORD dwHeight, WORD wBitCount)
{
	HDIB hDib = CreateDIB(dwWidth, dwHeight, wBitCount);
	if (! hDib)
		return FALSE;

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(LPBYTE lpDIB)
{
	if (lpDIB == NULL)
		return FALSE;
	
	DWORD dwSize = DIBlockSize(lpDIB);

    HDIB hDib  = GlobalAlloc(GHND, dwSize); 
    // Check that DIB handle is valid 
    if (! hDib) 
        return FALSE; 
 
    LPBYTE lpbi  = (LPBYTE)GlobalLock(hDib); 
	if (! lpbi)
        return FALSE; 
		
	CopyMemory(lpbi, lpDIB, dwSize);
	GlobalUnlock(hDib);

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(LPBYTE lpDIB,
				  WORD  wBitCount)		// bits/pixel 
{
	if (lpDIB == NULL)
		return FALSE;
	if (! Create(lpDIB))
		return FALSE;

	WORD wBits = ((LPBITMAPINFOHEADER)lpDIB)->biBitCount;
	if (wBitCount == wBits)
		return TRUE;

	HDIB hNewDib = ConvertDIBFormat(m_hDib, wBitCount, NULL); 
	if (! hNewDib)
		return FALSE;

	Destroy();
	m_hDib = hNewDib;
	return UpdateInternal();
}

BOOL CDib::Create(HBITMAP hBitmap)		// DIB Section
{
	if (! hBitmap)
        return FALSE; 

	HDIB hDib = DIBSectionToDIB(hBitmap); 
    if (! hDib) 
        return FALSE; 

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(HBITMAP hBitmap,		// DIB Section
				  WORD  wBitCount)		// bits/pixel 
{
	HDIB hNewDib;

	if (! hBitmap)
        return FALSE; 

	HDIB hDib = DIBSectionToDIB(hBitmap); 
    if (! hDib) 
        return FALSE; 

	DIBSECTION ds;
	GetObject(hBitmap, sizeof(DIBSECTION), &ds);

	if (wBitCount == ds.dsBmih.biBitCount)
		hNewDib = hDib;
	else
	{
		hNewDib = ConvertDIBFormat(hDib, wBitCount, NULL); 
		// cleanup hDib
		GlobalFree(hDib);
	}
	if (! hNewDib)
		return FALSE;

	Destroy();
	m_hDib = hNewDib;
	return UpdateInternal();
}

BOOL CDib::Create(HBITMAP hBitmap,		// DDB bitmap
			      HPALETTE hPalette)	// DDB palette
{
	if (! hBitmap)
        return FALSE; 

	HDIB hDib = BitmapToDIB(hBitmap, hPalette); 
    if (! hDib) 
        return FALSE; 

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(HBITMAP hBitmap,		// DDB bitmap
			      HPALETTE hPalette,	// DDB palette
				  WORD  wBitCount)		// bits/pixel 
{
	if (! hBitmap)
        return FALSE; 

	HDIB hDib = BitmapToDIB(hBitmap, hPalette, wBitCount); 
    if (! hDib) 
        return FALSE; 

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(CRect rcScreen)
{
	HDIB hDib = CopyScreenToDIB(rcScreen); 
    if (! hDib) 
        return FALSE; 

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(HWND hWnd, WORD fPrintArea)
{
	HDIB hDib = CopyWindowToDIB(hWnd, fPrintArea); 
    if (! hDib) 
        return FALSE; 

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

BOOL CDib::Create(HWND hWnd, CRect rcClientArea)
{
	HDIB hDib = CopyClientRectToDIB(hWnd, rcClientArea); 
    if (! hDib) 
        return FALSE; 

	Destroy();
	m_hDib = hDib;
	return UpdateInternal();
}

void CDib::Serialize(CArchive& ar)
{
	CObject::Serialize(ar);
	ar.Flush();
	if (ar.IsStoring())
	{
		Write(ar.GetFile());
	}
    else
    {
   		Read(ar.GetFile());
    }
}

BOOL CDib::Load(UINT uIDS, LPCSTR lpszDibType)
{                                
	LPCSTR lpszDibRes = MAKEINTRESOURCE(uIDS);

	return Load(lpszDibRes, lpszDibType);
}

BOOL CDib::Load(LPCSTR lpszDibRes, LPCSTR lpszDibType)
{                                
	HINSTANCE hInst = AfxGetInstanceHandle();
	HRSRC   hRes    = ::FindResource(hInst, lpszDibRes, lpszDibType);
	HGLOBAL hData   = ::LoadResource(hInst, hRes);

	// if resource ok?
	if (hRes == NULL || hData == NULL)
		return FALSE;

	// get resource buffer
	LPBYTE lpBuf = (LPBYTE)::LockResource(hData);
	// is DIB ?
	if (((LPBITMAPFILEHEADER)lpBuf)->bfType != DIB_HEADER_MARKER/*"BM"*/)
		return FALSE;

	// use this buffer to create CDib
	LPBYTE lpDIB = lpBuf + sizeof(BITMAPFILEHEADER);
	return Create(lpDIB);
}

BOOL CDib::Load(LPCSTR lpszDibFile)
{                                
	TRY
	{
		CFile file(lpszDibFile, CFile::modeRead|CFile::shareDenyNone);

		if (! Read(&file))
			return FALSE;
	}
	CATCH (CException, e)
	{
		return FALSE;
	}
	END_CATCH

	return TRUE;
}               

BOOL CDib::Save(LPCSTR lpszDibFile)
{
	TRY
	{
		CFile file(lpszDibFile, CFile::modeCreate|CFile::modeWrite);

		if (! Write(&file))
			return FALSE;
	}
	CATCH (CException, e)
	{
		return FALSE;
	}
	END_CATCH

	return TRUE;
}

BOOL CDib::Read(CFile *pFile)
{
	WaitCursorBegin();

	LPBITMAPINFOHEADER lpbi;
	DWORD dwSize;
	TRY
	{
		// read DIB file header
		BITMAPFILEHEADER bmfHdr;
		pFile->Read(&bmfHdr, sizeof(BITMAPFILEHEADER));
		// is DIB file?
		if (bmfHdr.bfType != DIB_HEADER_MARKER/*"BM"*/)
		{
			WaitCursorEnd();
			return FALSE;
		}
		DWORD dwLength = pFile->GetLength();
		if (bmfHdr.bfSize != dwLength)
			bmfHdr.bfSize = dwLength;

		// read DIB buffer
		dwSize = bmfHdr.bfSize - sizeof(BITMAPFILEHEADER);
		lpbi = (LPBITMAPINFOHEADER)GlobalAllocPtr(GHND, dwSize);
		DWORD dwCount = pFile->ReadHuge(lpbi, dwSize);
		// read ok?
		if (dwCount != dwSize)
		{
			GlobalFreePtr(lpbi);
			WaitCursorEnd();
			return FALSE;
		}

		// Check to see that it's a Windows DIB -- an OS/2 DIB would cause 
		// strange problems with the rest of the DIB API since the fields 
		// in the header are different and the color table entries are 
		// smaller. 
		// 
		// If it's not a Windows DIB (e.g. if biSize is wrong), return NULL. 
	    if (lpbi->biSize != sizeof(BITMAPINFOHEADER)) 
		{
			GlobalFreePtr(lpbi);
			WaitCursorEnd();
			return FALSE;
		}
		
		// fill color num item
		int nNumColors = (UINT)lpbi->biClrUsed;
		if (nNumColors == 0) 
		{ 
			// no color table for 24-bit, default size otherwise 
	        if (lpbi->biBitCount != 24) 
		        nNumColors = 1 << lpbi->biBitCount; // standard size table 
		} 
 
		// fill in some default values if they are zero 
	    if (lpbi->biClrUsed == 0) 
		    lpbi->biClrUsed = nNumColors; 
		if (lpbi->biSizeImage == 0) 
			lpbi->biSizeImage = ((((lpbi->biWidth * (DWORD)lpbi->biBitCount) + 31) & ~31) >> 3) * lpbi->biHeight; 
 	}
	CATCH (CException, e)
	{
		GlobalFreePtr(lpbi);
		WaitCursorEnd();
		return FALSE;
	}
	END_CATCH

	// create CDib with DIB buffer
	BOOL bSuccess = Create((LPBYTE)lpbi);
	GlobalFreePtr(lpbi);
	WaitCursorEnd();

	return bSuccess;
}

BOOL CDib::Write(CFile *pFile)
{
	WaitCursorBegin();

    BITMAPFILEHEADER    bmfHdr;     // Header for Bitmap file 
    LPBITMAPINFOHEADER  lpBI;       // Pointer to DIB info structure 
    DWORD               dwDIBSize; 

	// Get a pointer to the DIB memory, the first of which contains 
    // a BITMAPINFO structure 
    lpBI = (LPBITMAPINFOHEADER)GlobalLock(m_hDib); 
    if (!lpBI) 
	{
		GlobalUnlock(m_hDib);
		WaitCursorEnd();
        return FALSE; 
	}
 
    // Check to see if we're dealing with an OS/2 DIB.  If so, don't 
    // save it because our functions aren't written to deal with these 
    // DIBs. 
    if (lpBI->biSize != sizeof(BITMAPINFOHEADER)) 
    { 
        GlobalUnlock(m_hDib); 
		WaitCursorEnd();
        return FALSE; 
    } 
 
    // Fill in the fields of the file header 
 
    // Fill in file type (first 2 bytes must be "BM" for a bitmap) 
 
    bmfHdr.bfType = DIB_HEADER_MARKER;  // "BM" 
 
    // Calculating the size of the DIB is a bit tricky (if we want to 
    // do it right).  The easiest way to do this is to call GlobalSize() 
    // on our global handle, but since the size of our global memory may have 
    // been padded a few bytes, we may end up writing out a few too 
    // many bytes to the file (which may cause problems with some apps, 
    // like HC 3.0). 
    // 
    // So, instead let's calculate the size manually. 

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线观看一区二区精品视频| 国产成人精品影院| 亚洲日本丝袜连裤袜办公室| 亚洲国产成人午夜在线一区| 国产亚洲一二三区| 欧美高清在线视频| 成人免费小视频| 亚洲黄色小说网站| 亚洲三级视频在线观看| 一区二区成人在线观看| 一区二区三区精品视频| 亚洲视频免费看| 一级中文字幕一区二区| 亚洲r级在线视频| 麻豆国产精品官网| 国产91精品露脸国语对白| 99久久99精品久久久久久| 日本韩国欧美在线| 欧美sm极限捆绑bd| 中文字幕在线一区二区三区| 亚洲色图第一区| 美女尤物国产一区| 成人动漫av在线| 欧美日韩成人综合天天影院 | 久久久国产综合精品女国产盗摄| 国产无一区二区| 亚洲激情五月婷婷| 玖玖九九国产精品| av一区二区久久| 777久久久精品| 欧美激情一二三区| 日韩成人免费电影| 99久久精品国产一区| 在线91免费看| 自拍偷拍亚洲综合| 麻豆一区二区99久久久久| av成人免费在线| 日韩一区二区在线看| 亚洲女与黑人做爰| 国产精品一区一区| 欧美精品高清视频| 中文字幕一区在线观看视频| 麻豆久久一区二区| 欧美日韩午夜精品| 国产精品美女久久久久久久久| 五月婷婷另类国产| eeuss鲁片一区二区三区| 日韩欧美亚洲国产精品字幕久久久| 国产精品久久久久久户外露出 | 91网址在线看| 久久一区二区三区国产精品| 亚洲国产另类av| 99视频精品全部免费在线| 日韩视频免费观看高清完整版在线观看| 中文字幕一区二区三区在线播放 | 99久久婷婷国产| 欧美成人午夜电影| 亚洲一区在线观看免费| 色综合中文字幕国产 | 成人久久18免费网站麻豆| 777色狠狠一区二区三区| 亚洲一区二区三区四区在线 | 丝袜亚洲另类欧美综合| 91麻豆.com| 中文字幕一区二区三区色视频| 精品在线观看免费| 日韩欧美激情在线| 美国十次了思思久久精品导航| 欧美日韩三级一区| 亚洲高清在线精品| 欧美性三三影院| 亚洲成人在线网站| 欧美午夜影院一区| 亚洲123区在线观看| 欧美欧美欧美欧美首页| 午夜精品福利在线| 911国产精品| 久久精品国产第一区二区三区| 欧美精品日韩一本| 久久精品久久久精品美女| 日韩欧美中文字幕制服| 蜜桃av一区二区三区电影| 精品国产乱码久久久久久久久| 免费xxxx性欧美18vr| 欧美精品一区二区三区在线播放 | 国产日韩欧美在线一区| 国产传媒一区在线| 国产精品初高中害羞小美女文| 成人教育av在线| 一区二区在线免费观看| 欧美日韩一级二级三级| 美女一区二区视频| 国产精品久久毛片a| 色综合久久综合中文综合网| 亚洲一区在线视频| 26uuu成人网一区二区三区| 成人99免费视频| 亚洲午夜激情网站| 久久影音资源网| 色999日韩国产欧美一区二区| 亚洲五码中文字幕| 久久精品网站免费观看| 色综合天天在线| 日韩福利电影在线观看| 久久免费偷拍视频| 91久久精品网| 久久成人羞羞网站| 亚洲永久免费视频| 久久综合色一综合色88| 色欧美日韩亚洲| 狠狠久久亚洲欧美| 亚洲一区二区三区四区五区中文| 精品久久久久久久久久久院品网| av一区二区三区在线| 久久99国产精品久久99| 亚洲人精品午夜| 欧美一区永久视频免费观看| a4yy欧美一区二区三区| 精品一区二区三区在线观看 | 美脚の诱脚舐め脚责91| 一区二区在线观看视频在线观看| 精品久久久久久久久久久久久久久久久 | 久久伊人中文字幕| 欧美日本国产视频| 色域天天综合网| 国产福利一区二区三区| 久久av资源站| 日韩成人免费电影| 亚洲午夜久久久久久久久电影网 | 4438x亚洲最大成人网| 97久久人人超碰| 国产成人精品一区二区三区四区 | 日产国产欧美视频一区精品| 亚洲色图自拍偷拍美腿丝袜制服诱惑麻豆 | 三级久久三级久久久| 亚洲欧美视频在线观看| 国产欧美一二三区| 精品久久国产老人久久综合| 69堂成人精品免费视频| 欧美主播一区二区三区| 91官网在线免费观看| 色一情一乱一乱一91av| 成人开心网精品视频| 成人午夜视频福利| 成人激情电影免费在线观看| 国产精品夜夜嗨| 国产成人精品免费| 国产成人av电影| 成人免费视频网站在线观看| 粉嫩绯色av一区二区在线观看| 国产一区二区三区四区五区入口| 精品一区二区在线看| 精品亚洲欧美一区| 国产成人综合亚洲91猫咪| 国产在线播放一区二区三区 | 亚洲色图都市小说| 一区二区三区蜜桃| 石原莉奈在线亚洲三区| 国内精品不卡在线| 美女精品一区二区| 国内成人自拍视频| 北岛玲一区二区三区四区| 99久久久精品免费观看国产蜜| av在线不卡免费看| 精品视频一区 二区 三区| 欧美乱熟臀69xxxxxx| 日韩欧美一区二区免费| 久久久久久亚洲综合影院红桃| 欧美国产一区二区在线观看 | 午夜精品免费在线观看| 日本视频一区二区三区| 国产伦理精品不卡| 99re成人在线| 91麻豆精品国产91久久久资源速度 | 日韩精品一区二区三区在线| 精品国产亚洲在线| 国产精品传媒入口麻豆| 天天操天天综合网| 国产一区二区免费视频| 99国产精品视频免费观看| 欧美日韩国产免费| 久久精品一区二区| 一区二区三区欧美在线观看| 美女脱光内衣内裤视频久久影院| 国产精品资源在线观看| 在线观看欧美黄色| 久久综合精品国产一区二区三区| 国产精品久久久久久久久免费樱桃 | 不卡在线视频中文字幕| 欧美丝袜自拍制服另类| 久久婷婷国产综合精品青草| 日韩伦理电影网| 九色综合狠狠综合久久| 色综合久久综合| 精品福利视频一区二区三区| 亚洲你懂的在线视频| 国产综合久久久久影院| 欧美日韩一区中文字幕| 国产女人aaa级久久久级 | 美国十次综合导航|