00001
00002
00003
00004
00005
00006 #include <streams.h>
00007 #include <limits.h>
00008
00009 const DWORD bits555[] = {0x007C00,0x0003E0,0x00001F};
00010 const DWORD bits565[] = {0x00F800,0x0007E0,0x00001F};
00011 const DWORD bits888[] = {0xFF0000,0x00FF00,0x0000FF};
00012
00013 const struct {
00014 const GUID *pSubtype;
00015 WORD BitCount;
00016 CHAR *pName;
00017 WCHAR *wszName;
00018 } BitCountMap[] = { &MEDIASUBTYPE_RGB1, 1, "RGB Monochrome", L"RGB Monochrome",
00019 &MEDIASUBTYPE_RGB4, 4, "RGB VGA", L"RGB VGA",
00020 &MEDIASUBTYPE_RGB8, 8, "RGB 8", L"RGB 8",
00021 &MEDIASUBTYPE_RGB565, 16, "RGB 565 (16 bit)", L"RGB 565 (16 bit)",
00022 &MEDIASUBTYPE_RGB555, 16, "RGB 555 (16 bit)", L"RGB 555 (16 bit)",
00023 &MEDIASUBTYPE_RGB24, 24, "RGB 24", L"RGB 24",
00024 &MEDIASUBTYPE_RGB32, 32, "RGB 32", L"RGB 32",
00025 &MEDIASUBTYPE_ARGB32, 32, "ARGB 32", L"ARGB 32",
00026 &MEDIASUBTYPE_Overlay, 0, "Overlay", L"Overlay",
00027 &GUID_NULL, 0, "UNKNOWN", L"UNKNOWN"
00028 };
00029
00030 STDAPI_(DWORD) GetBitmapSize(const BITMAPINFOHEADER *pHeader)
00031 {
00032 return DIBSIZE(*pHeader);
00033 }
00034
00035 STDAPI_(const GUID) GetTrueColorType(const BITMAPINFOHEADER *pbmiHeader)
00036 {
00037 BITMAPINFO *pbmInfo = (BITMAPINFO *) pbmiHeader;
00038 ASSERT(pbmiHeader->biBitCount == 16);
00039
00040 if (pbmiHeader->biCompression == BI_RGB) {
00041 return MEDIASUBTYPE_RGB555;
00042 }
00043
00044 DWORD *pMask = (DWORD *) pbmInfo->bmiColors;
00045 if (pMask[0] == bits555[0]) {
00046 if (pMask[1] == bits555[1]) {
00047 if (pMask[2] == bits555[2]) {
00048 return MEDIASUBTYPE_RGB555;
00049 }
00050 }
00051 }
00052
00053 pMask = (DWORD *) pbmInfo->bmiColors;
00054 if (pMask[0] == bits565[0]) {
00055 if (pMask[1] == bits565[1]) {
00056 if (pMask[2] == bits565[2]) {
00057 return MEDIASUBTYPE_RGB565;
00058 }
00059 }
00060 }
00061 return GUID_NULL;
00062 }
00063
00064 STDAPI_(const GUID) GetBitmapSubtype(const BITMAPINFOHEADER *pbmiHeader)
00065 {
00066 ASSERT(pbmiHeader);
00067
00068 if (pbmiHeader->biCompression != BI_RGB) {
00069 if (pbmiHeader->biCompression != BI_BITFIELDS) {
00070 FOURCCMap FourCCMap(pbmiHeader->biCompression);
00071 return (const GUID) FourCCMap;
00072 }
00073 }
00074
00075 switch(pbmiHeader->biBitCount) {
00076 case 1 : return MEDIASUBTYPE_RGB1;
00077 case 4 : return MEDIASUBTYPE_RGB4;
00078 case 8 : return MEDIASUBTYPE_RGB8;
00079 case 16 : return GetTrueColorType(pbmiHeader);
00080 case 24 : return MEDIASUBTYPE_RGB24;
00081 case 32 : return MEDIASUBTYPE_RGB32;
00082 }
00083 return GUID_NULL;
00084 }
00085
00086 STDAPI_(WORD) GetBitCount(const GUID *pSubtype)
00087 {
00088 ASSERT(pSubtype);
00089 const GUID *pMediaSubtype;
00090 INT iPosition = 0;
00091
00092 while (TRUE) {
00093 pMediaSubtype = BitCountMap[iPosition].pSubtype;
00094 if (IsEqualGUID(*pMediaSubtype,GUID_NULL)) {
00095 return USHRT_MAX;
00096 }
00097 if (IsEqualGUID(*pMediaSubtype,*pSubtype)) {
00098 return BitCountMap[iPosition].BitCount;
00099 }
00100 iPosition++;
00101 }
00102 }
00103
00104 int LocateSubtype(const GUID *pSubtype)
00105 {
00106 ASSERT(pSubtype);
00107 const GUID *pMediaSubtype;
00108 INT iPosition = 0;
00109
00110 while (TRUE) {
00111 pMediaSubtype = BitCountMap[iPosition].pSubtype;
00112 if (IsEqualGUID(*pMediaSubtype,*pSubtype) ||
00113 IsEqualGUID(*pMediaSubtype,GUID_NULL)
00114 )
00115 {
00116 break;
00117 }
00118
00119 iPosition++;
00120 }
00121
00122 return iPosition;
00123 }
00124
00125 STDAPI_(WCHAR *) GetSubtypeNameW(const GUID *pSubtype)
00126 {
00127 return BitCountMap[LocateSubtype(pSubtype)].wszName;
00128 }
00129
00130 STDAPI_(CHAR *) GetSubtypeNameA(const GUID *pSubtype)
00131 {
00132 return BitCountMap[LocateSubtype(pSubtype)].pName;
00133 }
00134
00135 #ifndef GetSubtypeName
00136 #error wxutil.h should have defined GetSubtypeName
00137 #endif
00138 #undef GetSubtypeName
00139
00140 STDAPI_(CHAR *) GetSubtypeName(const GUID *pSubtype)
00141 {
00142 return GetSubtypeNameA(pSubtype);
00143 }
00144
00145 STDAPI_(LONG) GetBitmapFormatSize(const BITMAPINFOHEADER *pHeader)
00146 {
00147
00148 LONG Size = SIZE_PREHEADER + pHeader->biSize;
00149
00150 ASSERT(pHeader->biSize >= sizeof(BITMAPINFOHEADER));
00151
00152 ASSERT(pHeader->biBitCount <= iPALETTE || pHeader->biClrUsed == 0);
00153
00154 if (pHeader->biBitCount <= iPALETTE || pHeader->biClrUsed) {
00155 LONG Entries = (DWORD) 1 << pHeader->biBitCount;
00156 if (pHeader->biClrUsed) {
00157 Entries = pHeader->biClrUsed;
00158 }
00159 Size += Entries * sizeof(RGBQUAD);
00160 }
00161
00162 if (pHeader->biCompression == BI_BITFIELDS) {
00163 Size += SIZE_MASKS;
00164 }
00165
00166 return Size;
00167 }
00168
00169 STDAPI_(BOOL) ContainsPalette(const VIDEOINFOHEADER *pVideoInfo)
00170 {
00171 if (PALETTISED(pVideoInfo) == FALSE) {
00172 if (pVideoInfo->bmiHeader.biClrUsed == 0) {
00173 return FALSE;
00174 }
00175 }
00176 return TRUE;
00177 }
00178
00179 STDAPI_(const RGBQUAD *) GetBitmapPalette(const VIDEOINFOHEADER *pVideoInfo)
00180 {
00181 if (pVideoInfo->bmiHeader.biCompression == BI_BITFIELDS) {
00182 return TRUECOLOR(pVideoInfo)->bmiColors;
00183 }
00184 return COLORS(pVideoInfo);
00185 }