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

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

?? dib.cpp

?? 用在COM和嵌入系統開發的示例性程序源碼有詳細的開發說明.
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
		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");
	 		::DeleteObject(hBitmap);
			delete [] lpBMIH;
			::SelectPalette(hdc, hOldPalette, FALSE);
			return FALSE; 
		}
		else {
			m_dwSizeImage = lpBMIH->biSizeImage;
		}
	}
	else {
		lpBMIH->biCompression = BI_RGB; // decompress
		// figure the image size from the bitmap width and height
		DWORD dwBytes = ((DWORD) lpBMIH->biWidth * lpBMIH->biBitCount) / 32;
		if(((DWORD) lpBMIH->biWidth * lpBMIH->biBitCount) % 32) {
			dwBytes++;
		}
		dwBytes *= 4;
		m_dwSizeImage = dwBytes * lpBMIH->biHeight; // no compression
		lpBMIH->biSizeImage = m_dwSizeImage;
	} 
	// second GetDIBits call to make DIB
	LPBYTE lpImage = (LPBYTE) new char[m_dwSizeImage];
	VERIFY(::GetDIBits(pDC->GetSafeHdc(), hBitmap, 0, (UINT) lpBMIH->biHeight,
    		lpImage, (LPBITMAPINFO) lpBMIH, DIB_RGB_COLORS));
    TRACE("dib successfully created - height = %d\n", lpBMIH->biHeight);
	::DeleteObject(hBitmap);
	Empty();
	m_nBmihAlloc = m_nImageAlloc = crtAlloc;
	m_lpBMIH = lpBMIH;
	m_lpImage = lpImage;
	ComputeMetrics();
	ComputePaletteSize(m_lpBMIH->biBitCount);
	MakePalette();
	::SelectPalette(hdc, hOldPalette, FALSE);
	TRACE("Compress: new palette size = %d\n", m_nColorTableEntries); 
	return TRUE;
}

BOOL CDib::Read(CFile* pFile)
{
	// 1. read file header to get size of info hdr + color table
	// 2. read info hdr (to get image size) and color table
	// 3. read image
	// can't use bfSize in file header
	Empty();
	int nCount, nSize;
	BITMAPFILEHEADER bmfh;
	try {
		nCount = pFile->Read((LPVOID) &bmfh, sizeof(BITMAPFILEHEADER));
		if(nCount != sizeof(BITMAPFILEHEADER)) {
			throw new CException;
		}
		if(bmfh.bfType != 0x4d42) {
			throw new CException;
		}
		nSize = bmfh.bfOffBits - sizeof(BITMAPFILEHEADER);
		m_lpBMIH = (LPBITMAPINFOHEADER) new char[nSize];
		m_nBmihAlloc = m_nImageAlloc = crtAlloc;
		nCount = pFile->Read(m_lpBMIH, nSize); // info hdr & color table
		ComputeMetrics();
		ComputePaletteSize(m_lpBMIH->biBitCount);
		MakePalette();
		m_lpImage = (LPBYTE) new char[m_dwSizeImage];
		nCount = pFile->Read(m_lpImage, m_dwSizeImage); // image only
	}
	catch(CException* pe) {
		AfxMessageBox("Read error");
		pe->Delete();
		return FALSE;
	}
	return TRUE;
}

BOOL CDib::ReadSection(CFile* pFile, CDC* pDC /* = NULL */)
{
	// new function reads BMP from disk and creates a DIB section
	//    allows modification of bitmaps from disk
	// 1. read file header to get size of info hdr + color table
	// 2. read info hdr (to get image size) and color table
	// 3. create DIB section based on header parms
	// 4. read image into memory that CreateDibSection allocates
	Empty();
	int nCount, nSize;
	BITMAPFILEHEADER bmfh;
	try {
		nCount = pFile->Read((LPVOID) &bmfh, sizeof(BITMAPFILEHEADER));
		if(nCount != sizeof(BITMAPFILEHEADER)) {
			throw new CException;
		}
		if(bmfh.bfType != 0x4d42) {
			throw new CException;
		}
		nSize = bmfh.bfOffBits - sizeof(BITMAPFILEHEADER);
		m_lpBMIH = (LPBITMAPINFOHEADER) new char[nSize];
		m_nBmihAlloc = crtAlloc;
		m_nImageAlloc = noAlloc;
		nCount = pFile->Read(m_lpBMIH, nSize); // info hdr & color table
		if(m_lpBMIH->biCompression != BI_RGB) {
			throw new CException;
		}
		ComputeMetrics();
		ComputePaletteSize(m_lpBMIH->biBitCount);
		MakePalette();
		UsePalette(pDC);
		m_hBitmap = ::CreateDIBSection(pDC->GetSafeHdc(), (LPBITMAPINFO) m_lpBMIH,
			DIB_RGB_COLORS,	(LPVOID*) &m_lpImage, NULL, 0);
		ASSERT(m_lpImage != NULL);
		nCount = pFile->Read(m_lpImage, m_dwSizeImage); // image only
	}
	catch(CException* pe) {
		AfxMessageBox("ReadSection error");
		pe->Delete();
		return FALSE;
	}
	return TRUE;
}

BOOL CDib::Write(CFile* pFile)
{
	BITMAPFILEHEADER bmfh;
	bmfh.bfType = 0x4d42;  // 'BM'
	int nSizeHdr = sizeof(BITMAPINFOHEADER) + sizeof(RGBQUAD) * m_nColorTableEntries;
	bmfh.bfSize = 0;
//	bmfh.bfSize = sizeof(BITMAPFILEHEADER) + nSizeHdr + m_dwSizeImage;
	// meaning of bfSize open to interpretation (bytes, words, dwords?) -- we won't use it
	bmfh.bfReserved1 = bmfh.bfReserved2 = 0;
	bmfh.bfOffBits = sizeof(BITMAPFILEHEADER) + sizeof(BITMAPINFOHEADER) +
			sizeof(RGBQUAD) * m_nColorTableEntries;	
	try {
		pFile->Write((LPVOID) &bmfh, sizeof(BITMAPFILEHEADER));
		pFile->Write((LPVOID) m_lpBMIH,  nSizeHdr);
		pFile->Write((LPVOID) m_lpImage, m_dwSizeImage);
	}
	catch(CException* pe) {
		pe->Delete();
		AfxMessageBox("write error");
		return FALSE;
	}
	return TRUE;
}

void CDib::Serialize(CArchive& ar)
{
	DWORD dwPos;
	dwPos = ar.GetFile()->GetPosition();
	TRACE("CDib::Serialize -- pos = %d\n", dwPos);
	ar.Flush();
	dwPos = ar.GetFile()->GetPosition();
	TRACE("CDib::Serialize -- pos = %d\n", dwPos);
	if(ar.IsStoring()) {
		Write(ar.GetFile());
	}
	else {
		Read(ar.GetFile());
	}
}

// helper functions
void CDib::ComputePaletteSize(int nBitCount)
{
	if((m_lpBMIH == NULL) || (m_lpBMIH->biClrUsed == 0)) {
		switch(nBitCount) {
			case 1:
				m_nColorTableEntries = 2;
				break;
			case 4:
				m_nColorTableEntries = 16;
				break;
			case 8:
				m_nColorTableEntries = 256;
				break;
			case 16:
			case 24:
			case 32:
				m_nColorTableEntries = 0;
				break;
			default:
				ASSERT(FALSE);
		}
	}
	else {
		m_nColorTableEntries = m_lpBMIH->biClrUsed;
	}
	ASSERT((m_nColorTableEntries >= 0) && (m_nColorTableEntries <= 256)); 
}

void CDib::ComputeMetrics()
{
	if(m_lpBMIH->biSize != sizeof(BITMAPINFOHEADER)) {
		TRACE("Not a valid Windows bitmap -- probably an OS/2 bitmap\n");
		throw new CException;
	}
	m_dwSizeImage = m_lpBMIH->biSizeImage;
	if(m_dwSizeImage == 0) {
		DWORD dwBytes = ((DWORD) m_lpBMIH->biWidth * m_lpBMIH->biBitCount) / 32;
		if(((DWORD) m_lpBMIH->biWidth * m_lpBMIH->biBitCount) % 32) {
			dwBytes++;
		}
		dwBytes *= 4;
		m_dwSizeImage = dwBytes * m_lpBMIH->biHeight; // no compression
	}
	m_lpvColorTable = (LPBYTE) m_lpBMIH + sizeof(BITMAPINFOHEADER);
}

void CDib::Empty()
{
	// this is supposed to clean up whatever is in the DIB
	DetachMapFile();
	if(m_nBmihAlloc == crtAlloc) {
		delete [] m_lpBMIH;
	}
	else if(m_nBmihAlloc == heapAlloc) {
		::GlobalUnlock(m_hGlobal);
		::GlobalFree(m_hGlobal);
	}
	if(m_nImageAlloc == crtAlloc) delete [] m_lpImage;
	if(m_hPalette != NULL) ::DeleteObject(m_hPalette);
	if(m_hBitmap != NULL) ::DeleteObject(m_hBitmap);
	m_nBmihAlloc = m_nImageAlloc = noAlloc;
	m_hGlobal = NULL;
	m_lpBMIH = NULL;
	m_lpImage = NULL;
	m_lpvColorTable = NULL;
	m_nColorTableEntries = 0;
	m_dwSizeImage = 0;
	m_lpvFile = NULL;
	m_hMap = NULL;
	m_hFile = NULL;
	m_hBitmap = NULL;
	m_hPalette = NULL;
}

void CDib::DetachMapFile()
{
	if(m_hFile == NULL) return;
	::UnmapViewOfFile(m_lpvFile);
	::CloseHandle(m_hMap);
	::CloseHandle(m_hFile);
	m_hFile = NULL;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产乱码字幕精品高清av| 美女视频第一区二区三区免费观看网站| 99精品视频中文字幕| 一区二区三区高清| 久久久久国色av免费看影院| 成人h精品动漫一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了 | 国产精品自拍一区| 国产精品萝li| 欧美一区二区人人喊爽| 国产综合色在线视频区| 亚洲一区在线播放| 久久综合九色欧美综合狠狠 | 欧美自拍偷拍午夜视频| 精品少妇一区二区三区在线播放| 亚洲乱码国产乱码精品精的特点 | 久久精品噜噜噜成人av农村| 欧美福利一区二区| 日韩伦理av电影| 日韩视频123| 欧美日韩aaa| 国产精品99精品久久免费| 亚洲欧美一区二区三区久本道91| 欧美精品1区2区3区| 97久久精品人人做人人爽| 日本女优在线视频一区二区| 国产精品网站在线| 欧美一区二区三区视频在线观看| 91丝袜国产在线播放| 亚洲成人中文在线| 亚洲一区二区三区影院| 日本一区二区免费在线| 欧美激情一区二区三区蜜桃视频| 91精品国产一区二区| 欧美一二三区在线观看| 亚洲你懂的在线视频| 6080国产精品一区二区| 久草热8精品视频在线观看| 亚洲视频一区二区在线| 欧美一级在线观看| 91在线porny国产在线看| 91视频国产观看| 欧美日韩一区精品| 久久蜜桃av一区二区天堂| 亚洲人精品午夜| 国产乱妇无码大片在线观看| caoporn国产一区二区| 日韩精品一区国产麻豆| 亚洲欧美一区二区不卡| 成人精品小蝌蚪| 极品销魂美女一区二区三区| 日韩电影网1区2区| 一二三四区精品视频| 亚洲国产另类av| 国产一区二区精品在线观看| 免费在线欧美视频| 韩国成人在线视频| 久久99久久99小草精品免视看| 亚洲大片在线观看| 亚洲电影视频在线| 国产精品一区二区三区网站| 成人毛片视频在线观看| 欧美影院午夜播放| 国产网站一区二区| 蜜臀av亚洲一区中文字幕| 国产成人精品三级麻豆| 69久久夜色精品国产69蝌蚪网| 国产喂奶挤奶一区二区三区| 日本午夜一本久久久综合| www.av精品| 日韩欧美www| 国产欧美一区二区三区沐欲| 亚洲成av人片观看| 色天使久久综合网天天| 国产欧美精品日韩区二区麻豆天美| 一区二区欧美视频| 在线观看国产日韩| 亚洲欧洲精品天堂一级| 国产乱子伦一区二区三区国色天香 | 亚洲黄色尤物视频| 成人国产精品视频| 国产蜜臀97一区二区三区| 蜜臀av性久久久久av蜜臀妖精| 欧美三级中文字| 亚洲国产一区二区三区青草影视| 成人免费看视频| 2023国产精品自拍| 亚洲无人区一区| av在线综合网| 亚洲日本中文字幕区| 色噜噜久久综合| 一区二区三区国产精华| 欧美又粗又大又爽| 亚洲色图欧洲色图婷婷| 成人免费看的视频| 亚洲国产一区二区三区| 精品视频在线免费| 久久国产精品区| 成人欧美一区二区三区1314| 欧美性猛交xxxxxx富婆| 日本美女一区二区三区视频| 欧美va日韩va| 成人高清视频免费观看| 国产精品区一区二区三区| 91在线码无精品| 九九久久精品视频| 亚洲色图一区二区三区| 日韩免费电影网站| 91精品1区2区| 国产成人精品免费在线| 蜜臀av一区二区三区| 亚洲欧洲中文日韩久久av乱码| 精品少妇一区二区三区在线视频| 99国产欧美久久久精品| 国精产品一区一区三区mba视频 | 国产ts人妖一区二区| 亚洲v日本v欧美v久久精品| 国产精品久久久久久久久免费樱桃 | 成人综合婷婷国产精品久久| 久久草av在线| 另类小说一区二区三区| 日韩国产在线一| 亚洲国产另类av| 亚洲欧洲日本在线| 国产精品久久久久久久久免费樱桃 | 日韩美女在线视频 | 裸体一区二区三区| 国产在线精品一区二区三区不卡 | 综合网在线视频| 亚洲欧美日韩国产成人精品影院| 中文av字幕一区| 午夜欧美视频在线观看| 国产精品夫妻自拍| 日韩毛片视频在线看| 亚洲国产精品视频| 亚洲乱码一区二区三区在线观看| 久久午夜老司机| 中文字幕一区二区三区在线观看| 中文字幕不卡三区| 五月激情六月综合| 久久99日本精品| 成人avav影音| 日韩一区二区精品在线观看| 日韩视频在线你懂得| 久久这里只有精品首页| 亚洲精品免费电影| 免费精品99久久国产综合精品| 九九视频精品免费| 在线亚洲免费视频| 精品国产1区二区| 亚洲妇女屁股眼交7| 国产高清视频一区| 欧美一级黄色录像| 亚洲人成网站影音先锋播放| 亚洲成人资源网| www.亚洲免费av| 欧美xingq一区二区| 欧美在线色视频| 日韩视频免费直播| 亚洲成人免费看| 国产成人在线免费观看| 欧美一区二区三区在线| 青青草国产精品97视觉盛宴| 久久这里只有精品首页| 欧洲亚洲精品在线| 成人高清免费观看| 国产精品中文字幕欧美| 青青草国产精品97视觉盛宴| 亚洲成人av福利| 亚洲国产wwwccc36天堂| 国产精品系列在线| 欧美国产成人精品| 国产精品高清亚洲| 亚洲综合男人的天堂| 国产精品久久久久一区| 中文字幕 久热精品 视频在线| 国产午夜久久久久| 亚洲欧美在线aaa| 亚洲国产精品影院| 欧美aaa在线| 国内精品久久久久影院薰衣草| 精品一二三四区| 粉嫩高潮美女一区二区三区| 成人中文字幕电影| 色94色欧美sute亚洲线路一ni| 91豆麻精品91久久久久久| 欧美日韩国产精品自在自线| 欧美精品三级日韩久久| 精品国产一区二区三区av性色| 精品少妇一区二区| **性色生活片久久毛片| 亚洲国产色一区| 国产精品 欧美精品| 欧美在线不卡视频| 国产亚洲一区二区三区在线观看 | 亚洲另类春色校园小说| 亚洲黄色免费电影| 男人操女人的视频在线观看欧美| 国产一区二区在线观看免费| 91日韩精品一区|