亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
中文字幕制服丝袜一区二区三区 | 国产一区二区不卡在线| 日韩成人免费在线| 国产伦精品一区二区三区免费迷| 亚洲mv在线观看| 国产成人8x视频一区二区| www.综合网.com| 在线播放视频一区| 国产精品的网站| 久久99国产精品成人| 北条麻妃国产九九精品视频| 欧美性大战久久| 热久久一区二区| 在线观看免费一区| 国产日韩精品一区| 亚洲午夜在线观看视频在线| 精品一区二区成人精品| 欧美网站一区二区| 亚洲婷婷综合色高清在线| 国产一区二区美女| 911精品产国品一二三产区| 欧美韩日一区二区三区四区| 亚洲已满18点击进入久久| 激情五月婷婷综合| 91九色02白丝porn| 精品国产乱码久久久久久老虎| 亚洲欧洲美洲综合色网| 六月婷婷色综合| 欧美日本一道本在线视频| 2024国产精品| 午夜精品久久久久久久久久久 | 亚洲综合免费观看高清完整版 | 国产福利91精品一区二区三区| 欧美日韩视频在线观看一区二区三区| 久久久一区二区三区捆绑**| 图片区日韩欧美亚洲| 色狠狠桃花综合| 一区二区中文视频| 粉嫩aⅴ一区二区三区四区| 国产欧美一区二区精品婷婷 | 亚洲午夜av在线| 欧美日韩在线播放| 亚洲视频图片小说| 色偷偷一区二区三区| 亚洲色图欧美激情| 精品国产123| 欧美日本乱大交xxxxx| 日韩精品视频网站| 欧美tickling挠脚心丨vk| 国产在线观看免费一区| 中文字幕亚洲一区二区va在线| 97se亚洲国产综合自在线不卡| 中文字幕亚洲在| 91久久线看在观草草青青| 一区二区国产视频| 精品动漫一区二区三区在线观看| 国产黄色91视频| 亚洲伦在线观看| 日韩精品一区二区三区四区 | 日本电影欧美片| 老司机免费视频一区二区三区| 国产色产综合色产在线视频 | 9i看片成人免费高清| 视频精品一区二区| 中文字幕精品一区| 欧美午夜精品久久久久久超碰| 久久精品久久久精品美女| 久久精品夜夜夜夜久久| 91婷婷韩国欧美一区二区| 日韩国产一区二| 亚洲精品视频免费观看| 欧美性视频一区二区三区| 高潮精品一区videoshd| 日韩国产欧美一区二区三区| 国产精品福利影院| 精品国产制服丝袜高跟| 欧美日韩亚洲高清一区二区| 成年人午夜久久久| 国产一区二区美女| 久久99精品国产麻豆婷婷洗澡| 亚洲成人久久影院| 国产精品理论在线观看| 久久久电影一区二区三区| 欧美一区二区三区四区五区 | 欧美高清视频一二三区| 99re视频精品| 色综合久久综合网97色综合| 国产精品资源在线| 国产91精品在线观看| 国产一区二区三区在线观看精品| 三级欧美韩日大片在线看| 亚洲图片一区二区| 亚洲香蕉伊在人在线观| 奇米综合一区二区三区精品视频 | 日韩电影在线看| 久久超碰97中文字幕| 久久精品国产秦先生| 国产在线视视频有精品| 高清久久久久久| 欧美在线观看一区二区| 欧美伊人精品成人久久综合97| 在线观看亚洲精品| 91精品免费观看| 日韩一区二区高清| 日本一区二区视频在线观看| 怡红院av一区二区三区| 亚洲国产精品久久不卡毛片| 麻豆精品一区二区三区| 成人黄页毛片网站| 欧美日韩精品久久久| 久久久国产精华| 水野朝阳av一区二区三区| 成人自拍视频在线| 日韩免费观看高清完整版在线观看| 久久久国产精品午夜一区ai换脸| 亚洲国产欧美在线人成| 成人动漫视频在线| 欧美日韩成人激情| 亚洲乱码一区二区三区在线观看| 精品伊人久久久久7777人| 国产成人精品亚洲日本在线桃色 | 国产亚洲精品bt天堂精选| 亚洲精选一二三| 91小视频在线观看| 欧美日本一区二区| 亚洲欧美另类在线| 激情成人午夜视频| 欧美男人的天堂一二区| 亚洲成人精品一区二区| 成人动漫一区二区| 伊人一区二区三区| 色网综合在线观看| 亚洲成人中文在线| 欧美日韩一区二区三区视频| 国产精品美日韩| 在线这里只有精品| 亚洲国产aⅴ天堂久久| 欧美日韩午夜在线| 免费精品视频在线| 国产性色一区二区| 欧美色大人视频| 日本欧美一区二区三区| 91麻豆精品国产91久久久久久 | 性欧美疯狂xxxxbbbb| 欧美日韩黄色一区二区| 麻豆精品精品国产自在97香蕉 | 中文字幕的久久| 91蜜桃网址入口| 日韩精品91亚洲二区在线观看 | 亚洲欧美电影一区二区| 91麻豆国产自产在线观看| 亚洲第一主播视频| 国产亚洲精品资源在线26u| 色综合咪咪久久| 日韩精品91亚洲二区在线观看| 欧美精品一区二区久久久| eeuss鲁片一区二区三区在线观看| 亚洲精品欧美综合四区| 日韩一卡二卡三卡四卡| 成人精品视频一区| 麻豆91免费看| 爽爽淫人综合网网站| 成人欧美一区二区三区在线播放| 欧美精品xxxxbbbb| 99亚偷拍自图区亚洲| 日本视频免费一区| 五月天精品一区二区三区| 精品国产一二三区| 色综合天天综合网国产成人综合天| 亚洲成人免费av| 亚洲一区在线观看免费| 中日韩免费视频中文字幕| 日韩久久精品一区| 91精品国产综合久久福利| 色一区在线观看| 波多野结衣精品在线| 国产一区二区三区在线观看免费| 婷婷中文字幕综合| 亚洲国产精品嫩草影院| 亚洲黄一区二区三区| 欧美激情在线观看视频免费| 欧美日韩aaa| 在线视频国内自拍亚洲视频| 99re这里只有精品首页| 精品亚洲免费视频| 成人动漫一区二区在线| 不卡电影一区二区三区| caoporm超碰国产精品| 色综合色综合色综合| 欧美在线观看18| 7777精品伊人久久久大香线蕉经典版下载 | 欧美一级黄色录像| 在线观看视频一区二区 | 一区二区三区久久| 麻豆视频一区二区| 秋霞电影网一区二区| 日韩激情中文字幕| 精品一区二区三区视频在线观看| 久久精品国产久精国产| 国产精品影视在线观看|