📄 bcgptoolbarimages.cpp
字号:
{
return FALSE;
}
HBITMAP bmp = ::CreateBitmap (1, 1, 1, bi.biBitCount, NULL);
if (bmp == NULL)
{
::DeleteDC(hDC);
return NULL;
}
HBITMAP hOldBitmap = (HBITMAP)::SelectObject (hDC, bmp);
hPal = SelectPalette(hDC,hPal,FALSE);
RealizePalette(hDC);
// Allocate enough memory to hold bitmapinfoheader and color table
hDIB = GlobalAlloc(GMEM_FIXED,dwLen);
if (!hDIB)
{
::SelectPalette (hDC,hPal,FALSE);
if (hOldBitmap != NULL)
{
::SelectObject (hDC, hOldBitmap);
}
::DeleteObject (bmp);
::DeleteDC(hDC);
return NULL;
}
lpbi = (LPBITMAPINFOHEADER)hDIB;
*lpbi = bi;
// Call GetDIBits with a NULL lpBits param, so the device driver
// will calculate the biSizeImage field
GetDIBits(hDC, bitmap, 0L, (DWORD)bi.biHeight,
(LPBYTE)NULL, (LPBITMAPINFO)lpbi, (DWORD)DIB_RGB_COLORS);
bi = *lpbi;
// If the driver did not fill in the biSizeImage field, then compute it
// Each scan line of the image is aligned on a DWORD (32bit) boundary
if (bi.biSizeImage == 0){
bi.biSizeImage = ((((bi.biWidth * bi.biBitCount) + 31) & ~31) / 8)
* bi.biHeight;
// If a compression scheme is used the result may infact be larger
// Increase the size to account for this.
if (dwCompression != BI_RGB)
bi.biSizeImage = (bi.biSizeImage * 3) / 2;
}
// Realloc the buffer so that it can hold all the bits
dwLen += bi.biSizeImage;
handle = GlobalReAlloc(hDIB, dwLen, GMEM_MOVEABLE);
if (handle != NULL)
hDIB = handle;
else{
GlobalFree(hDIB);
// Reselect the original palette
SelectPalette(hDC,hPal,FALSE);
if (hOldBitmap != NULL)
{
::SelectObject (hDC, hOldBitmap);
}
::DeleteObject (bmp);
::DeleteDC(hDC);
return NULL;
}
// Get the bitmap bits
lpbi = (LPBITMAPINFOHEADER)hDIB;
// FINALLY get the DIB
BOOL bGotBits = GetDIBits( hDC, bitmap,
0L, // Start scan line
(DWORD)bi.biHeight, // # of scan lines
(LPBYTE)lpbi // address for bitmap bits
+ (bi.biSize + nColors * sizeof(RGBQUAD)),
(LPBITMAPINFO)lpbi, // address of bitmapinfo
(DWORD)DIB_RGB_COLORS); // Use RGB for color table
if( !bGotBits )
{
GlobalFree(hDIB);
SelectPalette(hDC,hPal,FALSE);
if (hOldBitmap != NULL)
{
::SelectObject (hDC, hOldBitmap);
}
::DeleteObject (bmp);
::DeleteDC(hDC);
return NULL;
}
// Convert color table to the standard 3-d colors:
DWORD* pColorTable = (DWORD*)(((LPBYTE)lpbi) + (UINT) lpbi->biSize);
for (int iColor = 0; iColor < nColors; iColor ++)
{
pColorTable[iColor] = CBCGPToolBarImages::MapFromSysColor (pColorTable[iColor]);
}
SelectPalette(hDC,hPal,FALSE);
if (hOldBitmap != NULL)
{
::SelectObject (hDC, hOldBitmap);
}
::DeleteObject (bmp);
::DeleteDC(hDC);
return hDIB;
}
/////////////////////////////////////////////////////////////////////////////
// CBCGPToolBarImages diagnostics
#ifdef _DEBUG
void CBCGPToolBarImages::AssertValid() const
{
CObject::AssertValid();
ASSERT(m_hbmImageWell != NULL);
}
void CBCGPToolBarImages::Dump(CDumpContext& dc) const
{
CObject::Dump(dc);
dc << "\nm_bUserImagesList = " << m_bUserImagesList;
dc << "\nm_sizeImage = " << m_sizeImage;
if (m_bUserImagesList)
{
dc << "\nm_strUDLPath = " << m_strUDLPath;
}
if (dc.GetDepth() > 0)
{
}
dc << "\n";
}
#endif
BOOL CBCGPToolBarImages::CopyImageToClipboard (int iImage)
{
CBCGPLocalResource locaRes;
try
{
CWindowDC dc (NULL);
//----------------------
// Create a bitmap copy:
//----------------------
CDC memDCDest;
memDCDest.CreateCompatibleDC (NULL);
CBitmap bitmapCopy;
if (!bitmapCopy.CreateCompatibleBitmap (&dc, m_sizeImage.cx, m_sizeImage.cy))
{
AfxMessageBox (IDP_BCGBARRES_CANT_COPY_BITMAP);
return FALSE;
}
CBitmap* pOldBitmapDest = memDCDest.SelectObject (&bitmapCopy);
memDCDest.FillRect (CRect (0, 0, m_sizeImage.cx, m_sizeImage.cy),
&globalData.brBtnFace);
CBCGPDrawState ds;
PrepareDrawImage (ds, FALSE);
Draw (&memDCDest, 0, 0, iImage);
EndDrawImage (ds);
memDCDest.SelectObject (pOldBitmapDest);
if (!AfxGetMainWnd ()->OpenClipboard ())
{
AfxMessageBox (IDP_BCGBARRES_CANT_COPY_BITMAP);
return FALSE;
}
if (!::EmptyClipboard ())
{
AfxMessageBox (IDP_BCGBARRES_CANT_COPY_BITMAP);
::CloseClipboard ();
return FALSE;
}
HANDLE hclipData = ::SetClipboardData (CF_BITMAP, bitmapCopy.Detach ());
if (hclipData == NULL)
{
AfxMessageBox (IDP_BCGBARRES_CANT_COPY_BITMAP);
TRACE (_T("CBCGToolBar::OnBcgbarresCopyImage error. Error code = %x\n"), GetLastError ());
}
::CloseClipboard ();
return TRUE;
}
catch (...)
{
AfxMessageBox (IDP_BCGBARRES_INTERLAL_ERROR);
}
return FALSE;
}
//****************************************************************************************
BOOL CBCGPToolBarImages::CopyTo (CBCGPToolBarImages& dest)
{
if (dest.m_bIsTemporary)
{
ASSERT(FALSE);
return FALSE;
}
if (dest.IsValid ())
{
dest.Clear ();
}
dest.m_sizeImage = m_sizeImage;
dest.m_sizeImageDest = m_sizeImageDest;
dest.m_bUserImagesList = m_bUserImagesList;
dest.m_strUDLPath = m_strUDLPath;
dest.m_bModified = m_bModified;
dest.m_iCount = m_iCount;
dest.m_clrTransparent = m_clrTransparent;
dest.m_bReadOnly = m_bReadOnly;
dest.m_hbmImageWell = (HBITMAP) ::CopyImage (m_hbmImageWell, IMAGE_BITMAP, 0, 0, LR_CREATEDIBSECTION);
for (POSITION pos = m_lstOrigResIds.GetHeadPosition (); pos != NULL;)
{
UINT uiResId = m_lstOrigResIds.GetNext (pos);
dest.m_lstOrigResIds.AddTail (uiResId);
int iOffset = -1;
if (m_mapOrigResOffsets.Lookup (uiResId, iOffset))
{
dest.m_mapOrigResOffsets.SetAt (uiResId, iOffset);
}
}
for (POSITION posInst = m_lstOrigResInstances.GetHeadPosition (); pos != NULL;)
{
HINSTANCE hInst = m_lstOrigResInstances.GetNext (posInst);
dest.m_lstOrigResInstances.AddTail (hInst);
}
return TRUE;
}
//****************************************************************************************
void CBCGPToolBarImages::Clear ()
{
if (m_bIsTemporary)
{
ASSERT (FALSE);
return;
}
AfxDeleteObject((HGDIOBJ*)&m_hbmImageWell);
m_hbmImageWell = NULL;
AfxDeleteObject((HGDIOBJ*)&m_hbmImageLight);
m_hbmImageLight = NULL;
m_lstOrigResIds.RemoveAll();
m_mapOrigResOffsets.RemoveAll ();
m_lstOrigResInstances.RemoveAll ();
m_strUDLPath.Empty();
m_bUserImagesList = FALSE;
m_iCount = 0;
m_bModified = FALSE;
}
//*************************************************************************************
void CBCGPToolBarImages::TransparentBlt( HDC hdcDest, int nXDest, int nYDest, int nWidth,
int nHeight, CDC* pDcSrc, int nXSrc, int nYSrc,
COLORREF colorTransparent,
int nWidthDest/* = -1*/, int nHeightDest/* = -1*/)
{
CDC dc, memDC, maskDC;
dc.Attach( hdcDest );
maskDC.CreateCompatibleDC(&dc);
CBitmap maskBitmap;
int cx = nWidthDest == -1 ? nWidth : nWidthDest;
int cy = nHeightDest == -1 ? nHeight : nHeightDest;
//add these to store return of SelectObject() calls
CBitmap* pOldMemBmp = NULL;
CBitmap* pOldMaskBmp = NULL;
memDC.CreateCompatibleDC(&dc);
CBitmap bmpImage;
bmpImage.CreateCompatibleBitmap( &dc, cx, cy);
pOldMemBmp = memDC.SelectObject( &bmpImage );
if (nWidthDest == -1 || (nWidthDest == nWidth && nHeightDest == nHeight))
{
memDC.BitBlt( 0,0,nWidth, nHeight, pDcSrc, nXSrc, nYSrc, SRCCOPY);
}
else
{
memDC.StretchBlt (0,0, nWidthDest, nHeightDest, pDcSrc,
nXSrc, nYSrc, nWidth, nHeight, SRCCOPY);
}
// Create monochrome bitmap for the mask
maskBitmap.CreateBitmap (cx, cy, 1, 1, NULL );
pOldMaskBmp = maskDC.SelectObject( &maskBitmap );
memDC.SetBkColor( colorTransparent );
// Create the mask from the memory DC
maskDC.BitBlt (0, 0, cx, cy, &memDC, 0, 0, SRCCOPY);
// Set the background in memDC to black. Using SRCPAINT with black
// and any other color results in the other color, thus making
// black the transparent color
memDC.SetBkColor(RGB(0,0,0));
memDC.SetTextColor(RGB(255,255,255));
memDC.BitBlt(0, 0, cx, cy, &maskDC, 0, 0, SRCAND);
// Set the foreground to black. See comment above.
dc.SetBkColor(RGB(255,255,255));
dc.SetTextColor(RGB(0,0,0));
dc.BitBlt (nXDest, nYDest, cx, cy, &maskDC, 0, 0, SRCAND);
// Combine the foreground with the background
dc.BitBlt(nXDest, nYDest, cx, cy, &memDC,
0, 0, SRCPAINT);
if (pOldMaskBmp)
maskDC.SelectObject( pOldMaskBmp );
if (pOldMemBmp)
memDC.SelectObject( pOldMemBmp );
dc.Detach();
}
//**********************************************************************************
BOOL CBCGPToolBarImages::MapTo3dColors ( BOOL bUseRGBQUAD/* = TRUE*/,
COLORREF clrSrc/* = (COLORREF)-1*/,
COLORREF clrDest/* = (COLORREF)-1*/)
{
if (m_hbmImageWell == NULL)
{
return FALSE;
}
if (clrSrc != (COLORREF)-1 && clrDest == (COLORREF)-1)
{
ASSERT (FALSE);
return FALSE;
}
//-------------------------------------------------------
// Create memory source DC and select an original bitmap:
//-------------------------------------------------------
CDC memDCSrc;
memDCSrc.CreateCompatibleDC (NULL);
HBITMAP hOldBitmapSrc = NULL;
int iBitmapWidth;
int iBitmapHeight;
//-------------------------------
// Get original bitmap attrbutes:
//-------------------------------
BITMAP bmp;
if (::GetObject (m_hbmImageWell, sizeof (BITMAP), &bmp) == 0)
{
return FALSE;
}
hOldBitmapSrc = (HBITMAP) memDCSrc.SelectObject (m_hbmImageWell);
if (hOldBitmapSrc == NULL)
{
return FALSE;
}
iBitmapWidth = bmp.bmWidth;
iBitmapHeight = bmp.bmHeight;
//----------------------------------------------------------
// Create a new bitmap compatibel with the source memory DC:
// (original bitmap SHOULD BE ALREADY SELECTED!):
//----------------------------------------------------------
HBITMAP hNewBitmap = (HBITMAP) ::CreateCompatibleBitmap (memDCSrc,
iBitmapWidth,
iBitmapHeight);
if (hNewBitmap == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
return FALSE;
}
//------------------------------
// Create memory destination DC:
//------------------------------
CDC memDCDst;
memDCDst.CreateCompatibleDC (&memDCSrc);
HBITMAP hOldBitmapDst = (HBITMAP) memDCDst.SelectObject (hNewBitmap);
if (hOldBitmapDst == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
::DeleteObject (hNewBitmap);
return FALSE;
}
//-----------------------------
// Copy original bitmap to new:
//-----------------------------
memDCDst.BitBlt (0, 0, iBitmapWidth, iBitmapHeight,
&memDCSrc, 0, 0, SRCCOPY);
//------------------------------------
// Change a specific colors to system:
//------------------------------------
for (int x = 0; x < iBitmapWidth; x ++)
{
for (int y = 0; y < iBitmapHeight; y ++)
{
COLORREF clrOrig = ::GetPixel (memDCDst, x, y);
if (clrSrc != (COLORREF)-1)
{
if (clrOrig == clrSrc)
{
::SetPixel (memDCDst, x, y, clrDest);
}
}
else
{
COLORREF clrNew = m_nBitsPerPixel == 24 && !m_bDisableTrueColorAlpha ?
MapToSysColorAlpha (clrOrig) :
MapToSysColor (clrOrig, bUseRGBQUAD);
if (clrOrig != clrNew)
{
::SetPixel (memDCDst, x, y, clrNew);
}
}
}
}
memDCDst.SelectObject (hOldBitmapDst);
memDCSrc.SelectObject (hOldBitmapSrc);
::DeleteObject (m_hbmImageWell);
m_hbmImageWell = hNewBitmap;
return TRUE;
}
//*******************************************************************************
void CBCGPToolBarImages::CopyTemp (CBCGPToolBarImages& imagesDest)
{
imagesDest.Clear ();
imagesDest.m_bIsTemporary = TRUE;
imagesDest.m_sizeImage = m_sizeImage;
imagesDest.m_sizeImageDest = m_sizeImageDest;
imagesDest.m_hbmImageWell = m_hbmImageWell;
imagesDest.m_bUserImagesList = m_bUserImagesList;
imagesDest.m_iCount = m_iCount;
imagesDest.m_bReadOnly = TRUE;
}
//*******************************************************************************
BOOL CBCGPToolBarImages::UpdateLightImage ()
{
AfxDeleteObject((HGDIOBJ*)&m_hbmImageLight);
m_hbmImageLight = NULL;
if (m_hbmImageWell == NULL)
{
return TRUE;
}
OSVERSIONINFO osvi;
osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
::GetVersionEx (&osvi);
if (globalData.m_nBitsPerPixel <= 8 ||
osvi.dwPlatformId != VER_PLATFORM_WIN32_NT)
{
return TRUE;
}
//-------------------------------------------------------
// Create memory source DC and select an original bitmap:
//-------------------------------------------------------
CDC memDCSrc;
memDCSrc.CreateCompatibleDC (NULL);
BITMAP bmp;
if (::GetObject (m_hbmImageWell, sizeof (BITMAP), &bmp) == 0)
{
return FALSE;
}
int iBitmapWidth = bmp.bmWidth;
int iBitmapHeight = bmp.bmHeight;
HBITMAP hOldBitmapSrc = (HBITMAP) memDCSrc.SelectObject (m_hbmImageWell);
if (hOldBitmapSrc == NULL)
{
return FALSE;
}
//------------------------------------------------------
// Create memory destination DC and select a new bitmap:
//------------------------------------------------------
CDC memDCDst;
memDCDst.CreateCompatibleDC (&memDCSrc);
BITMAPINFO bi;
// Fill in the BITMAPINFOHEADER
bi.bmiHeader.biSize = sizeof(BITMAPINFOHEADER);
bi.bmiHeader.biWidth = iBitmapWidth;
bi.bmiHeader.biHeight = iBitmapHeight;
bi.bmiHeader.biPlanes = 1;
bi.bmiHeader.biBitCount = 32;
bi.bmiHeader.biCompression = BI_RGB;
bi.bmiHeader.biSizeImage = iBitmapWidth * iBitmapHeight;
bi.bmiHeader.biXPelsPerMeter = 0;
bi.bmiHeader.biYPelsPerMeter = 0;
bi.bmiHeader.biClrUsed = 0;
bi.bmiHeader.biClrImportant = 0;
COLORREF* pBits = NULL;
m_hbmImageLight = CreateDIBSection (
memDCDst.m_hDC, &bi, DIB_RGB_COLORS, (void **)&pBits,
NULL, NULL);
if (m_hbmImageLight == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
return FALSE;
}
HBITMAP hOldBitmapDst = (HBITMAP) memDCDst.SelectObject (m_hbmImageLight);
if (hOldBitmapDst == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
::DeleteObject (m_hbmImageLight);
m_hbmImageLight = NULL;
return FALSE;
}
//-----------------------------
// Copy original bitmap to new:
//-----------------------------
memDCDst.BitBlt (0, 0, iBitmapWidth, iBitmapHeight,
&memDCSrc, 0, 0, SRCCOPY);
CBCGPDrawManager dm (memDCDst);
dm.HighlightRect (CRect (0, 0, iBitmapWidth, iBitmapHeight),
130,
m_clrTransparent == -1 ? globalData.clrBtnFace : m_clrTransparent);
memDCDst.SelectObject (hOldBitmapDst);
memDCSrc.SelectObject (hOldBitmapSrc);
return TRUE;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -