Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

173 lines
4.7 KiB

/**************************************************************************\
*
* Copyright (c) 1998-1999, Microsoft Corp. All Rights Reserved.
*
* Module Name:
*
* Gdiplus pixel formats
*
* Abstract:
*
* Definitions for color types, palettes, pixel format IDs.
*
* Notes:
*
* imaging.h
*
* Revision History:
*
* 10/13/1999 agodfrey
* Separated it from imaging.h
*
\**************************************************************************/
#ifndef _GDIPLUSPIXELFORMATS_H
#define _GDIPLUSPIXELFORMATS_H
//
// 32-bit and 64-bit ARGB pixel value
//
typedef DWORD ARGB;
typedef DWORDLONG ARGB64;
#define ALPHA_SHIFT 24
#define RED_SHIFT 16
#define GREEN_SHIFT 8
#define BLUE_SHIFT 0
#define ALPHA_MASK ((ARGB) 0xff << ALPHA_SHIFT)
#define MAKEARGB(a, r, g, b) \
(((ARGB) ((a) & 0xff) << ALPHA_SHIFT) | \
((ARGB) ((r) & 0xff) << RED_SHIFT) | \
((ARGB) ((g) & 0xff) << GREEN_SHIFT) | \
((ARGB) ((b) & 0xff) << BLUE_SHIFT))
//
// In-memory pixel data formats:
// bits 0-7 = format index
// bits 8-15 = pixel size (in bits)
// bits 16-23 = flags
// bits 24-31 = reserved
//
typedef enum PixelFormatID
{
PIXFMTFLAG_INDEXED = 0x00010000, // Indexes into a palette
PIXFMTFLAG_GDI = 0x00020000, // Is a GDI-supported format
PIXFMTFLAG_ALPHA = 0x00040000, // Has an alpha component
PIXFMTFLAG_PALPHA = 0x00080000, // Uses pre-multiplied alpha
PIXFMTFLAG_EXTENDED = 0x00100000, // Uses extended color (16 bits per channel)
PIXFMTFLAG_CANONICAL = 0x00200000, // ?
PIXFMT_UNDEFINED = 0,
PIXFMT_DONTCARE = 0,
PIXFMT_1BPP_INDEXED = 1 | ( 1 << 8) | PIXFMTFLAG_INDEXED
| PIXFMTFLAG_GDI,
PIXFMT_4BPP_INDEXED = 2 | ( 4 << 8) | PIXFMTFLAG_INDEXED
| PIXFMTFLAG_GDI,
PIXFMT_8BPP_INDEXED = 3 | ( 8 << 8) | PIXFMTFLAG_INDEXED
| PIXFMTFLAG_GDI,
PIXFMT_16BPP_GRAYSCALE = 4 | (16 << 8) | PIXFMTFLAG_EXTENDED,
PIXFMT_16BPP_RGB555 = 5 | (16 << 8) | PIXFMTFLAG_GDI,
PIXFMT_16BPP_RGB565 = 6 | (16 << 8) | PIXFMTFLAG_GDI,
PIXFMT_16BPP_ARGB1555 = 7 | (16 << 8) | PIXFMTFLAG_ALPHA
| PIXFMTFLAG_GDI,
PIXFMT_24BPP_RGB = 8 | (24 << 8) | PIXFMTFLAG_GDI,
PIXFMT_32BPP_RGB = 9 | (32 << 8) | PIXFMTFLAG_GDI,
PIXFMT_32BPP_ARGB = 10 | (32 << 8) | PIXFMTFLAG_ALPHA
| PIXFMTFLAG_GDI
| PIXFMTFLAG_CANONICAL,
PIXFMT_32BPP_PARGB = 11 | (32 << 8) | PIXFMTFLAG_ALPHA
| PIXFMTFLAG_PALPHA
| PIXFMTFLAG_GDI,
PIXFMT_48BPP_RGB = 12 | (48 << 8) | PIXFMTFLAG_EXTENDED,
PIXFMT_64BPP_ARGB = 13 | (64 << 8) | PIXFMTFLAG_ALPHA
| PIXFMTFLAG_CANONICAL
| PIXFMTFLAG_EXTENDED,
PIXFMT_64BPP_PARGB = 14 | (64 << 8) | PIXFMTFLAG_ALPHA
| PIXFMTFLAG_PALPHA
| PIXFMTFLAG_EXTENDED,
PIXFMT_24BPP_BGR = 15 | (24 << 8) | PIXFMTFLAG_GDI,
PIXFMT_MAX = 16
} PixelFormatID;
// Return the pixel size for the specified format (in bits)
inline UINT
GetPixelFormatSize(
PixelFormatID pixfmt
)
{
return (pixfmt >> 8) & 0xff;
}
// Determine if the specified pixel format is an indexed color format
inline BOOL
IsIndexedPixelFormat(
PixelFormatID pixfmt
)
{
return (pixfmt & PIXFMTFLAG_INDEXED) != 0;
}
// Determine if the pixel format can have alpha channel
inline BOOL
IsAlphaPixelFormat(
PixelFormatID pixfmt
)
{
return (pixfmt & PIXFMTFLAG_ALPHA) != 0;
}
// Determine if the pixel format is an extended format,
// i.e. supports 16-bit per channel
inline BOOL
IsExtendedPixelFormat(
PixelFormatID pixfmt
)
{
return (pixfmt & PIXFMTFLAG_EXTENDED) != 0;
}
// Determine if the pixel format is canonical format:
// PIXFMT_32BPP_ARGB
// PIXFMT_32BPP_PARGB
// PIXFMT_64BPP_ARGB
// PIXFMT_64BPP_PARGB
inline BOOL
IsCanonicalPixelFormat(
PixelFormatID pixfmt
)
{
return (pixfmt & PIXFMTFLAG_CANONICAL) != 0;
}
//
// Color palette
// palette entries are limited to 32bpp ARGB pixel format
//
enum
{
PALFLAG_HASALPHA = 0x0001,
PALFLAG_GRAYSCALE = 0x0002,
PALFLAG_HALFTONE = 0x0004
};
typedef struct tagColorPalette
{
UINT Flags; // palette flags
UINT Count; // number of color entries
ARGB Entries[1]; // palette color entries
} ColorPalette;
#endif