Article ID: 94326 - Last Review: November 21, 2006 - Revision: 4.5 SeeDIB.exe Shows 16 and 32 Bits-Per-Pel Bitmap Formats
This article was previously published under Q94326 On This PageSUMMARY
SeeDIB.exe is a sample application that demonstrates how to load, display,
and save 1, 4, 8, 16, 24, and 32-bits-per-pixel (Device Independent Bitmap (DIB) formats. In addition, SeeDIB.exe demonstrates a simple method of creating an optimized palette for displaying DIBs with more than 8-bits-per-pixel on 8-bits-per-pixel devices.
Note To minimize color loss, SeeDIB uses CreateDIBSection() to do conversions between uncompressed DIBs which have more than 8-bits-per- pixel. This function is not available on Windows NT 3.1. MORE INFORMATIONThe following file is available for download from the Microsoft Download Center: SeeDIB.exe
(http://download.microsoft.com/download/platformsdk/sample56/1/w95/en-us/seedib.exe)
For additional information about how to download Microsoft Support files, click the following article number to view the article in the Microsoft Knowledge Base:
119591
(http://support.microsoft.com/kb/119591/EN-US/
)
How to Obtain Microsoft Support Files from Online Services
Microsoft scanned this file for viruses. Microsoft used the most current virus-detection software that was available on the date that the file was posted. The file is stored on security-enhanced servers that help to prevent any unauthorized changes to the file.
For DIBs, the 16 and 32-bit formats contain three DWORD masks in the bmiColors member of the BITMAPINFO structure. These masks specify which bits in the pel correspond to which color.
The three masks must have contiguous bits, and their order is assumed to be R, G, B (high bits to low bits). The order of the three masks in the color table must also be first red, then green, then blue (RGB). In this manner, the programmer can specify a mask indicating how many shades of each RGB color will be available for bitmaps created with CreateDIBitmap(). For 16-bits-per-pixel DIBs, CreateDIBitmap() defaults to the RGB555 format. For 32-bits-per-pixel DIBs, CreateDIBitmap() defaults to an RGB888 format. NOTE: The DIB engine in Windows 95 supports only RGB555 and RGB565 for 16-bit DIBs and only RGB888 for 32-bit DIBs. ExampleThe RGB555 format masks would look like the following example:0x00007C00 red (0000 0000 0000 0000 0111 1100 0000 0000) 0x000003E0 green (0000 0000 0000 0000 0000 0011 1110 0000) 0x0000001F blue (0000 0000 0000 0000 0000 0000 0001 1111) The RGB888 format masks would look like the following example: 0x00FF0000 red (0000 0000 1111 1111 0000 0000 0000 0000) 0x0000FF00 green (0000 0000 0000 0000 1111 1111 0000 0000) 0x000000FF blue (0000 0000 0000 0000 0000 0000 1111 1111) UsageWhen using 16 and 32-bit formats, there are also certain fields of the BITMAPINFOHEADER structure that must be set to the correct values:
Windows 95In Windows 95, if the BI_BITFIELDS flag is set, then a color mask must be specified and it must be one of the following:Resolution Bits Per Color Color Mask ------------------------------------------------------------- 16bpp 5,5,5 0x00007c00 0x000003e0 0x0000001f 16bpp 5,6,5 0x0000f800 0x000007e0 0x0000001f 32bpp 8,8,8 0x00ff0000 0x0000ff00 0x000000ff APPLIES TO
| Other Resources Other Support Sites
CommunityArticle Translations |





















Back to the top