29#define EXPECT_REF(obj,ref) _expect_ref((IUnknown*)obj, ref, __LINE__)
34 rc = IUnknown_Release(
obj);
35 ok_(__FILE__,
line)(rc ==
ref,
"expected refcount %ld, got %ld\n",
ref, rc);
44#define IFD_UNDEFINED 7
47#define IFD_SRATIONAL 10
99 { 0x11, 0x22, 0x33, 0 }
137 { 0x11,0x22,0x33,0x44,0x55,0x66,0x77,0x88 }
191 { { 100, 1 }, { 50, 1 }, 0, 100.0, 50.0, 0, 0 },
192 { { 50, 1 }, { 100, 1 }, 0, 50.0, 100.0, 0, 0 },
194 { { 100, 1 }, { 50, 1 }, 1, 100.0, 50.0, 0, 0 },
195 { { 50, 1 }, { 100, 1 }, 1, 50.0, 100.0, 0, 0 },
197 { { 49, 1 }, { 49, 1 }, 2, 49.0, 49.0, 0, 0 },
198 { { 33, 1 }, { 55, 1 }, 2, 33.0, 55.0, 0, 0 },
199 { { 50, 2 }, { 66, 3 }, 2, 25.0, 22.0, 0, 0 },
201 { { 100, 1 }, { 200, 1 }, 3, 254.0, 508.0, 0, 0 },
204 { { 0, 1 }, { 29, 1 }, 2, 96.0, 96.0, 0, 29.0 },
205 { { 58, 1 }, { 29, 0 }, 2, 96.0, 96.0, 58.0, 0 },
208 { { 0, 1 }, { 100, 1 }, 3, 96.0, 96.0, 243.84, 254.0 },
209 { { 50, 1 }, { 72, 0 }, 3, 96.0, 96.0, 127.0, 243.84 }
247 { 0x11, 0x22, 0x33, 0 }
320 { 0x12,0x30, 0x47,0xe0 }
334 ok(hdata != 0,
"GlobalAlloc failed\n");
335 if (!hdata)
return NULL;
342 ok(
hr ==
S_OK,
"CreateStreamOnHGlobal failed, hr=%lx\n",
hr);
364 ok(
hr ==
S_OK,
"CreateStreamOnHGlobal error %#lx\n",
hr);
370 ok(
hr ==
S_OK,
"GetContainerFormat error %#lx\n",
hr);
374 refcount = IStream_Release(
stream);
375 ok(refcount > 0,
"expected stream refcount > 0\n");
391 hr = IWICComponentInfo_QueryInterface(
info, &IID_IWICPixelFormatInfo2, (
void **)&formatinfo);
394 hr = IWICPixelFormatInfo2_SupportsTransparency(formatinfo, transparency);
395 ok(
hr ==
S_OK,
"SupportsTransparency error %#lx\n",
hr);
396 IWICPixelFormatInfo2_Release(formatinfo);
398 hr = IWICComponentInfo_QueryInterface(
info, &IID_IWICPixelFormatInfo, (
void **)&formatinfo);
401 hr = IWICPixelFormatInfo2_GetBitsPerPixel(formatinfo,
bpp);
402 ok(
hr ==
S_OK,
"GetBitsPerPixel error %#lx\n",
hr);
403 hr = IWICPixelFormatInfo2_GetChannelCount(formatinfo,
channels);
404 ok(
hr ==
S_OK,
"GetChannelCount error %#lx\n",
hr);
405 IWICPixelFormatInfo2_Release(formatinfo);
407 IWICComponentInfo_Release(
info);
424 printf(
"tag %u: id %04x, type %04x, count %lu, value %ld",
428 short *bps = (
short *)((
char *)
tiff +
tag[
i].value);
429 printf(
" (%d,%d,%d,%d)\n", bps[0], bps[1], bps[2], bps[3]);
445 ok(
hr ==
S_OK,
"Failed to load TIFF image data %#lx\n",
hr);
448 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
451 hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &
format);
452 ok(
hr ==
S_OK,
"GetPixelFormat error %#lx\n",
hr);
457 ok(
hr ==
S_OK,
"CreatePalette error %#lx\n",
hr);
458 hr = IWICBitmapFrameDecode_CopyPalette(frame,
palette);
460 "expected WINCODEC_ERR_PALETTEUNAVAILABLE, got %#lx\n",
hr);
463 IWICBitmapFrameDecode_Release(frame);
464 IWICBitmapDecoder_Release(
decoder);
486 ok(
hr ==
S_OK,
"CreateDecoder error %#lx\n",
hr);
489 frame_count = 0xdeadbeef;
490 hr = IWICBitmapDecoder_GetFrameCount(
decoder, &frame_count);
492 ok(frame_count == 0,
"expected 0, got %u\n", frame_count);
494 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
499 ok(
hr ==
S_OK,
"IStream_Seek error %#lx\n",
hr);
501 capability = 0xdeadbeef;
503 ok(
hr ==
S_OK,
"QueryCapability error %#lx\n",
hr);
504 ok(capability == exp_caps || capability == exp_caps_xp,
505 "expected %#lx, got %#lx\n", exp_caps, capability);
507 frame_count = 0xdeadbeef;
508 hr = IWICBitmapDecoder_GetFrameCount(
decoder, &frame_count);
509 ok(
hr ==
S_OK,
"GetFrameCount error %#lx\n",
hr);
510 ok(frame_count == 1,
"expected 1, got %u\n", frame_count);
512 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
514 IWICBitmapFrameDecode_Release(frame);
518 ok(
hr ==
S_OK,
"IStream_Seek error %#lx\n",
hr);
526 IWICBitmapDecoder_Release(
decoder);
534 IWICBitmapDecoder_Release(
decoder);
538 ok(
hr ==
S_OK,
"IStream_Seek error %#lx\n",
hr);
541 ok(
hr ==
S_OK,
"CreateDecoderFromStream error %#lx\n",
hr);
543 frame_count = 0xdeadbeef;
544 hr = IWICBitmapDecoder_GetFrameCount(
decoder, &frame_count);
545 ok(
hr ==
S_OK,
"GetFrameCount error %#lx\n",
hr);
546 ok(frame_count == 1,
"expected 1, got %u\n", frame_count);
548 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
550 IWICBitmapFrameDecode_Release(frame);
558 IWICBitmapDecoder_Release(
decoder);
573 static const BYTE expected_data[16] = { 0x11,0x11,0x11,0x22,0x33,0x33,0x33,0x44,
574 0x55,0x55,0x55,0x66,0x77,0x77,0x77,0x88 };
577 ok(
hr ==
S_OK,
"Failed to load TIFF image data %#lx\n",
hr);
580 hr = IWICBitmapDecoder_GetFrameCount(
decoder, &frame_count);
581 ok(
hr ==
S_OK,
"GetFrameCount error %#lx\n",
hr);
582 ok(frame_count == 1,
"expected 1, got %u\n", frame_count);
585 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
588 IWICBitmapDecoder_Release(
decoder);
595 hr = IWICBitmapFrameDecode_GetResolution(frame, &dpi_x, &dpi_y);
596 ok(
hr ==
S_OK,
"GetResolution error %#lx\n",
hr);
597 ok(dpi_x == 96.0,
"expected 96.0, got %f\n", dpi_x);
598 ok(dpi_y == 96.0,
"expected 96.0, got %f\n", dpi_y);
600 hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &
format);
601 ok(
hr ==
S_OK,
"GetPixelFormat error %#lx\n",
hr);
606 ok(
hr ==
S_OK,
"CreatePalette error %#lx\n",
hr);
607 hr = IWICBitmapFrameDecode_CopyPalette(frame,
palette);
609 "expected WINCODEC_ERR_PALETTEUNAVAILABLE, got %#lx\n",
hr);
616 hr = IWICBitmapFrameDecode_CopyPixels(frame, &rc, 8,
sizeof(
data),
data);
617 ok(
hr ==
S_OK,
"CopyPixels error %#lx\n",
hr);
619 for (
i = 0;
i <
sizeof(
data);
i++)
620 ok(
data[
i] == expected_data[
i],
"%u: expected %02x, got %02x\n",
i, expected_data[
i],
data[
i]);
622 IWICBitmapFrameDecode_Release(frame);
627 unsigned short *
r, *
g, *
b;
650 g[
i] = (
i | 0x40) * 257;
651 b[
i] = (
i | 0x80) * 257;
670 ok(
hr ==
S_OK,
"Failed to load TIFF image data %#lx\n",
hr);
673 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
676 hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &
format);
677 ok(
hr ==
S_OK,
"GetPixelFormat error %#lx\n",
hr);
682 ok(
hr ==
S_OK,
"CreatePalette error %#lx\n",
hr);
683 hr = IWICBitmapFrameDecode_CopyPalette(frame,
palette);
684 ok(
hr ==
S_OK,
"CopyPalette error %#lx\n",
hr);
687 ok(
hr ==
S_OK,
"GetColorCount error %#lx\n",
hr);
699 IWICBitmapFrameDecode_Release(frame);
700 IWICBitmapDecoder_Release(
decoder);
719 ok(
hr ==
S_OK,
"Failed to load TIFF image data %#lx\n",
hr);
722 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
723 ok(
hr ==
S_OK,
"%d: GetFrame error %#lx\n",
i,
hr);
725 hr = IWICBitmapFrameDecode_GetResolution(frame, &dpi_x, &dpi_y);
726 ok(
hr ==
S_OK,
"%d: GetResolution error %#lx\n",
i,
hr);
731 "%d: x: expected %f or %f, got %f\n",
i,
test_data->expected_dpi_x,
test_data->broken_dpi_x, dpi_x);
736 "%d: x: expected %f, got %f\n",
i,
test_data->expected_dpi_x, dpi_x);
742 "%d: y: expected %f or %f, got %f\n",
i,
test_data->expected_dpi_y,
test_data->broken_dpi_y, dpi_y);
747 "%d: y: expected %f, got %f\n",
i,
test_data->expected_dpi_y, dpi_y);
750 IWICBitmapFrameDecode_Release(frame);
751 IWICBitmapDecoder_Release(
decoder);
765 static const BYTE expected_data[] = { 0x33,0x22,0x11 };
768 ok(
hr ==
S_OK,
"Failed to load TIFF image data %#lx\n",
hr);
773 ok(
hr ==
S_OK,
"GetFrameCount error %#lx\n",
hr);
776 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
784 hr = IWICBitmapFrameDecode_GetResolution(frame, &dpi_x, &dpi_y);
785 ok(
hr ==
S_OK,
"GetResolution error %#lx\n",
hr);
786 ok(dpi_x == 300.0,
"got %f\n", dpi_x);
787 ok(dpi_y == 300.0,
"got %f\n", dpi_y);
789 hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &
format);
790 ok(
hr ==
S_OK,
"GetPixelFormat error %#lx\n",
hr);
801 hr = IWICBitmapFrameDecode_CopyPixels(frame, &rc,
stride,
sizeof(
data),
data);
808 for (
i = 0;
i <
sizeof(
data);
i++)
809 ok(
data[
i] == expected_data[
i],
"%u: expected %02x, got %02x\n",
i, expected_data[
i],
data[
i]);
813 IWICBitmapFrameDecode_Release(frame);
814 IWICBitmapDecoder_Release(
decoder);
855 { 1,0,2,3,4,5,6,7,8,9,0,1,2,3,4,5 }
874 static const BYTE bits_1bpsBGR[] = { 0,255,0,255,0,255,255,255,0,0,0,255,255,0,0,0,255,255,255,255,255,0,0,0,0,255,0,255,0,255 };
877 24, 10, 2, &GUID_WICPixelFormat24bppBGR, bits_1bpsBGR
879 static const BYTE bits_4bpsBGR[] = { 204,85,85,136,187,51,0,85,85,85,0,68,0,102,0,136,0,119,0,153,0 };
882 24, 5, 2, &GUID_WICPixelFormat24bppBGR, bits_4bpsBGR
884 static const BYTE bits_8bpsBGR[] = { 2,0,1,5,4,3,8,7,6 };
887 24, 3, 1, &GUID_WICPixelFormat24bppBGR, bits_8bpsBGR
889 static const BYTE bits_48bppRGB[] = { 1,0,2,3,4,5,6,7,8,9,0,1 };
894 static const BYTE bits_1bpsBGRA[] = { 0,255,0,255,0,255,0,255,0,255,255,0,255,0,0,255,255,0,255,255,0,0,255,0,0,255,0,255,0,255,0,255,0,0,0,0,0,255,0,0 };
897 32, 5, 2, &GUID_WICPixelFormat32bppBGRA, bits_1bpsBGRA
901 32, 5, 2, &GUID_WICPixelFormat32bppPBGRA, bits_1bpsBGRA
903 static const BYTE bits_4bpsBGRA[] = { 204,85,85,51,85,136,187,85,0,68,0,85,0,102,0,119,0,136,0,153,0,0,0,17,0,34,0,51 };
906 32, 5, 2, &GUID_WICPixelFormat32bppBGRA, bits_4bpsBGRA
910 32, 5, 2, &GUID_WICPixelFormat32bppPBGRA, bits_4bpsBGRA
912 static const BYTE bits_8bpsBGRA[] = { 2,0,1,3,6,5,4,7,0,9,8,1,4,3,2,5 };
915 32, 4, 1, &GUID_WICPixelFormat32bppBGRA, bits_8bpsBGRA
919 32, 4, 1, &GUID_WICPixelFormat32bppPBGRA, bits_8bpsBGRA
921 static const BYTE bits_64bppRGBA[] = { 1,0,2,3,4,5,6,7,8,9,0,1,2,3,4,5 };
930 static const BYTE bits_BlackWhite[] = { 85,195,184,85 };
933 1, 30, 1, &GUID_WICPixelFormatBlackWhite, bits_BlackWhite
935 static const BYTE bits_BlackWhite_xp[] = { 85,195,184,84 };
936 static const struct bitmap_data data_BlackWhite_xp =
938 1, 30, 1, &GUID_WICPixelFormatBlackWhite, bits_BlackWhite_xp
955 static const BYTE bits_16bppGray[] = { 1,0,2,3,4,5 };
958 16, 3, 1, &GUID_WICPixelFormat16bppGray, bits_16bppGray
960 static const BYTE bits_32bppGrayFloat[] = { 1,0,2,3,4,5,6,7,8,9,0,1 };
961 static const struct bitmap_data data_32bppGrayFloat =
965 static const BYTE bits_96bppRGBFloat[] = { 1,0,2,3,4,5,6,7,8,9,0,1 };
966 static const struct bitmap_data data_96bppRGBFloat =
968 96, 1, 1, &GUID_WICPixelFormat96bppRGBFloat, bits_96bppRGBFloat
970 static const BYTE bits_128bppRGBAFloat[] = { 1,0,2,3,4,5,6,7,8,9,0,1,2,3,4,5 };
971 static const struct bitmap_data data_128bppRGBAFloat =
973 128, 1, 1, &GUID_WICPixelFormat128bppRGBAFloat, bits_128bppRGBAFloat
975 static const struct bitmap_data data_128bppPRGBAFloat =
977 128, 1, 1, &GUID_WICPixelFormat128bppPRGBAFloat, bits_128bppRGBAFloat
979 static const BYTE bits_1bppIndexed[] = { 85,195,184,85 };
982 1, 32, 1, &GUID_WICPixelFormat1bppIndexed, bits_1bppIndexed
984 static const BYTE bits_4bppIndexed[] = { 85,195,184,85 };
987 4, 7, 1, &GUID_WICPixelFormat4bppIndexed, bits_4bppIndexed
989 static const BYTE bits_4bppIndexed_xp[] = { 85,195,184,80 };
990 static const struct bitmap_data data_4bppIndexed_xp =
992 4, 7, 1, &GUID_WICPixelFormat4bppIndexed, bits_4bppIndexed_xp
994 static const BYTE bits_8bppIndexed[] = { 1,0,2,3,4,5,6,7,8,9 };
997 8, 3, 1, &GUID_WICPixelFormat8bppIndexed, bits_8bppIndexed
999 static const BYTE bits_32bppCMYK[] = { 1,0,2,3,4,5,6,7,8,9,0,1 };
1002 32, 3, 1, &GUID_WICPixelFormat32bppCMYK, bits_32bppCMYK
1004 static const BYTE bits_64bppCMYK[] = { 1,0,2,3,4,5,6,7,8,9,0,1,2,3,4,5 };
1007 64, 2, 1, &GUID_WICPixelFormat64bppCMYK, bits_64bppCMYK
1020 { 2, 3, 1, 0, &data_1bpsBGR },
1021 { 2, 3, 4, 0, &data_4bpsBGR },
1022 { 2, 3, 8, 0, &data_8bpsBGR },
1023 { 2, 3, 16, 0, &data_48bppRGB },
1024 { 2, 3, 24, 0,
NULL },
1025 { 2, 3, 32, 0, &data_96bppRGBFloat },
1026 { 2, 4, 1, 0, &data_1bpsBGRA },
1027 { 2, 4, 1, 1, &data_1bpsPBGRA },
1028 { 2, 4, 4, 0, &data_4bpsBGRA },
1029 { 2, 4, 4, 1, &data_4bpsPBGRA },
1030 { 2, 4, 8, 0, &data_8bpsBGRA },
1031 { 2, 4, 8, 1, &data_8bpsPBGRA },
1032 { 2, 4, 16, 0, &data_64bppRGBA },
1033 { 2, 4, 16, 1, &data_64bppPRGBA },
1034 { 2, 4, 24, 0,
NULL },
1035 { 2, 4, 32, 0, &data_128bppRGBAFloat },
1036 { 2, 4, 32, 1, &data_128bppPRGBAFloat },
1038 { 1, 1, 1, 0, &data_BlackWhite, &data_BlackWhite_xp },
1039 { 1, 1, 4, 0, &data_4bppGray, &data_4bppGray_xp },
1040 { 1, 1, 8, 0, &data_8bppGray },
1041 { 1, 1, 16, 0, &data_16bppGray },
1042 { 1, 1, 24, 0,
NULL },
1043 { 1, 1, 32, 0, &data_32bppGrayFloat },
1045 { 3, 1, 1, 0, &data_1bppIndexed },
1046 { 3, 1, 4, 0, &data_4bppIndexed, &data_4bppIndexed_xp },
1047 { 3, 1, 8, 0, &data_8bppIndexed },
1049 { 3, 1, 16, 0, &data_8bppIndexed },
1050 { 3, 1, 24, 0, &data_8bppIndexed },
1051 { 3, 1, 32, 0, &data_8bppIndexed },
1054 { 5, 4, 1, 0,
NULL },
1055 { 5, 4, 4, 0,
NULL },
1056 { 5, 4, 8, 0, &data_32bppCMYK },
1057 { 5, 4, 16, 0, &data_64bppCMYK },
1058 { 5, 4, 24, 0,
NULL },
1059 { 5, 4, 32, 0,
NULL },
1082 if (
tag[
i].
id == 0x100)
1083 tag_width = &
tag[
i];
1084 else if (
tag[
i].
id == 0x101)
1085 tag_height = &
tag[
i];
1086 else if (
tag[
i].
id == 0x102)
1088 else if (
tag[
i].
id == 0x106)
1089 tag_photo = &
tag[
i];
1090 else if (
tag[
i].
id == 0x115)
1091 tag_samples = &
tag[
i];
1092 else if (
tag[
i].
id == 0x140)
1093 tag_colormap = &
tag[
i];
1094 else if (
tag[
i].
id == 0x152)
1095 tag_extra_samples = &
tag[
i];
1098 ok(tag_bps && tag_photo && tag_samples && tag_colormap && tag_extra_samples,
"tag 0x102,0x106,0x115,0x140 or 0x152 is missing\n");
1099 if (!tag_bps || !tag_photo || !tag_samples || !tag_colormap || !tag_extra_samples)
return;
1101 ok(tag_bps->type ==
IFD_SHORT,
"tag 0x102 should have type IFD_SHORT\n");
1102 bps = (
short *)(
buf + tag_bps->value);
1103 ok(bps[0] == 8 && bps[1] == 8 && bps[2] == 8 && bps[3] == 0,
1104 "expected bps 8,8,8,0 got %d,%d,%d,%d\n", bps[0], bps[1], bps[2], bps[3]);
1110 bpp = td[
i].samples * td[
i].bps;
1112 trace(
"photometric %d, samples %d, extra samples %d, bps %d, bpp %u, width %u => width_bytes %u\n",
1113 td[
i].photometric, td[
i].
samples, td[
i].extra_samples, td[
i].bps,
bpp,
1115 tag_width->
value = td[
i].data->width;
1116 tag_height->value = td[
i].data->height;
1120 tag_width->
value = 1;
1121 tag_height->value = 1;
1124 tag_colormap->count = (1 << td[
i].bps) * 3;
1141 tag_photo->
value = td[
i].photometric;
1142 tag_bps->count = td[
i].samples;
1143 tag_samples->value = td[
i].samples;
1146 tag_bps->value = td[
i].bps;
1148 tag_bps->value =
MAKELONG(td[
i].bps, td[
i].bps);
1151 tag_bps->value = (
BYTE *)bps -
buf;
1152 bps[0] = bps[1] = bps[2] = td[
i].bps;
1156 tag_bps->value = (
BYTE *)bps -
buf;
1157 bps[0] = bps[1] = bps[2] = bps[3] = td[
i].bps;
1161 ok(0,
"%u: unsupported samples count %d\n",
i, td[
i].
samples);
1165 if (td[
i].extra_samples)
1167 tag_extra_samples->id = 0x152;
1168 tag_extra_samples->value = td[
i].extra_samples;
1172 tag_extra_samples->id = 0x14e;
1173 tag_extra_samples->value = td[
i].samples;
1180 "%u: (%d,%d,%d,%d) wrong error %#lx\n",
i, td[
i].photometric, td[
i].
samples, td[
i].extra_samples, td[
i].bps,
hr);
1183 IWICBitmapDecoder_Release(
decoder);
1190 "%u: failed to load TIFF image data (%d,%d,%d,%d) %#lx\n",
1191 i, td[
i].photometric, td[
i].
samples, td[
i].extra_samples, td[
i].bps,
hr);
1192 if (
hr !=
S_OK)
continue;
1194 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
1195 ok(
hr ==
S_OK,
"%u: GetFrame error %#lx\n",
i,
hr);
1197 hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &
format);
1198 ok(
hr ==
S_OK,
"%u: GetPixelFormat error %#lx\n",
i,
hr);
1201 win_skip(
"Windows Server 2008 misinterprets 96bppRGBFloat as 128bppRGBFloat, skipping the tests\n");
1202 IWICBitmapFrameDecode_Release(frame);
1203 IWICBitmapDecoder_Release(
decoder);
1207 "%u (%d,%d,%d,%d): expected %s, got %s\n",
1208 i, td[
i].photometric, td[
i].samples, td[
i].extra_samples, td[
i].bps,
1211 transparency = (td[
i].photometric == 2 && td[
i].samples == 4);
1213 ok(
hr ==
S_OK,
"%u: get_pixelformat_bpp error %#lx\n",
i,
hr);
1214 ok(
bpp == td[
i].
data->bpp,
"%u: expected %u, got %u\n",
i, td[
i].data->bpp,
bpp);
1216 ok(transparency == (td[
i].photometric == 2 && td[
i].
samples == 4),
"%u: got %u\n",
i, transparency);
1220 ok(
hr ==
S_OK,
"%u: CopyPixels error %#lx\n",
i,
hr);
1222 if (
ret && td[
i].alt_data)
1224 ok(
ret == 0,
"%u: (%d,%d,%d,%d) wrong pixel data\n",
i, td[
i].photometric, td[
i].
samples, td[
i].extra_samples, td[
i].bps);
1228 for (
j = 0;
j <
n;
j++)
1232 IWICBitmapFrameDecode_Release(frame);
1233 IWICBitmapDecoder_Release(
decoder);
1243 double dpi_x, dpi_y;
1248 static const BYTE expected_data[24] = { 0,0,0,0xff, 0xff,0,0,0, 0xff,0,0,0xff,
1249 0,0xff,0,0, 0xff,0xff,0,0xff, 0xff,0xff,0xff,0 };
1252 ok(
hr ==
S_OK,
"Failed to load TIFF image data %#lx\n",
hr);
1255 hr = IWICBitmapDecoder_GetFrameCount(
decoder, &frame_count);
1256 ok(
hr ==
S_OK,
"GetFrameCount error %#lx\n",
hr);
1257 ok(frame_count == 1,
"expected 1, got %u\n", frame_count);
1259 hr = IWICBitmapDecoder_GetFrame(
decoder, 0, &frame);
1267 hr = IWICBitmapFrameDecode_GetResolution(frame, &dpi_x, &dpi_y);
1268 ok(
hr ==
S_OK,
"GetResolution error %#lx\n",
hr);
1269 ok(dpi_x == 96.0,
"expected 96.0, got %f\n", dpi_x);
1270 ok(dpi_y == 96.0,
"expected 96.0, got %f\n", dpi_y);
1272 hr = IWICBitmapFrameDecode_GetPixelFormat(frame, &
format);
1273 ok(
hr ==
S_OK,
"GetPixelFormat error %#lx\n",
hr);
1278 ok(
hr ==
S_OK,
"CreatePalette error %#lx\n",
hr);
1279 hr = IWICBitmapFrameDecode_CopyPalette(frame,
palette);
1281 "expected WINCODEC_ERR_PALETTEUNAVAILABLE, got %#lx\n",
hr);
1289 hr = IWICBitmapFrameDecode_CopyPixels(frame, &rc, 12,
sizeof(
data),
data);
1290 ok(
hr ==
S_OK,
"CopyPixels error %#lx\n",
hr);
1292 for (
i = 0;
i <
sizeof(
data);
i++)
1293 ok(
data[
i] == expected_data[
i],
"%u: expected %02x, got %02x\n",
i, expected_data[
i],
data[
i]);
1295 IWICBitmapFrameDecode_Release(frame);
1296 IWICBitmapDecoder_Release(
decoder);
1306 &IID_IWICImagingFactory, (
void **)&
factory);
1307 ok(
hr ==
S_OK,
"CoCreateInstance error %#lx\n",
hr);
1319 IWICImagingFactory_Release(
factory);
int memcmp(void *Buffer1, void *Buffer2, ACPI_SIZE Count)
HRESULT WINAPI DECLSPEC_HOTPATCH CoCreateInstance(REFCLSID rclsid, LPUNKNOWN pUnkOuter, DWORD dwClsContext, REFIID iid, LPVOID *ppv)
HRESULT WINAPI DECLSPEC_HOTPATCH CoInitializeEx(LPVOID lpReserved, DWORD dwCoInit)
void WINAPI DECLSPEC_HOTPATCH CoUninitialize(void)
HRESULT WINAPI CreateStreamOnHGlobal(HGLOBAL hGlobal, BOOL fDeleteOnRelease, LPSTREAM *ppstm)
unsigned short(__cdecl typeof(TIFFCurrentDirectory))(struct tiff *)
GLuint GLuint GLsizei count
GLint GLint GLsizei GLsizei GLsizei GLint GLenum GLenum const GLvoid * pixels
GLuint GLuint GLsizei GLenum type
GLint GLenum GLsizei GLsizei GLsizei GLint GLsizei const GLvoid * data
GLint GLint GLsizei GLsizei height
GLdouble GLdouble GLdouble r
GLint GLint GLsizei width
GLboolean GLboolean GLboolean b
GLenum GLuint GLenum GLsizei const GLchar * buf
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint GLint GLint j
LPVOID NTAPI GlobalLock(HGLOBAL hMem)
BOOL NTAPI GlobalUnlock(HGLOBAL hMem)
HGLOBAL NTAPI GlobalAlloc(UINT uFlags, SIZE_T dwBytes)
_Check_return_ _CRT_JIT_INTRINSIC double __cdecl fabs(_In_ double x)
static GLint image_size(GLint width, GLint height, GLenum format, GLenum type)
#define memcpy(s1, s2, n)
static const BYTE bits_4bppGray_xp[]
static const float bits_32bppGrayFloat[]
static const BYTE bits_8bppGray[]
static const BYTE bits_64bppRGBA[]
static const BYTE bits_4bppGray[]
static const WORD bits_48bppRGB[]
@ COINIT_APARTMENTTHREADED
#define IsEqualGUID(rguid1, rguid2)
static __inline const char * wine_dbgstr_guid(const GUID *id)
const WICPixelFormatGUID * format
const struct bitmap_data * alt_data
struct IFD_entry entry[13]
short palette_data[3][256]
struct IFD_entry entry[12]
struct IFD_entry entry[13]
struct IFD_entry entry[14]
struct IFD_entry entry[15]
struct IFD_entry entry[14]
short palette_data[3][256]
struct IFD_entry entry[13]
#define FIELD_OFFSET(t, f)
@ WICDecodeMetadataCacheOnDemand
@ WICBitmapDecoderCapabilityCanDecodeSomeImages
@ WICBitmapDecoderCapabilityCanEnumerateMetadata
@ WICBitmapDecoderCapabilityCanDecodeAllImages
#define WINCODEC_ERR_COMPONENTNOTFOUND
#define WINCODEC_ERR_WRONGSTATE
#define WINCODEC_ERR_BADIMAGE
#define WINCODEC_ERR_UNSUPPORTEDPIXELFORMAT
#define WINCODEC_ERR_PALETTEUNAVAILABLE
#define WINCODEC_ERR_FRAMEMISSING