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

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

?? cdib.cpp

?? 影像處理程序 基本的影像處理算法
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
// cdib.cpp
// new version for WIN32
#include "stdafx.h"
#include "cdib.h"

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

IMPLEMENT_SERIAL(CDib, CObject, 0);

CDib::CDib()
{
	m_hFile = NULL;
	m_hBitmap = NULL;
	m_hPalette = NULL;
	m_nBmihAlloc = m_nImageAlloc = noAlloc;
	Empty();
}

CDib::CDib(CSize size, int nBitCount)
{
	m_hFile = NULL;
	m_hBitmap = NULL;
	m_hPalette = NULL;
	m_nBmihAlloc = m_nImageAlloc = noAlloc;
	Empty();
	ComputePaletteSize(nBitCount);
	m_lpBMIH = (LPBITMAPINFOHEADER) new 
		char[sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * m_nColorTableEntries];
	m_nBmihAlloc = crtAlloc;
	m_lpBMIH->biSize = sizeof(BITMAPINFOHEADER);
	m_lpBMIH->biWidth = size.cx;
	m_lpBMIH->biHeight = size.cy;
	m_lpBMIH->biPlanes = 1;
	m_lpBMIH->biBitCount = nBitCount;
	m_lpBMIH->biCompression = BI_RGB;
	m_lpBMIH->biSizeImage = 0;
	m_lpBMIH->biXPelsPerMeter = 0;
	m_lpBMIH->biYPelsPerMeter = 0;
	m_lpBMIH->biClrUsed = m_nColorTableEntries;
	m_lpBMIH->biClrImportant = m_nColorTableEntries;
	ComputeMetrics();
	memset(m_lpvColorTable, 0, sizeof(RGBQUAD) * m_nColorTableEntries);
	m_lpImage = NULL;  // no data yet
}

CDib::~CDib()
{
	Empty();
}

CSize CDib::GetDimensions()
{	
	if(m_lpBMIH == NULL) return CSize(0, 0);
	return CSize((int) m_lpBMIH->biWidth, (int) m_lpBMIH->biHeight);
}

BOOL CDib::AttachMapFile(const char* strPathname, BOOL bShare) // for reading
{
	// if we open the same file twice, Windows treats it as 2 separate files
	// doesn't work with rare BMP files where # palette entries > biClrUsed
	HANDLE hFile = ::CreateFile(strPathname, GENERIC_WRITE | GENERIC_READ,
		bShare ? FILE_SHARE_READ : 0,
		NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL);
	ASSERT(hFile != INVALID_HANDLE_VALUE);
	DWORD dwFileSize = ::GetFileSize(hFile, NULL);
	HANDLE hMap = ::CreateFileMapping(hFile, NULL, PAGE_READWRITE, 0, 0, NULL);
	DWORD dwErr = ::GetLastError();
	
	if(hMap == NULL)
	{
		AfxMessageBox("Empty bitmap file");
		return FALSE;
	}
	
	LPVOID lpvFile = ::MapViewOfFile(hMap, FILE_MAP_WRITE, 0, 0, 0); // map whole file
	ASSERT(lpvFile != NULL);
	
	if(((LPBITMAPFILEHEADER) lpvFile)->bfType != 0x4d42)
	{
		AfxMessageBox("Invalid bitmap file");
		DetachMapFile();
		return FALSE;
	}
	
	AttachMemory((LPBYTE) lpvFile + sizeof(BITMAPFILEHEADER));
	m_lpvFile = lpvFile;
	m_hFile = hFile;
	m_hMap = hMap;
	return TRUE;
}

BOOL CDib::CopyToMapFile(const char* strPathname)
{
	// copies DIB to a new file, releases prior pointers
	// if you previously used CreateSection, the HBITMAP will be NULL (and unusable)
	BITMAPFILEHEADER bmfh;
	bmfh.bfType = 0x4d42;  // 'BM'
	bmfh.bfSize = m_dwSizeImage + sizeof(BITMAPINFOHEADER) +
			sizeof(RGBQUAD) * m_nColorTableEntries + sizeof(BITMAPFILEHEADER);
	// meaning of bfSize open to interpretation
	bmfh.bfReserved1 = bmfh.bfReserved2 = 0;
	bmfh.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER) +
			sizeof(RGBQUAD) * m_nColorTableEntries;	
	HANDLE hFile = ::CreateFile(strPathname, GENERIC_WRITE | GENERIC_READ, 0, NULL,
		CREATE_ALWAYS, FILE_ATTRIBUTE_NORMAL, NULL);
	ASSERT(hFile != INVALID_HANDLE_VALUE);
	int nSize =  sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER) +
				sizeof(RGBQUAD) * m_nColorTableEntries +  m_dwSizeImage;
	HANDLE hMap = ::CreateFileMapping(hFile, NULL, PAGE_READWRITE, 0, nSize, NULL);
	DWORD dwErr = ::GetLastError();
	ASSERT(hMap != NULL);
	LPVOID lpvFile = ::MapViewOfFile(hMap, FILE_MAP_WRITE, 0, 0, 0); // map whole file
	ASSERT(lpvFile != NULL);
	LPBYTE lpbCurrent = (LPBYTE) lpvFile;
	memcpy(lpbCurrent, &bmfh, sizeof(BITMAPFILEHEADER)); // file header
	lpbCurrent += sizeof(BITMAPFILEHEADER);
	LPBITMAPINFOHEADER lpBMIH = (LPBITMAPINFOHEADER) lpbCurrent;
	memcpy(lpbCurrent, m_lpBMIH,
		sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * m_nColorTableEntries); // info
	lpbCurrent += sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * m_nColorTableEntries;
	memcpy(lpbCurrent, m_lpImage, m_dwSizeImage); // bit image
	DWORD dwSizeImage = m_dwSizeImage;
	Empty();
	m_dwSizeImage = dwSizeImage;
	m_nBmihAlloc = m_nImageAlloc = noAlloc;
	m_lpBMIH = lpBMIH;
	m_lpImage = lpbCurrent;
	m_hFile = hFile;
	m_hMap = hMap;
	m_lpvFile = lpvFile;
	ComputePaletteSize(m_lpBMIH->biBitCount);
	ComputeMetrics();
	MakePalette();
	return TRUE;
}

BOOL CDib::AttachMemory(LPVOID lpvMem, BOOL bMustDelete, HGLOBAL hGlobal)
{
	// assumes contiguous BITMAPINFOHEADER, color table, image
	// color table could be zero length
	Empty();
	m_hGlobal = hGlobal;
	if(bMustDelete == FALSE)
	{
		m_nBmihAlloc = noAlloc;
	}
	else
	{
		m_nBmihAlloc = ((hGlobal == NULL) ? crtAlloc : heapAlloc);
	}
	try
	{
		m_lpBMIH = (LPBITMAPINFOHEADER) lpvMem;
		ComputeMetrics();
		ComputePaletteSize(m_lpBMIH->biBitCount);
		m_lpImage = (LPBYTE) m_lpvColorTable + sizeof(RGBQUAD) * m_nColorTableEntries;
		MakePalette();
	}
	catch(CException* pe)
	{
		AfxMessageBox("AttachMemory error");
		pe->Delete();
		return FALSE;
	}
	return TRUE;
}

UINT CDib::UsePalette(CDC* pDC, BOOL bBackground /* = FALSE */)
{
	if(m_hPalette == NULL) return 0;
	HDC hdc = pDC->GetSafeHdc();
	::SelectPalette(hdc, m_hPalette, bBackground);
	return ::RealizePalette(hdc);
}

BOOL CDib::Draw(CDC* pDC, CPoint origin, CSize size)
{
	if(m_lpBMIH == NULL) return FALSE;
	if(m_hPalette != NULL)
	{
		::SelectPalette(pDC->GetSafeHdc(), m_hPalette, TRUE);
	}
	pDC->SetStretchBltMode(COLORONCOLOR);
	::StretchDIBits(pDC->GetSafeHdc(), origin.x, origin.y, size.cx, size.cy,
		0, 0, m_lpBMIH->biWidth, m_lpBMIH->biHeight,
		m_lpImage, (LPBITMAPINFO) m_lpBMIH, DIB_RGB_COLORS, SRCCOPY);
	return TRUE;
}

HBITMAP CDib::CreateSection(CDC* pDC /* = NULL */)
{
	if(m_lpBMIH == NULL) return NULL;
	if(m_lpImage != NULL) return NULL; // can only do this if image doesn't exist
	m_hBitmap = ::CreateDIBSection(pDC->GetSafeHdc(), (LPBITMAPINFO) m_lpBMIH,
		DIB_RGB_COLORS,	(LPVOID*) &m_lpImage, NULL, 0);
	ASSERT(m_lpImage != NULL);
	return m_hBitmap;
}

BOOL CDib::MakePalette()
{
	// makes a logical palette (m_hPalette) from the DIB's color table
	// this palette will be selected and realized prior to drawing the DIB
	if(m_nColorTableEntries == 0) return FALSE;
	if(m_hPalette != NULL) ::DeleteObject(m_hPalette);
	TRACE("CDib::MakePalette -- m_nColorTableEntries = %d\n", m_nColorTableEntries);
	LPLOGPALETTE pLogPal = (LPLOGPALETTE) new char[2 * sizeof(WORD) +
		m_nColorTableEntries * sizeof(PALETTEENTRY)];
	pLogPal->palVersion = 0x300;
	pLogPal->palNumEntries = m_nColorTableEntries;
	LPRGBQUAD pDibQuad = (LPRGBQUAD) m_lpvColorTable;
	for(int i = 0; i < m_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++;
	}
	m_hPalette = ::CreatePalette(pLogPal);
	delete pLogPal;
	return TRUE;
}	

BOOL CDib::SetSystemPalette(CDC* pDC)
{
	// if the DIB doesn't have a color table, we can use the system's halftone palette
	if(m_nColorTableEntries != 0) return FALSE;
	m_hPalette = ::CreateHalftonePalette(pDC->GetSafeHdc());
	return TRUE;
}

HBITMAP CDib::CreateBitmap(CDC* pDC)
{
    if (m_dwSizeImage == 0) return NULL;
    HBITMAP hBitmap = ::CreateDIBitmap(pDC->GetSafeHdc(), m_lpBMIH,
            CBM_INIT, m_lpImage, (LPBITMAPINFO) m_lpBMIH, DIB_RGB_COLORS);
    ASSERT(hBitmap != NULL);
    return hBitmap;
}

BOOL CDib::Compress(CDC* pDC, BOOL bCompress /* = TRUE */)
{
	// 1. makes GDI bitmap from existing DIB
	// 2. makes a new DIB from GDI bitmap with compression
	// 3. cleans up the original DIB
	// 4. puts the new DIB in the object
	if((m_lpBMIH->biBitCount != 4) && (m_lpBMIH->biBitCount != 8)) return FALSE;
		// compression supported only for 4 bpp and 8 bpp DIBs
	if(m_hBitmap) return FALSE; // can't compress a DIB Section!
	TRACE("Compress: original palette size = %d\n", m_nColorTableEntries); 
	HDC hdc = pDC->GetSafeHdc();
	HPALETTE hOldPalette = ::SelectPalette(hdc, m_hPalette, FALSE);
	HBITMAP hBitmap;  // temporary
	if((hBitmap = CreateBitmap(pDC)) == NULL) return FALSE;
	int nSize = sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * m_nColorTableEntries;
	LPBITMAPINFOHEADER lpBMIH = (LPBITMAPINFOHEADER) new char[nSize];
	memcpy(lpBMIH, m_lpBMIH, nSize);  // new header
	if(bCompress)
	{
		switch (lpBMIH->biBitCount)
		{
		case 4:
			lpBMIH->biCompression = BI_RLE4;
			break;
		case 8:
			lpBMIH->biCompression = BI_RLE8;
			break;
		default:
			ASSERT(FALSE);
		}
		// calls GetDIBits with null data pointer to get size of compressed DIB
		if(!::GetDIBits(pDC->GetSafeHdc(), hBitmap, 0, (UINT) lpBMIH->biHeight,
						NULL, (LPBITMAPINFO) lpBMIH, DIB_RGB_COLORS))
		{
			AfxMessageBox("Unable to compress this DIB");
			// probably a problem with the color table
	 		::DeleteObject(hBitmap);
			delete [] lpBMIH;
			::SelectPalette(hdc, hOldPalette, FALSE);
			return FALSE; 
		}
		if (lpBMIH->biSizeImage == 0)
		{
			AfxMessageBox("Driver can't do compression");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
麻豆91在线看| 亚洲国产精品自拍| 欧美天天综合网| 激情综合五月婷婷| 一区二区日韩av| 国产亚洲欧美一区在线观看| 欧美综合久久久| 不卡电影免费在线播放一区| 蜜臀va亚洲va欧美va天堂| 一个色综合网站| 国产精品二区一区二区aⅴ污介绍| 欧美日韩国产欧美日美国产精品| 99热精品一区二区| 国产美女在线观看一区| 天堂在线一区二区| 亚洲欧美日韩国产另类专区| 国产香蕉久久精品综合网| 欧美日本高清视频在线观看| 色婷婷av一区| jlzzjlzz欧美大全| 国产成人免费xxxxxxxx| 精东粉嫩av免费一区二区三区| 亚洲第一久久影院| 亚洲一区二区视频| 亚洲欧美日韩国产另类专区| 国产精品国产精品国产专区不蜜| 亚洲精品一线二线三线| 91麻豆精品国产自产在线观看一区 | 日日摸夜夜添夜夜添国产精品| 亚洲视频免费在线| 欧美激情一区二区三区全黄| 久久先锋资源网| 欧美刺激脚交jootjob| 欧美一区二区三区人| 精品视频一区二区不卡| 在线观看中文字幕不卡| 色综合久久六月婷婷中文字幕| av在线免费不卡| 不卡一区在线观看| 91欧美一区二区| 91免费国产在线| 在线免费亚洲电影| 精品视频在线免费观看| 欧美色电影在线| 88在线观看91蜜桃国自产| 欧美一区二区三区免费| 日韩精品一区二区三区在线观看| 日韩欧美色电影| 久久综合久久99| 国产精品毛片高清在线完整版| 国产精品福利一区二区三区| 亚洲欧美在线aaa| 一区二区视频在线| 亚洲电影第三页| 久久国产精品一区二区| 国产最新精品精品你懂的| 国产福利一区二区三区视频| 成人福利视频网站| 91黄色免费看| 91精品国产麻豆国产自产在线| 日韩欧美一级精品久久| 国产欧美日韩视频一区二区| 国产精品电影院| 26uuu国产在线精品一区二区| 欧美日韩aaa| 欧美日韩在线播放一区| 欧美丰满美乳xxx高潮www| 精品国产乱码久久久久久老虎| 欧美国产日韩精品免费观看| 自拍偷拍国产亚洲| 丝袜国产日韩另类美女| 国产一区啦啦啦在线观看| av中文字幕一区| 欧美老人xxxx18| 久久伊99综合婷婷久久伊| 亚洲品质自拍视频| 日韩国产一二三区| 丰满亚洲少妇av| 欧美日韩免费观看一区三区| 久久久亚洲国产美女国产盗摄 | 香蕉加勒比综合久久| 精品一区二区三区欧美| 不卡一区中文字幕| 4438x亚洲最大成人网| 国产视频一区在线播放| 成人av在线影院| 91美女在线看| 91麻豆精品国产自产在线| 国产午夜精品美女毛片视频| 夜夜爽夜夜爽精品视频| 国产精品综合视频| 欧美精品一级二级三级| 国产精品私人自拍| 首页国产丝袜综合| 91麻豆免费观看| 精品国内二区三区| 亚洲午夜激情网页| 不卡高清视频专区| 8v天堂国产在线一区二区| 成人欧美一区二区三区黑人麻豆| 免费的成人av| 欧美日韩中字一区| 国产欧美一区二区精品仙草咪| 亚洲不卡在线观看| 99国产精品久久| 久久精子c满五个校花| 日本人妖一区二区| 91福利国产成人精品照片| 国产欧美一区视频| 韩国中文字幕2020精品| 欧美精品1区2区| 亚洲黄一区二区三区| 顶级嫩模精品视频在线看| 精品欧美久久久| 国产精品污www在线观看| 在线观看av不卡| 国产女主播一区| 极品少妇一区二区三区精品视频| 欧美日韩精品系列| 亚洲黄色录像片| av在线这里只有精品| 国产亲近乱来精品视频| 狠狠色丁香婷婷综合| 日韩一区二区三区在线观看| 亚洲国产一区二区三区| 色婷婷久久久综合中文字幕| 国产精品精品国产色婷婷| 国产不卡在线一区| 久久蜜桃av一区二区天堂| 捆绑调教一区二区三区| 欧美一区二区三区四区在线观看 | 亚洲成人av福利| 色999日韩国产欧美一区二区| 亚洲欧洲综合另类| 91农村精品一区二区在线| 亚洲欧洲无码一区二区三区| 成人午夜在线播放| 亚洲欧美在线aaa| 色综合激情五月| 亚洲亚洲精品在线观看| 精品国偷自产国产一区| 免费观看一级特黄欧美大片| 日韩欧美一区二区久久婷婷| 久久99精品视频| 久久免费看少妇高潮| 国产成人av电影在线| 国产精品网友自拍| 色偷偷成人一区二区三区91| 一区二区欧美视频| 欧美蜜桃一区二区三区| 免费亚洲电影在线| 久久婷婷一区二区三区| 成人精品国产免费网站| 亚洲视频你懂的| 欧美精品久久一区二区三区| 日本女优在线视频一区二区 | 亚洲日本电影在线| 欧美三级电影一区| 蜜乳av一区二区| 国产亚洲va综合人人澡精品| 99re8在线精品视频免费播放| 亚洲伊人色欲综合网| 日韩午夜在线观看| 成人免费黄色大片| 亚洲最快最全在线视频| 欧美一级高清片在线观看| 国产成人在线免费| 亚洲麻豆国产自偷在线| 91精品婷婷国产综合久久性色 | 欧美日韩精品欧美日韩精品一| 水蜜桃久久夜色精品一区的特点| 欧美精品一区二区三区蜜臀| 97久久精品人人做人人爽50路| 天天做天天摸天天爽国产一区| 久久综合久久99| 日本韩国一区二区| 捆绑紧缚一区二区三区视频| 中文字幕av免费专区久久| 欧美日韩国产一级| 精品中文字幕一区二区| 亚洲色图第一区| 精品国产一区二区三区久久久蜜月| 成人午夜激情影院| 日本麻豆一区二区三区视频| 久久精品视频在线免费观看| 欧美亚洲禁片免费| 高清不卡一区二区| 午夜精品久久久久久不卡8050| 久久久久久久久久看片| 欧美日韩精品一区二区| 成人动漫视频在线| 久久疯狂做爰流白浆xx| 亚洲美女免费在线| 国产亚洲自拍一区| 欧美疯狂性受xxxxx喷水图片| 99久久精品免费精品国产| 久久电影国产免费久久电影| 亚洲国产精品一区二区www在线| 国产视频一区不卡| 日韩欧美国产精品一区|