Changing a CBitmap's Palette

Environment: VC6 SP5

Sometimes, it is useful or at least desirable to use one bitmap and simply change its palette to achieve various graphical effects. Unfortunately, I have been unable to find any way to directly manipulate a CBitmap's palette information. What I have done in the function below is select the bitmap into a device context and manipulate the device context's color table. By applying the palette to the device context, you then can extract the bitmap with its new palette from the device context and reattach it to the original CBitmap object.

The function below takes two parameters: a CBitmap which contains a 4-bit-per-pixel or 8-bit-per-pixel (paletted) device-independent bitmap and a CPalette object that must have the same number of colors as the CBitmap object. After all, validation is performed in the first step to get the palette information from the CPalette object and put it into an array of RGBQUADs (that's how the DC expects it). Then, the bitmap is selected into a memory DC and the new palette is applied. Finally, the bitmap is extracted from the DC with the new palette information and reattached to the CBitmap object.

The function returns FALSE on failure and TRUE on success. Any memory that was dynamically allocated is cleaned up regardless of a failure to convert the bitmap's palette.

BOOL ApplyPaletteToBitmap(CBitmap &bitmap, CPalette &palette) {
   if (bitmap.m_hObject == NULL || palette.m_hObject == NULL)
      return FALSE;

   BITMAP bmp;
   bitmap.GetBitmap(&bmp);

   int npalColors = palette.GetEntryCount();

   // Bitmaps with 16 or 256 colors use palettes
   // Make sure the palette has enough entries for the bitmap
   // as well
   if ((bmp.bmBitsPixel != 4 && bmp.bmBitsPixel != 8) ||
       (bmp.bmBitsPixel == 4 && npalColors != 16) ||
       (bmp.bmBitsPixel == 8 && npalColors != 256))
      return FALSE;

   LPPALETTEENTRY pPalEntry = NULL;
   RGBQUAD *pRGB = NULL;
   BOOL ret = TRUE;

   try {
      // Create the palette
      pPalEntry = new PALETTEENTRY[npalColors];
      pRGB = new RGBQUAD[npalColors];

      palette.GetPaletteEntries(0, npalColors, pPalEntry);

      for (int i = 0; i < npalColors; i++) {
         pRGB[i].rgbRed   = pPalEntry[i].peRed;
         pRGB[i].rgbGreen = pPalEntry[i].peGreen;
         pRGB[i].rgbBlue  = pPalEntry[i].peBlue;
         pRGB[i].rgbReserved = 0;
      }

      CClientDC dc(NULL);
      CDC memDC;
      memDC.CreateCompatibleDC(&dc);
      memDC.SelectObject(&bitmap);

      SetDIBColorTable(memDC, 0, npalColors, pRGB);

      bitmap.Attach((HBITMAP)(memDC.GetCurrentBitmap()->Detach()));
   }
   catch (...) {
      ret = FALSE;
   }

   if (pPalEntry)
      delete [] pPalEntry;
   if (pRGB)
      delete [] pRGB;

   return ret;
}


Comments

  • CreateDIBSection

    Posted by Legacy on 07/02/2003 12:00am

    Originally posted by: hoan

    instead of do that, you create DIBSection bitmap and then do what you wan. You can set color table for this bitmap by SetDIBColorTable and you also modify direct bitmap data by the pointer to Bits returned by CreateDIBSection!

    Regards.

    Reply
  • yaaa

    Posted by Legacy on 02/24/2003 12:00am

    Originally posted by: prakash

    this is quite wonderful.
    i want more information on the reading of tiff format and processing it . how can i convert grey scale image to a RGB format? what is psudo coloring

    Reply
Leave a Comment
  • Your email address will not be published. All fields are required.

Top White Papers and Webcasts

  • Genesys has been able to apply the best of all strategic approaches in moving to the cloud. It has acquired assets to bypass the long R&D process required to build from scratch, yet skillfully planned a phased integration to provide customers with functionality they need quickly. It also has followed an aggressive development plan to deliver multiple releases per quarter to continue to enrich its cloud offerings for customers. For these reasons, Frost & Sullivan is pleased to present Genesys with the 2014 …

  • As virtualization becomes the norm throughout organizations of nearly all sizes, and as more organizations look to private cloud solutions, IT decision makers are increasingly in need of ways to keep storage costs and complexity under control in the face of often-runaway virtual machine (VM) sprawl. Application-aware storage is designed to help achieve these important goals. Read this white paper to learn how application-aware storage allows you to gain VM-level visibility into application performance and …

Most Popular Programming Stories

More for Developers

RSS Feeds

Thanks for your registration, follow us on our social networks to keep up-to-date