📄 bcgptoolbarimages.cpp
字号:
}
return TRUE;
}
//********************************************************************************
void CBCGPToolBarImages::FillDitheredRect (CDC* pDC, const CRect& rect)
{
ASSERT_VALID(pDC);
pDC->FillRect (&rect, &globalData.brLight);
}
//********************************************************************************
void CBCGPToolBarImages::OnSysColorChange()
{
if (m_bIsTemporary)
{
return;
}
int iOldCount = m_iCount;
// re-color bitmap for toolbar
if (m_hbmImageWell != NULL)
{
if (m_bUserImagesList)
{
Load (m_strUDLPath);
}
else
{
// Image was buit from the resources...
if (m_lstOrigResIds.IsEmpty ())
{
return;
}
ASSERT (m_lstOrigResInstances.GetCount () == m_lstOrigResIds.GetCount ());
AfxDeleteObject((HGDIOBJ*)&m_hbmImageWell); // get rid of old one
POSITION posInst = m_lstOrigResInstances.GetHeadPosition ();
for (POSITION pos = m_lstOrigResIds.GetHeadPosition ();
pos != NULL;)
{
ASSERT (posInst != NULL);
UINT uiResId = m_lstOrigResIds.GetNext (pos);
ASSERT (uiResId > 0);
HINSTANCE hInst = m_lstOrigResInstances.GetNext (posInst);
ASSERT (hInst != NULL);
HBITMAP hbmp = (HBITMAP) ::LoadImage (
hInst,
MAKEINTRESOURCE (uiResId),
IMAGE_BITMAP,
0, 0,
LR_CREATEDIBSECTION | LR_LOADMAP3DCOLORS);
AddImage (hbmp);
::DeleteObject (hbmp);
}
}
}
UpdateCount ();
ASSERT (iOldCount == m_iCount);
if (m_nBitsPerPixel > 8)
{
//------------------------------------------------
// LR_LOADMAP3DCOLORS don't support > 8bpp images,
// we should convert it now:
//------------------------------------------------
MapTo3dColors (FALSE);
}
UpdateLightImage ();
m_clrImageShadow = globalData.clrBtnShadow;
}
//********************************************************************************
void CBCGPToolBarImages::UpdateCount ()
{
if (m_hbmImageWell == NULL)
{
m_iCount = 0;
return;
}
BITMAP bmp;
if (::GetObject (m_hbmImageWell, sizeof (BITMAP), &bmp) == 0)
{
m_iCount = 0;
return;
}
int iWidth = bmp.bmWidth;
m_iCount = iWidth / m_sizeImage.cx;
}
//////////////////////////////////////////
// Image editing methods:
//////////////////////////////////////////
int CBCGPToolBarImages::AddImage (HBITMAP hbmp)
{
if (m_bIsTemporary)
{
ASSERT (FALSE);
return -1;
}
//-------------------------------------------------------
// Create memory source DC and select an original bitmap:
//-------------------------------------------------------
CDC memDCSrc;
memDCSrc.CreateCompatibleDC (NULL);
HBITMAP hOldBitmapSrc = NULL;
int iBitmapWidth;
int iBitmapHeight;
int iNewBitmapWidth;
BITMAP bmp;
if (::GetObject (hbmp, sizeof (BITMAP), &bmp) == 0)
{
return -1;
}
iNewBitmapWidth = bmp.bmWidth;
iBitmapHeight = bmp.bmHeight;
if (m_hbmImageWell != NULL)
{
//-------------------------------
// Get original bitmap attrbutes:
//-------------------------------
if (::GetObject (m_hbmImageWell, sizeof (BITMAP), &bmp) == 0)
{
return -1;
}
hOldBitmapSrc = (HBITMAP) memDCSrc.SelectObject (m_hbmImageWell);
if (hOldBitmapSrc == NULL)
{
return -1;
}
iBitmapWidth = bmp.bmWidth;
iBitmapHeight = bmp.bmHeight;
}
else
{
iBitmapWidth = 0;
hOldBitmapSrc = (HBITMAP) memDCSrc.SelectObject (hbmp);
if (hOldBitmapSrc == NULL)
{
return -1;
}
}
//----------------------------------------------------------
// Create a new bitmap compatibel with the source memory DC
// (original bitmap SHOULD BE ALREADY SELECTED!):
//----------------------------------------------------------
HBITMAP hNewBitmap = (HBITMAP) ::CreateCompatibleBitmap (memDCSrc,
iBitmapWidth + iNewBitmapWidth,
iBitmapHeight);
if (hNewBitmap == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
return -1;
}
//------------------------------------------------------
// Create memory destination DC and select a new bitmap:
//------------------------------------------------------
CDC memDCDst;
memDCDst.CreateCompatibleDC (&memDCSrc);
HBITMAP hOldBitmapDst = (HBITMAP) memDCDst.SelectObject (hNewBitmap);
if (hOldBitmapDst == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
::DeleteObject (hNewBitmap);
return -1;
}
if (m_hbmImageWell != NULL)
{
//-----------------------------
// Copy original bitmap to new:
//-----------------------------
memDCDst.BitBlt (0, 0, iBitmapWidth, iBitmapHeight,
&memDCSrc, 0, 0, SRCCOPY);
}
//--------------------------------
// Select a new image and copy it:
//--------------------------------
if (memDCSrc.SelectObject (hbmp) == NULL)
{
memDCDst.SelectObject (hOldBitmapDst);
memDCSrc.SelectObject (hOldBitmapSrc);
::DeleteObject (hNewBitmap);
return -1;
}
memDCDst.BitBlt (iBitmapWidth, 0, iNewBitmapWidth, iBitmapHeight,
&memDCSrc, 0, 0, SRCCOPY);
memDCDst.SelectObject (hOldBitmapDst);
memDCSrc.SelectObject (hOldBitmapSrc);
if (m_hbmImageWell != NULL)
{
::DeleteObject (m_hbmImageWell);
}
m_hbmImageWell = hNewBitmap;
m_bModified = TRUE;
UpdateCount ();
UpdateLightImage ();
return m_iCount - 1;
}
//*******************************************************************************
BOOL CBCGPToolBarImages::UpdateImage (int iImage, HBITMAP hbmp)
{
if (m_bIsTemporary)
{
ASSERT (FALSE);
return FALSE;
}
if (!m_bUserImagesList) // Only user images can be edited!
{
return FALSE;
}
CWindowDC dc (NULL);
CBitmap bitmap;
CDC memDCSrc;
CDC memDCDst;
memDCSrc.CreateCompatibleDC (&dc);
memDCDst.CreateCompatibleDC (&dc);
HBITMAP hOldBitmapDst = (HBITMAP) memDCDst.SelectObject (m_hbmImageWell);
HBITMAP hOldBitmapSrc = (HBITMAP) memDCSrc.SelectObject (hbmp);
memDCDst.BitBlt (m_sizeImage.cx * iImage, 0, m_sizeImage.cx, m_sizeImage.cy,
&memDCSrc, 0, 0, SRCCOPY);
memDCDst.SelectObject (hOldBitmapDst);
memDCSrc.SelectObject (hOldBitmapSrc);
m_bModified = TRUE;
UpdateLightImage ();
return TRUE;
}
//*******************************************************************************
BOOL CBCGPToolBarImages::DeleteImage (int iImage)
{
if (m_bIsTemporary)
{
ASSERT (FALSE);
return FALSE;
}
if (!m_bUserImagesList) // Only user images can be edited!
{
return FALSE;
}
if (iImage < 0 || iImage >= GetCount ()) // Wrong index
{
return FALSE;
}
//-------------------------------
// Get original bitmap attrbutes:
//-------------------------------
BITMAP bmp;
if (::GetObject (m_hbmImageWell, sizeof (BITMAP), &bmp) == 0)
{
return FALSE;
}
//-------------------------------------------------------
// Create memory source DC and select an original bitmap:
//-------------------------------------------------------
CDC memDCSrc;
memDCSrc.CreateCompatibleDC (NULL);
HBITMAP hOldBitmapSrc = (HBITMAP) memDCSrc.SelectObject (m_hbmImageWell);
if (hOldBitmapSrc == NULL)
{
return FALSE;
}
//----------------------------------------------------------
// Create a new bitmap compatibel with the source memory DC
// (original bitmap SHOULD BE ALREADY SELECTED!):
//----------------------------------------------------------
HBITMAP hNewBitmap = (HBITMAP) ::CreateCompatibleBitmap (memDCSrc,
bmp.bmWidth - m_sizeImage.cx,
bmp.bmHeight);
if (hNewBitmap == NULL)
{
memDCSrc.SelectObject (hOldBitmapSrc);
return FALSE;
}
//------------------------------------------------------
// Create memory destination DC and select a new bitmap:
//------------------------------------------------------
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:
//-----------------------------
if (iImage != 0)
{
memDCDst.BitBlt (0, 0,
m_sizeImage.cx * iImage, bmp.bmHeight,
&memDCSrc, 0, 0, SRCCOPY);
}
if (iImage != m_iCount - 1)
{
memDCDst.BitBlt (m_sizeImage.cx * iImage, 0,
bmp.bmWidth - (m_iCount - iImage - 1) * m_sizeImage.cx, bmp.bmHeight,
&memDCSrc,
m_sizeImage.cx * (iImage + 1), 0, SRCCOPY);
}
memDCDst.SelectObject (hOldBitmapDst);
memDCSrc.SelectObject (hOldBitmapSrc);
::DeleteObject (m_hbmImageWell);
m_hbmImageWell = hNewBitmap;
m_bModified = TRUE;
UpdateCount ();
UpdateLightImage ();
return TRUE;
}
//*******************************************************************************
COLORREF CBCGPToolBarImages::MapToSysColor (COLORREF color, BOOL bUseRGBQUAD)
{
struct COLORMAP
{
// use DWORD instead of RGBQUAD so we can compare two RGBQUADs easily
DWORD rgbqFrom;
int iSysColorTo;
};
static const COLORMAP sysColorMap[] =
{
// mapping from color in DIB to system color
{ RGB_TO_RGBQUAD(0x00, 0x00, 0x00), COLOR_BTNTEXT }, // black
{ RGB_TO_RGBQUAD(0x80, 0x80, 0x80), COLOR_BTNSHADOW }, // dark grey
{ RGB_TO_RGBQUAD(0xC0, 0xC0, 0xC0), COLOR_BTNFACE }, // bright grey
{ RGB_TO_RGBQUAD(0xFF, 0xFF, 0xFF), COLOR_BTNHIGHLIGHT } // white
};
const int nMaps = 4;
// look for matching RGBQUAD color in original
for (int i = 0; i < nMaps; i++)
{
if (color == sysColorMap[i].rgbqFrom)
{
return bUseRGBQUAD ?
CLR_TO_RGBQUAD (globalData.GetColor (sysColorMap[i].iSysColorTo)) :
globalData.GetColor (sysColorMap[i].iSysColorTo);
}
}
return color;
}
//********************************************************************************
COLORREF CBCGPToolBarImages::MapToSysColorAlpha (COLORREF color)
{
BYTE r = GetRValue (color);
BYTE g = GetGValue (color);
BYTE b = GetBValue (color);
const int nDelta = 10;
if (abs (r - b) > nDelta || abs (r - g) > nDelta || abs (b - g) > nDelta)
{
return color;
}
return CBCGPDrawManager::PixelAlpha (globalData.clrBarFace,
1. + ((double) r - 192) / 255,
1. + ((double) g - 192) / 255,
1. + ((double) b - 192) / 255);
}
//********************************************************************************
COLORREF CBCGPToolBarImages::MapFromSysColor (COLORREF color, BOOL bUseRGBQUAD)
{
struct COLORMAP
{
// use DWORD instead of RGBQUAD so we can compare two RGBQUADs easily
DWORD rgbTo;
int iSysColorFrom;
};
static const COLORMAP sysColorMap[] =
{
// mapping from color in DIB to system color
{ RGB(0x00, 0x00, 0x00), COLOR_BTNTEXT }, // black
{ RGB(0x80, 0x80, 0x80), COLOR_BTNSHADOW }, // dark grey
{ RGB(0xC0, 0xC0, 0xC0), COLOR_BTNFACE }, // bright grey
{ RGB(0xFF, 0xFF, 0xFF), COLOR_BTNHIGHLIGHT } // white
};
const int nMaps = 4;
// look for matching RGBQUAD color in original
for (int i = 0; i < nMaps; i++)
{
COLORREF clrSystem = globalData.GetColor (sysColorMap[i].iSysColorFrom);
if (bUseRGBQUAD)
{
if (color == CLR_TO_RGBQUAD (clrSystem))
{
return CLR_TO_RGBQUAD (sysColorMap[i].rgbTo);
}
}
else
{
if (color == clrSystem)
{
return sysColorMap[i].rgbTo;
}
}
}
return color;
}
//************************************************************************************
BOOL CBCGPToolBarImages::Save (LPCTSTR lpszBmpFileName)
{
if (!m_bUserImagesList || // Only user-defined bitmaps can be saved!
m_hbmImageWell == NULL) // Not loaded yet!
{
return FALSE;
}
if (m_bReadOnly)
{
return FALSE;
}
CString strFile;
if (lpszBmpFileName == NULL)
{
strFile = m_strUDLPath;
}
else
{
strFile = lpszBmpFileName;
}
if (!m_bModified && strFile == m_strUDLPath)
{
return TRUE;
}
HANDLE hDib = DDBToDIB (m_hbmImageWell, 0);
if (hDib == NULL)
{
TRACE(_T("CBCGPToolBarImages::Save Can't convert DDB to DIB\n"));
return FALSE;
}
BOOL bSuccess = WriteDIB (strFile, hDib);
::GlobalFree (hDib);
if (!bSuccess)
{
return FALSE;
}
m_bModified = FALSE;
return TRUE;
}
//************************************************************************************
static BOOL WriteDIB( LPCTSTR szFile, HANDLE hDIB)
{
BITMAPFILEHEADER hdr;
LPBITMAPINFOHEADER lpbi;
if (!hDIB)
return FALSE;
CFile file;
if( !file.Open (szFile, CFile::modeWrite | CFile::modeCreate))
{
return FALSE;
}
lpbi = (LPBITMAPINFOHEADER) hDIB;
int nColors = 1 << lpbi->biBitCount;
if (nColors > 256 || lpbi->biBitCount == 32)
nColors = 0;
// Fill in the fields of the file header
hdr.bfType = ((WORD) ('M' << 8) | 'B'); // is always "BM"
hdr.bfSize = GlobalSize (hDIB) + sizeof( hdr );
hdr.bfReserved1 = 0;
hdr.bfReserved2 = 0;
hdr.bfOffBits = (DWORD) (sizeof( hdr ) + lpbi->biSize +
nColors * sizeof(RGBQUAD));
// Write the file header
file.Write( &hdr, sizeof(hdr) );
// Write the DIB header and the bits
file.Write( lpbi, GlobalSize(hDIB) );
return TRUE;
}
//********************************************************************************
static HANDLE DDBToDIB (HBITMAP bitmap, DWORD dwCompression)
{
BITMAP bm;
BITMAPINFOHEADER bi;
LPBITMAPINFOHEADER lpbi;
DWORD dwLen;
HANDLE hDIB;
HANDLE handle;
HDC hDC;
HPALETTE hPal;
// The function has no arg for bitfields
if( dwCompression == BI_BITFIELDS)
return NULL;
hPal = (HPALETTE) GetStockObject(DEFAULT_PALETTE);
// Get bitmap information
::GetObject(bitmap, sizeof(bm),(LPSTR)&bm);
// Initialize the bitmapinfoheader
bi.biSize = sizeof(BITMAPINFOHEADER);
bi.biWidth = bm.bmWidth;
bi.biHeight = bm.bmHeight;
bi.biPlanes = 1;
bi.biBitCount = (WORD) (bm.bmPlanes * bm.bmBitsPixel);
bi.biCompression = dwCompression;
bi.biSizeImage = 0;
bi.biXPelsPerMeter = 0;
bi.biYPelsPerMeter = 0;
bi.biClrUsed = 0;
bi.biClrImportant = 0;
// Compute the size of the infoheader and the color table
int nColors = (1 << bi.biBitCount);
if (nColors > 256 || bi.biBitCount == 32)
nColors = 0;
dwLen = bi.biSize + nColors * sizeof(RGBQUAD);
// We need a device context to get the DIB from
hDC = ::CreateCompatibleDC (NULL);
if (hDC == NULL)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -