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

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

?? dib.cpp

?? 圖像霍夫曼編碼顯示 目前只支持256色圖像的顯示
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
    // 
    // To do this, find size of header plus size of color table.  Since the 
    // first DWORD in both BITMAPINFOHEADER and BITMAPCOREHEADER conains 
    // the size of the structure, let's use this. 
 
    // Partial Calculation 
 
    dwDIBSize = *(LPDWORD)lpBI + PaletteSize((LPBYTE)lpBI);   
 
    // Now calculate the size of the image 
 
    // It's an RLE bitmap, we can't calculate size, so trust the biSizeImage 
    // field 
 
    if ((lpBI->biCompression == BI_RLE8) || (lpBI->biCompression == BI_RLE4)) 
        dwDIBSize += lpBI->biSizeImage; 
    else 
    { 
        DWORD dwBmBitsSize;  // Size of Bitmap Bits only 
 
        // It's not RLE, so size is Width (DWORD aligned) * Height 
 
        dwBmBitsSize = WIDTHBYTES((lpBI->biWidth)*((DWORD)lpBI->biBitCount)) * 
                lpBI->biHeight; 
 
        dwDIBSize += dwBmBitsSize; 
 
        // Now, since we have calculated the correct size, why don't we 
        // fill in the biSizeImage field (this will fix any .BMP files which  
        // have this field incorrect). 
 
        lpBI->biSizeImage = dwBmBitsSize; 
    } 
 
 
    // Calculate the file size by adding the DIB size to sizeof(BITMAPFILEHEADER) 
                    
    bmfHdr.bfSize = dwDIBSize + sizeof(BITMAPFILEHEADER); 
    bmfHdr.bfReserved1 = 0; 
    bmfHdr.bfReserved2 = 0; 
 
    // Now, calculate the offset the actual bitmap bits will be in 
    // the file -- It's the Bitmap file header plus the DIB header, 
    // plus the size of the color table. 
     
    bmfHdr.bfOffBits = (DWORD)sizeof(BITMAPFILEHEADER) + lpBI->biSize + 
            PaletteSize((LPBYTE)lpBI); 
 
 	TRY
	{
	    // Write the file header 
		pFile->Write(&bmfHdr, sizeof(BITMAPFILEHEADER));
		// write DIB buffer
		pFile->WriteHuge(lpBI, dwDIBSize);
	}
	CATCH (CException, e)
	{
        GlobalUnlock(m_hDib); 
		WaitCursorEnd();
		return FALSE;
	}
	END_CATCH

	GlobalUnlock(m_hDib); 
	WaitCursorEnd();
	
	return TRUE;
}

BOOL CDib::Display(CDC* pDC, int xDest, int yDest, int nWidthDest, int nHeightDest, 
 				   int xSrc, int ySrc, DWORD dwRop)
{
	CDC MemDC;
	MemDC.CreateCompatibleDC(pDC);

	CBitmap* pOldBmp = MemDC.SelectObject(m_pBitmap);

	CPalette* pOldPal = pDC->SelectPalette(m_pPalette, TRUE);
    pDC->RealizePalette();

	BOOL bSuccess = pDC->BitBlt( xDest, yDest, 
							nWidthDest, nHeightDest,
						    &MemDC, 
							xSrc, ySrc, 
							dwRop);

	MemDC.SelectObject(pOldBmp);
	pDC->SelectPalette(pOldPal, TRUE);

	return bSuccess;
}

BOOL CDib::Display(CDC * pDC, int xDest, int yDest, int nWidthDest, int nHeightDest, 
				   int xSrc, int ySrc, int nWidthSrc, int nHeightSrc, DWORD dwRop)
{
	CDC MemDC;
	MemDC.CreateCompatibleDC(pDC);

	CBitmap* pOldBmp = MemDC.SelectObject(m_pBitmap);

	CPalette* pOldPal = pDC->SelectPalette(m_pPalette, TRUE);
    pDC->RealizePalette();

	BOOL bSuccess = pDC->StretchBlt( xDest, yDest, 
								nWidthDest, nHeightDest,
						        &MemDC, 
								xSrc, ySrc, 
								nWidthSrc, nHeightSrc, 
								dwRop);

	MemDC.SelectObject(pOldBmp);
	pDC->SelectPalette(pOldPal, TRUE);

	return bSuccess;
}

BOOL CDib::Display(CDC * pDC, int x, int y, DWORD dwRop)
{
	CDC MemDC;
	MemDC.CreateCompatibleDC(pDC);

	CBitmap* pOldBmp = MemDC.SelectObject(m_pBitmap);

	CPalette* pOldPal = pDC->SelectPalette(m_pPalette, TRUE);
    pDC->RealizePalette();

	BOOL bSuccess = pDC->BitBlt(x, y, 
								GetWidth(), GetHeight(),
								&MemDC, 
								0, 0, 
								dwRop);

	MemDC.SelectObject(pOldBmp);
	pDC->SelectPalette(pOldPal, TRUE);

	return bSuccess;
}

BOOL CDib::Display(CDC* pDC, CRect rcDest, CRect rcSrc, DWORD dwRop)
{
	CDC MemDC;
	MemDC.CreateCompatibleDC(pDC);

	CBitmap* pOldBmp = MemDC.SelectObject(m_pBitmap);

	CPalette* pOldPal = pDC->SelectPalette(m_pPalette, TRUE);
    pDC->RealizePalette();

	BOOL bSuccess = pDC->StretchBlt( rcDest.left, rcDest.top, 
								rcDest.Width(), rcDest.Height(),
						        &MemDC, 
								rcSrc.left, rcSrc.top, 
								rcSrc.Width(), rcSrc.Height(),
								dwRop);

	MemDC.SelectObject(pOldBmp);
	pDC->SelectPalette(pOldPal, TRUE);

	return bSuccess;
}

BOOL CDib::BuildBitmap()
{
	if (m_pBitmap != NULL)
	{
		delete m_pBitmap;
		m_pBitmap = NULL;
		m_hBitmap = NULL;
	}
	m_hBitmap = DIBToDIBSection(m_hDib);
	if (m_hBitmap == NULL)
		return FALSE;
	m_pBitmap = new CBitmap;
	m_pBitmap->Attach(m_hBitmap);

	return TRUE;
}

BOOL CDib::BuildPalette()
{
	if (m_pPalette != NULL)
	{
		delete m_pPalette;
		m_pPalette = NULL;
	}
	HPALETTE hPalette = CreateDIBPalette(m_hDib);
	if (hPalette == NULL)
		return FALSE;
	m_pPalette = new CPalette;
	m_pPalette->Attach(hPalette);

	return TRUE;
}

BOOL CDib::UpdateInternal()
{
	BuildPalette();
	return BuildBitmap();
}

CPalette* CDib::GetPalette()
{
	return m_pPalette;
}

CBitmap* CDib::GetBitmap()
{
	return m_pBitmap;
}

BOOL CDib::IsEmpty()
{
	if (m_hDib == NULL)
		return TRUE;

	if (! GlobalLock(m_hDib))
		return TRUE;

	GlobalUnlock(m_hDib);
	return FALSE;
}

DWORD CDib::GetCompression()
{
    LPBITMAPINFOHEADER lpBI = (LPBITMAPINFOHEADER)GlobalLock(m_hDib); 
    if (!lpBI) 
	{
		GlobalUnlock(m_hDib);
        return 0; 
	}
 
	DWORD dwCompression = lpBI->biCompression;
	GlobalUnlock(m_hDib);

	return dwCompression;
}

WORD CDib::GetBitCount()
{
    LPBITMAPINFOHEADER lpBI = (LPBITMAPINFOHEADER)GlobalLock(m_hDib); 
    if (!lpBI) 
	{
		GlobalUnlock(m_hDib);
        return 0; 
	}
 
	WORD wBitCount = lpBI->biBitCount;
	GlobalUnlock(m_hDib);

	return wBitCount;
}

LONG CDib::GetWidth()
{
	// get DIB buffer pointer
    LPBYTE lpDIB = (LPBYTE)GlobalLock(m_hDib); 
	if (! lpDIB)
	{
		GlobalUnlock(m_hDib);
		return 0;
	}

	LONG lWidth = (LONG)DIBWidth(lpDIB);
	GlobalUnlock(m_hDib);

	return lWidth; 
}

LONG CDib::GetHeight()
{
	// get DIB buffer pointer
    LPBYTE lpDIB = (LPBYTE)GlobalLock(m_hDib); 
	if (! lpDIB)
	{
		GlobalUnlock(m_hDib);
		return 0;
	}

	LONG lHeight = (LONG)DIBHeight(lpDIB);
	GlobalUnlock(m_hDib);

	return lHeight; 
}

LONG CDib::GetWidthBytes()
{
	return WIDTHBYTES((GetWidth())*((DWORD)GetBitCount()));
}

COLORREF CDib::GetPixel(LONG x, LONG y)
{
	COLORREF cColor;
	switch (GetBitCount())
	{
		case 1 :	if (1<<(7-x%8) & 
						*(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y)))
						cColor = RGB(255,255,255);
					else
						cColor = RGB(0,0,0);
					break;
		case 4 :	
				{
					PALETTEENTRY PaletteColors[16];
					m_pPalette->GetPaletteEntries(0, 16, PaletteColors);
					int nIndex = (*(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y)) & 
								   (x%2 ? 0x0f : 0xf0)) >> (x%2 ? 0 : 4);
					cColor = RGB(PaletteColors[nIndex].peRed,
								 PaletteColors[nIndex].peGreen,
								 PaletteColors[nIndex].peBlue);
				}
					break;
		case 8 :	
				{
					PALETTEENTRY PaletteColors[256];
					m_pPalette->GetPaletteEntries(0, 256, PaletteColors);
					int nIndex = *(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y));
					cColor = RGB(PaletteColors[nIndex].peRed,
								 PaletteColors[nIndex].peGreen,
								 PaletteColors[nIndex].peBlue);
				}
					break;
		default:	cColor = RGB(*(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y)),
								 *(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y)+1),
								 *(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y)+2));
					break;
	}
	return cColor;
}

LONG CDib::GetPixelOffset(LONG x, LONG y)
{
	return (GetHeight()-y-1)*GetWidthBytes()+x/(8/GetBitCount());
}

LPBYTE CDib::GetBitsPtr()
{
    LPBYTE lpDIB = (LPBYTE)GlobalLock(m_hDib); 
    if (! lpDIB) 
	{
		GlobalUnlock(m_hDib);
		return NULL;
	}

	LPBYTE lpData = FindDIBBits(lpDIB);
	GlobalUnlock(m_hDib);

	return lpData;
}

HANDLE CDib::GetHandle()
{
	return m_hDib;
}

WORD CDib::GetColorNumber()
{
    LPBYTE lpBI = (LPBYTE)GlobalLock(m_hDib); 
    if (! lpBI) 
	{
		GlobalUnlock(m_hDib);
		return 0;
	}
 
	WORD wColors = DIBNumColors(lpBI);
	GlobalUnlock(m_hDib);

	return wColors;
}

WORD CDib::GetPaletteSize()
{
    LPBYTE lpBI = (LPBYTE)GlobalLock(m_hDib); 
    if (! lpBI) 
	{
		GlobalUnlock(m_hDib);
		return 0;
	}
 
	WORD wPalSize = PaletteSize(lpBI);
	GlobalUnlock(m_hDib);

	return wPalSize;
}

CDC* CDib::BeginPaint(CDC *pDC)
{
	m_pMemDC = new CDC;
	m_pMemDC->CreateCompatibleDC(pDC);
	m_pPaletteTmp = m_pMemDC->SelectPalette(m_pPalette, TRUE);
	m_pMemDC->RealizePalette();
	m_pBitmapTmp = (CBitmap *)m_pMemDC->SelectObject(m_pBitmap);
	return m_pMemDC;
}

void CDib::EndPaint()
{
	m_pMemDC->SelectObject(m_pBitmapTmp);
	m_pMemDC->SelectPalette(m_pPaletteTmp, TRUE);
	delete m_pMemDC;

	Create(m_hBitmap);
}

BOOL CDib::DisplayPalette(CDC* pDC, CRect rc)
{
	return ::DisplayPalette(pDC->GetSafeHdc(), &rc, (HPALETTE)m_pPalette->GetSafeHandle());
}

CDib * CDib::Clone()
{
	if (m_hDib == NULL)
		return NULL;

	HDIB hDIB = CopyHandle(m_hDib);
	if (hDIB == NULL)
		return NULL;

	CDib *pDib = new CDib;
	pDib->m_hDib = hDIB;
	pDib->BuildPalette();
	pDib->BuildBitmap();

	return pDib;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕中文字幕一区| 日韩一级黄色大片| 中文字幕免费不卡| 成人免费视频caoporn| 国产精品久久久久永久免费观看 | 成人av手机在线观看| 欧美激情一区二区三区全黄| 国产凹凸在线观看一区二区| 中文字幕乱码亚洲精品一区| 色悠悠久久综合| 亚洲图片欧美综合| 日韩区在线观看| 成人理论电影网| 亚洲一区二区三区国产| 日韩午夜精品电影| 国产电影精品久久禁18| 亚洲人成网站在线| 欧美一区二区免费观在线| 国产主播一区二区| 自拍偷拍国产精品| 日韩三级电影网址| 99这里只有精品| 日韩精品乱码免费| 中文字幕一区二区三区四区| 欧美亚洲综合久久| 国产在线播精品第三| 亚洲视频在线一区二区| 欧美一区二区三区的| 国产suv一区二区三区88区| 亚洲女同ⅹxx女同tv| 91麻豆精品91久久久久久清纯 | 国产寡妇亲子伦一区二区| 综合久久久久久| 日韩精品最新网址| 色av成人天堂桃色av| 久久国产欧美日韩精品| 亚洲黄色性网站| 精品处破学生在线二十三| 91久久精品一区二区三区| 麻豆国产精品官网| 一区二区三区美女| 中文av字幕一区| 日韩久久久精品| 欧美日产在线观看| 91丝袜呻吟高潮美腿白嫩在线观看| 日韩**一区毛片| 亚洲女与黑人做爰| 中文字幕av一区 二区| 欧美一区二区高清| 欧美亚洲动漫精品| 99这里都是精品| 国产一区二区0| 日韩电影一区二区三区| 亚洲一区二区三区四区的| 欧美国产欧美亚州国产日韩mv天天看完整| 欧美日韩国产电影| 欧美性感一区二区三区| 91丨porny丨国产入口| 国产精品一区免费在线观看| 男男成人高潮片免费网站| 一区二区三区.www| 亚洲精选视频免费看| 欧美国产亚洲另类动漫| 国产亚洲精品久| 欧美xingq一区二区| 91精品婷婷国产综合久久竹菊| 一本色道综合亚洲| 91麻豆福利精品推荐| av在线一区二区三区| 不卡视频免费播放| 懂色av一区二区三区免费观看 | 狠狠色综合色综合网络| 免费看日韩a级影片| 午夜精品爽啪视频| 亚洲一二三区在线观看| 一区二区三区丝袜| 一区二区三区欧美在线观看| 亚洲精品伦理在线| 一区二区三区四区中文字幕| 亚洲国产成人porn| 亚洲午夜成aⅴ人片| 亚洲一区二区欧美日韩| 偷拍亚洲欧洲综合| 日韩成人伦理电影在线观看| 人人超碰91尤物精品国产| 久久草av在线| 国产精品一区二区在线观看网站| 久久99最新地址| 国产v日产∨综合v精品视频| 成人免费精品视频| 色婷婷激情一区二区三区| 欧美三区在线观看| 日韩三级视频中文字幕| 久久色成人在线| 亚洲欧洲成人自拍| 亚洲在线中文字幕| 日本麻豆一区二区三区视频| 经典三级一区二区| 成年人午夜久久久| 欧美日韩国产首页| 精品精品欲导航| 国产精品天干天干在观线| 综合激情网...| 日韩成人精品视频| 国产九九视频一区二区三区| 成人黄色电影在线| 欧美日韩高清一区| 欧美不卡视频一区| 中文字幕在线观看一区二区| 亚洲高清不卡在线| 久久国产剧场电影| av福利精品导航| 欧美疯狂性受xxxxx喷水图片| 2021国产精品久久精品| 专区另类欧美日韩| 久久99国产精品免费网站| 成人av资源站| 欧美一区二区三区免费观看视频| 亚洲国产精品精华液2区45| 一区二区三区波多野结衣在线观看| 免费xxxx性欧美18vr| 成人免费高清在线观看| 日韩一区二区免费视频| 一区精品在线播放| 久草中文综合在线| 欧美日韩小视频| 中文字幕色av一区二区三区| 麻豆精品国产传媒mv男同 | 亚洲美女一区二区三区| 免费在线观看一区二区三区| 97久久超碰国产精品电影| 精品成人一区二区三区四区| 亚洲精品日韩综合观看成人91| 国产剧情在线观看一区二区| 91麻豆精品国产自产在线观看一区 | 波多野结衣91| 日韩一区二区高清| 一区二区三区欧美日韩| 丁香婷婷深情五月亚洲| 日韩一区二区精品葵司在线| 亚洲午夜一区二区| 99久久婷婷国产| 日本一区二区三区久久久久久久久不| 日韩电影免费在线| 精品视频资源站| 亚洲综合视频在线| 99精品欧美一区二区蜜桃免费| 久久久午夜精品| 久久99精品久久久久久久久久久久| 欧美私模裸体表演在线观看| 中文字幕制服丝袜一区二区三区 | 国产午夜精品在线观看| 另类专区欧美蜜桃臀第一页| 欧美年轻男男videosbes| 一区二区三区视频在线观看| 99精品欧美一区二区三区小说| 日本一区二区动态图| 国产成人日日夜夜| 国产色一区二区| 国产精品69久久久久水密桃| 久久一区二区视频| 国产一区二区视频在线播放| 日韩女优毛片在线| 裸体一区二区三区| 精品久久久久99| 国产美女娇喘av呻吟久久| 国产亚洲制服色| 国产69精品一区二区亚洲孕妇| 久久一区二区三区四区| 国产精品99久久久| 国产精品第一页第二页第三页| av中文字幕一区| 亚洲美女视频在线| 欧美熟乱第一页| 亚洲chinese男男1069| 欧美高清激情brazzers| 日本va欧美va瓶| 久久众筹精品私拍模特| 波多野结衣亚洲一区| 亚洲三级小视频| 欧美色综合久久| 琪琪久久久久日韩精品| xf在线a精品一区二区视频网站| 国产一区二区影院| 亚洲色图制服丝袜| 欧美日韩国产电影| 国产美女精品在线| 亚洲精品五月天| 日韩一级片在线观看| 国产91精品久久久久久久网曝门 | 欧美性欧美巨大黑白大战| 亚洲成人精品一区| 日韩精品一区二区三区swag | av日韩在线网站| 天天综合网 天天综合色| 精品久久久久久久久久久久久久久 | 欧美精品在线观看播放| 精品一区二区三区免费视频| 国产精品素人视频| 欧美日本免费一区二区三区|