1 //
2 // Copyright 2013 Christian Henning
3 //
4 // Distributed under the Boost Software License, Version 1.0
5 // See accompanying file LICENSE_1_0.txt or copy at
6 // http://www.boost.org/LICENSE_1_0.txt
7 //
8 //#define BOOST_TEST_MODULE png_read_test_module
9 #define BOOST_GIL_IO_ADD_FS_PATH_SUPPORT
10 #define BOOST_GIL_IO_ENABLE_GRAY_ALPHA
11 #define BOOST_FILESYSTEM_VERSION 3
12
13 #include <boost/gil/extension/io/png.hpp>
14
15 #include <boost/test/unit_test.hpp>
16
17 #include <cstdint>
18 #include <iostream>
19
20 #include "paths.hpp"
21 #include "scanline_read_test.hpp"
22 #include "unit_test_utility.hpp"
23
24 using namespace std;
25 using namespace boost;
26 using namespace gil;
27 using namespace boost::gil::detail;
28 namespace fs = boost::filesystem;
29
30 using tag_t = png_tag;
31
32 BOOST_AUTO_TEST_SUITE( gil_io_png_tests )
33
34 using gray_alpha8_pixel_t = pixel<uint8_t, gray_alpha_layout_t>;
35 using gray_alpha8_image_t= image<gray_alpha8_pixel_t, false>;
36
37 using gray_alpha16_pixel_t = pixel<uint16_t, gray_alpha_layout_t>;
38 using gray_alpha16_image_t = image<gray_alpha16_pixel_t, false>;
39
40 template< typename Image >
test_file(string filename)41 void test_file( string filename )
42 {
43 Image src, dst;
44
45 image_read_settings< png_tag > settings;
46 settings._read_file_gamma = true;
47 settings._read_transparency_data = true;
48
49
50 using backend_t = get_reader_backend<std::string const, tag_t>::type;
51
52 backend_t backend = read_image_info( png_in + filename
53 , settings
54 );
55
56 read_image( png_in + filename
57 , src
58 , settings
59 );
60
61
62 #ifdef BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES
63 image_write_info< png_tag > write_info;
64 write_info._file_gamma = backend._info._file_gamma;
65
66 write_view( png_out + filename
67 , view( src )
68 , write_info
69 );
70
71 read_image( png_out + filename
72 , dst
73 , settings
74 );
75
76
77 BOOST_CHECK( equal_pixels( const_view( src )
78 , const_view( dst )
79 )
80 );
81 #endif // BOOST_GIL_IO_TEST_ALLOW_WRITING_IMAGES
82 }
83
84 template< typename Image >
test_png_scanline_reader(string filename)85 void test_png_scanline_reader( string filename )
86 {
87 test_scanline_reader<Image, png_tag>( string( png_in + filename ).c_str() );
88 }
89
BOOST_AUTO_TEST_CASE(read_header_test)90 BOOST_AUTO_TEST_CASE( read_header_test )
91 {
92 using backend_t = get_reader_backend<std::string const, tag_t>::type;
93
94 backend_t backend = read_image_info( png_filename
95 , tag_t()
96 );
97
98 BOOST_CHECK_EQUAL( backend._info._width , 1000u );
99 BOOST_CHECK_EQUAL( backend._info._height, 600u );
100
101 BOOST_CHECK_EQUAL( backend._info._num_channels, 4 );
102 BOOST_CHECK_EQUAL( backend._info._bit_depth , 8 );
103 BOOST_CHECK_EQUAL( backend._info._color_type , PNG_COLOR_TYPE_RGBA );
104
105 BOOST_CHECK_EQUAL( backend._info._interlace_method , PNG_INTERLACE_NONE );
106 BOOST_CHECK_EQUAL( backend._info._compression_method, PNG_COMPRESSION_TYPE_BASE );
107 BOOST_CHECK_EQUAL( backend._info._filter_method , PNG_FILTER_TYPE_BASE );
108
109
110 BOOST_CHECK_EQUAL( backend._info._file_gamma, 1 );
111 }
112
113 #ifdef BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES
114
BOOST_AUTO_TEST_CASE(read_pixel_per_meter)115 BOOST_AUTO_TEST_CASE( read_pixel_per_meter )
116 {
117 image_read_settings< png_tag > settings;
118 settings.set_read_members_true();
119
120 using backend_t = get_reader_backend<std::string const, tag_t>::type;
121
122 backend_t backend = read_image_info( png_base_in + "EddDawson/36dpi.png"
123 , settings
124 );
125
126 BOOST_CHECK_EQUAL( backend._info._pixels_per_meter, png_uint_32( 1417 ));
127 }
128
BOOST_AUTO_TEST_CASE(read_with_trns_chunk_color_type_0)129 BOOST_AUTO_TEST_CASE(read_with_trns_chunk_color_type_0)
130 {
131 // PNG 1.2: For color type 0 (grayscale), the tRNS chunk contains a single gray level value,
132 // stored in the format:
133 //
134 // Gray: 2 bytes, range 0 .. (2^bitdepth)-1
135 {
136 auto const png_path = png_in + "tbbn0g04.png";
137 image_read_settings<png_tag> settings;
138 settings.set_read_members_true();
139 auto backend = read_image_info(png_path, settings);
140 BOOST_CHECK_EQUAL(backend._info._width, 32u);
141 BOOST_CHECK_EQUAL(backend._info._height, 32u);
142 BOOST_CHECK_EQUAL(backend._info._bit_depth, 4);
143 BOOST_CHECK_EQUAL(backend._info._num_channels, 1u);
144 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_GRAY);
145
146 gray_alpha8_image_t img;
147 read_image(png_path, img, settings);
148 BOOST_CHECK_EQUAL(backend._info._width, 32u);
149 BOOST_CHECK_EQUAL(backend._info._height, 32u);
150 BOOST_TEST(const_view(img).front() == gray_alpha8c_pixel_t(255, 0));
151 BOOST_TEST(const_view(img)[78] == gray_alpha8c_pixel_t(221, 255));
152 BOOST_TEST(const_view(img)[79] == gray_alpha8c_pixel_t(204, 255));
153 BOOST_TEST(const_view(img)[975] == gray_alpha8c_pixel_t(238, 255));
154 BOOST_TEST(const_view(img)[976] == gray_alpha8c_pixel_t(221, 255));
155 BOOST_TEST(const_view(img).back() == gray_alpha8c_pixel_t(255, 0));
156 }
157 {
158 auto const png_path = png_in + "tbwn0g16.png";
159 image_read_settings<png_tag> settings;
160 settings.set_read_members_true();
161 auto backend = read_image_info(png_path, settings);
162 BOOST_CHECK_EQUAL(backend._info._width, 32u);
163 BOOST_CHECK_EQUAL(backend._info._height, 32u);
164 BOOST_CHECK_EQUAL(backend._info._bit_depth, 16);
165 BOOST_CHECK_EQUAL(backend._info._num_channels, 1u);
166 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_GRAY);
167
168 gray_alpha16_image_t img;
169 read_image(png_path, img, settings);
170 BOOST_CHECK_EQUAL(backend._info._width, 32u);
171 BOOST_CHECK_EQUAL(backend._info._height, 32u);
172 BOOST_TEST(const_view(img).front() == gray_alpha16c_pixel_t(65535, 0));
173 BOOST_TEST(const_view(img)[78] == gray_alpha16c_pixel_t(58339, 65535));
174 BOOST_TEST(const_view(img)[79] == gray_alpha16c_pixel_t(51657, 65535));
175 BOOST_TEST(const_view(img)[975] == gray_alpha16c_pixel_t(62965, 65535));
176 BOOST_TEST(const_view(img)[976] == gray_alpha16c_pixel_t(58339, 65535));
177 BOOST_TEST(const_view(img).back() == gray_alpha16c_pixel_t(65535, 0));
178 }
179 }
180
BOOST_AUTO_TEST_CASE(read_with_trns_chunk_color_type_2)181 BOOST_AUTO_TEST_CASE(read_with_trns_chunk_color_type_2)
182 {
183 // PNG 1.2: For color type 2 (truecolor), the tRNS chunk contains a single RGB color value,
184 // stored in the format:
185 //
186 // Red: 2 bytes, range 0 .. (2^bitdepth)-1
187 // Green: 2 bytes, range 0 .. (2^bitdepth)-1
188 // Blue: 2 bytes, range 0 .. (2^bitdepth)-1
189 {
190 auto const png_path = png_in + "tbbn2c16.png";
191 image_read_settings<png_tag> settings;
192 settings.set_read_members_true();
193 auto backend = read_image_info(png_path, settings);
194 BOOST_CHECK_EQUAL(backend._info._width, 32u);
195 BOOST_CHECK_EQUAL(backend._info._height, 32u);
196 BOOST_CHECK_EQUAL(backend._info._bit_depth, 16);
197 BOOST_CHECK_EQUAL(backend._info._num_channels, 3u);
198 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_RGB);
199
200 rgba16_image_t img;
201 read_image(png_path, img, settings);
202 BOOST_CHECK_EQUAL(backend._info._width, 32u);
203 BOOST_CHECK_EQUAL(backend._info._height, 32u);
204 BOOST_TEST(const_view(img).front() == rgba16c_pixel_t(65535, 65535, 65535, 0));
205 BOOST_TEST(const_view(img)[78] == rgba16c_pixel_t(58339, 58339, 58339, 65535));
206 BOOST_TEST(const_view(img)[79] == rgba16c_pixel_t(51657, 51657, 51657, 65535));
207 BOOST_TEST(const_view(img)[975] == rgba16c_pixel_t(62965, 62965, 62965, 65535));
208 BOOST_TEST(const_view(img)[976] == rgba16c_pixel_t(58339, 58339, 58339, 65535));
209 BOOST_TEST(const_view(img).back() == rgba16c_pixel_t(65535, 65535, 65535, 0));
210 }
211 {
212 auto const png_path = png_in + "tbgn2c16.png";
213 image_read_settings<png_tag> settings;
214 settings.set_read_members_true();
215 auto backend = read_image_info(png_path, settings);
216 BOOST_CHECK_EQUAL(backend._info._width, 32u);
217 BOOST_CHECK_EQUAL(backend._info._height, 32u);
218 BOOST_CHECK_EQUAL(backend._info._bit_depth, 16);
219 BOOST_CHECK_EQUAL(backend._info._num_channels, 3u);
220 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_RGB);
221
222 rgba16_image_t img;
223 read_image(png_path, img, settings);
224 BOOST_CHECK_EQUAL(backend._info._width, 32u);
225 BOOST_CHECK_EQUAL(backend._info._height, 32u);
226 BOOST_TEST(const_view(img).front() == rgba16c_pixel_t(65535, 65535, 65535, 0));
227 BOOST_TEST(const_view(img)[78] == rgba16c_pixel_t(58339, 58339, 58339, 65535));
228 BOOST_TEST(const_view(img)[79] == rgba16c_pixel_t(51657, 51657, 51657, 65535));
229 BOOST_TEST(const_view(img)[975] == rgba16c_pixel_t(62965, 62965, 62965, 65535));
230 BOOST_TEST(const_view(img)[976] == rgba16c_pixel_t(58339, 58339, 58339, 65535));
231 BOOST_TEST(const_view(img).back() == rgba16c_pixel_t(65535, 65535, 65535, 0));
232 }
233 {
234 auto const png_path = png_in + "tbrn2c08.png";
235 image_read_settings<png_tag> settings;
236 settings.set_read_members_true();
237 auto backend = read_image_info(png_path, settings);
238 BOOST_CHECK_EQUAL(backend._info._width, 32u);
239 BOOST_CHECK_EQUAL(backend._info._height, 32u);
240 BOOST_CHECK_EQUAL(backend._info._bit_depth, 8);
241 BOOST_CHECK_EQUAL(backend._info._num_channels, 3u);
242 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_RGB);
243
244 rgba8_image_t img;
245 read_image(png_path, img, settings);
246 BOOST_CHECK_EQUAL(backend._info._width, 32u);
247 BOOST_CHECK_EQUAL(backend._info._height, 32u);
248 BOOST_TEST(const_view(img).front() == rgba8c_pixel_t(255, 255, 255, 0));
249 BOOST_TEST(const_view(img)[78] == rgba8c_pixel_t(227, 227, 227, 255));
250 BOOST_TEST(const_view(img)[79] == rgba8c_pixel_t(201, 201, 201, 255));
251 BOOST_TEST(const_view(img)[975] == rgba8c_pixel_t(245, 245, 245, 255));
252 BOOST_TEST(const_view(img)[976] == rgba8c_pixel_t(227, 227, 227, 255));
253 BOOST_TEST(const_view(img).back() == rgba8c_pixel_t(255, 255, 255, 0));
254 }
255 }
256
BOOST_AUTO_TEST_CASE(read_with_trns_chunk_color_type_3)257 BOOST_AUTO_TEST_CASE(read_with_trns_chunk_color_type_3)
258 {
259 // PNG 1.2: For color type 3 (indexed color), the tRNS chunk contains a series of one-byte
260 // alpha values, corresponding to entries in the PLTE chunk:
261 //
262 // Alpha for palette index 0: 1 byte
263 // Alpha for palette index 1: 1 byte
264 // ...etc...
265 {
266 auto const png_path = png_in + "tbbn3p08.png";
267 image_read_settings<png_tag> settings;
268 settings.set_read_members_true();
269 auto backend = read_image_info(png_path, settings);
270 BOOST_CHECK_EQUAL(backend._info._width, 32u);
271 BOOST_CHECK_EQUAL(backend._info._height, 32u);
272 BOOST_CHECK_EQUAL(backend._info._bit_depth, 8);
273 BOOST_CHECK_EQUAL(backend._info._num_channels, 1u);
274 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_PALETTE);
275
276 rgba8_image_t img;
277 read_image(png_path, img, settings);
278 BOOST_CHECK_EQUAL(backend._info._width, 32u);
279 BOOST_CHECK_EQUAL(backend._info._height, 32u);
280 BOOST_TEST(const_view(img).front() == rgba8c_pixel_t(255, 255, 255, 0));
281 BOOST_TEST(const_view(img)[78] == rgba8c_pixel_t(227, 227, 227, 255));
282 BOOST_TEST(const_view(img)[79] == rgba8c_pixel_t(201, 201, 201, 255));
283 BOOST_TEST(const_view(img)[975] == rgba8c_pixel_t(246, 246, 246, 255));
284 BOOST_TEST(const_view(img)[976] == rgba8c_pixel_t(227, 227, 227, 255));
285 BOOST_TEST(const_view(img).back() == rgba8c_pixel_t(255, 255, 255, 0));
286 }
287 {
288 auto const png_path = png_in + "tbgn3p08.png";
289 image_read_settings<png_tag> settings;
290 settings.set_read_members_true();
291 auto backend = read_image_info(png_path, settings);
292 BOOST_CHECK_EQUAL(backend._info._width, 32u);
293 BOOST_CHECK_EQUAL(backend._info._height, 32u);
294 BOOST_CHECK_EQUAL(backend._info._bit_depth, 8);
295 BOOST_CHECK_EQUAL(backend._info._num_channels, 1u);
296 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_PALETTE);
297
298 rgba8_image_t img;
299 read_image(png_path, img, settings);
300 BOOST_CHECK_EQUAL(backend._info._width, 32u);
301 BOOST_CHECK_EQUAL(backend._info._height, 32u);
302 BOOST_TEST(const_view(img).front() == rgba8c_pixel_t(255, 255, 255, 0));
303 BOOST_TEST(const_view(img)[78] == rgba8c_pixel_t(227, 227, 227, 255));
304 BOOST_TEST(const_view(img)[79] == rgba8c_pixel_t(201, 201, 201, 255));
305 BOOST_TEST(const_view(img)[975] == rgba8c_pixel_t(246, 246, 246, 255));
306 BOOST_TEST(const_view(img)[976] == rgba8c_pixel_t(227, 227, 227, 255));
307 BOOST_TEST(const_view(img).back() == rgba8c_pixel_t(255, 255, 255, 0));
308 }
309 {
310 auto const png_path = png_in + "tp1n3p08.png";
311 image_read_settings<png_tag> settings;
312 settings.set_read_members_true();
313 auto backend = read_image_info(png_path, settings);
314 BOOST_CHECK_EQUAL(backend._info._width, 32u);
315 BOOST_CHECK_EQUAL(backend._info._height, 32u);
316 BOOST_CHECK_EQUAL(backend._info._bit_depth, 8);
317 BOOST_CHECK_EQUAL(backend._info._num_channels, 1u);
318 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_PALETTE);
319
320 rgba8_image_t img;
321 read_image(png_path, img, settings);
322 BOOST_CHECK_EQUAL(backend._info._width, 32u);
323 BOOST_CHECK_EQUAL(backend._info._height, 32u);
324 BOOST_TEST(const_view(img).front() == rgba8c_pixel_t(255, 255, 255, 0));
325 BOOST_TEST(const_view(img)[78] == rgba8c_pixel_t(227, 227, 227, 255));
326 BOOST_TEST(const_view(img)[79] == rgba8c_pixel_t(201, 201, 201, 255));
327 BOOST_TEST(const_view(img)[975] == rgba8c_pixel_t(246, 246, 246, 255));
328 BOOST_TEST(const_view(img)[976] == rgba8c_pixel_t(227, 227, 227, 255));
329 BOOST_TEST(const_view(img).back() == rgba8c_pixel_t(255, 255, 255, 0));
330 }
331 {
332 auto const png_path = png_in + "tm3n3p02.png";
333 image_read_settings<png_tag> settings;
334 settings.set_read_members_true();
335 auto backend = read_image_info(png_path, settings);
336 BOOST_CHECK_EQUAL(backend._info._width, 32u);
337 BOOST_CHECK_EQUAL(backend._info._height, 32u);
338 BOOST_CHECK_EQUAL(backend._info._bit_depth, 2);
339 BOOST_CHECK_EQUAL(backend._info._num_channels, 1u);
340 BOOST_CHECK_EQUAL(backend._info._color_type, PNG_COLOR_TYPE_PALETTE);
341
342 rgba8_image_t img;
343 read_image(png_path, img, settings);
344 BOOST_CHECK_EQUAL(backend._info._width, 32u);
345 BOOST_CHECK_EQUAL(backend._info._height, 32u);
346 BOOST_TEST(const_view(img).front() == rgba8c_pixel_t(0, 0, 255, 0));
347 BOOST_TEST(const_view(img)[16] == rgba8c_pixel_t(0, 0, 255, 85));
348 BOOST_TEST(const_view(img)[511] == rgba8c_pixel_t(0, 0, 255, 85));
349 BOOST_TEST(const_view(img)[1007] == rgba8c_pixel_t(0, 0, 255, 170));
350 BOOST_TEST(const_view(img).back() == rgba8c_pixel_t(0, 0, 255, 255));
351 }
352 }
353
354 #endif // BOOST_GIL_IO_TEST_ALLOW_READING_IMAGES
355
356 #ifdef BOOST_GIL_IO_USE_PNG_TEST_SUITE_IMAGES
357
BOOST_AUTO_TEST_CASE(BASIc_format_test)358 BOOST_AUTO_TEST_CASE( BASIc_format_test )
359 {
360 // Basic format test files (non-interlaced)
361
362 // BASN0g01 - black & white
363 test_file< gray1_image_t >( "BASN0G01.PNG" );
364 test_png_scanline_reader< gray1_image_t >( "BASN0G01.PNG" );
365
366 // BASN0g02 - 2 bit (4 level) grayscale
367 test_file< gray2_image_t >( "BASN0G02.PNG" );
368 test_png_scanline_reader< gray2_image_t >( "BASN0G02.PNG" );
369
370 // BASN0g04 - 4 bit (16 level) grayscale
371 test_file< gray4_image_t >( "BASN0G04.PNG" );
372 test_png_scanline_reader< gray4_image_t >( "BASN0G04.PNG" );
373
374 // BASN0g08 - 8 bit (256 level) grayscale
375 test_file< gray8_image_t >( "BASN0G08.PNG" );
376 test_png_scanline_reader< gray8_image_t >( "BASN0G08.PNG" );
377
378 // BASN0g16 - 16 bit (64k level) grayscale
379 test_file< gray16_image_t >( "BASN0G16.PNG" );
380 test_png_scanline_reader< gray16_image_t >( "BASN0G16.PNG" );
381
382 // BASN2c08 - 3x8 bits rgb color
383 test_file< rgb8_image_t >( "BASN2C08.PNG" );
384 test_png_scanline_reader< rgb8_image_t >( "BASN2C08.PNG" );
385
386 // BASN2c16 - 3x16 bits rgb color
387 test_file< rgb16_image_t >( "BASN2C16.PNG" );
388 test_png_scanline_reader< rgb16_image_t >( "BASN2C16.PNG" );
389
390 // BASN3p01 - 1 bit (2 color) paletted
391 test_file< rgb8_image_t >( "BASN3P01.PNG" );
392 test_png_scanline_reader< rgb8_image_t >( "BASN3P01.PNG" );
393
394 // BASN3p02 - 2 bit (4 color) paletted
395 test_file< rgb8_image_t >( "BASN3P02.PNG" );
396 test_png_scanline_reader< rgb8_image_t >( "BASN3P02.PNG" );
397
398 // BASN3p04 - 4 bit (16 color) paletted
399 test_file< rgb8_image_t >( "BASN3P04.PNG" );
400 test_png_scanline_reader< rgb8_image_t >( "BASN3P04.PNG" );
401
402 // BASN3p08 - 8 bit (256 color) paletted
403 test_file< rgb8_image_t >( "BASN3P08.PNG" );
404 test_png_scanline_reader< rgb8_image_t >( "BASN3P08.PNG" );
405
406 // BASN4a08 - 8 bit grayscale + 8 bit alpha-channel
407 test_file< gray_alpha8_image_t >( "BASN4A08.PNG" );
408 test_png_scanline_reader< gray_alpha8_image_t >( "BASN4A08.PNG" );
409
410 // BASN4a16 - 16 bit grayscale + 16 bit alpha-channel
411 test_file< gray_alpha16_image_t >( "BASN4A16.PNG" );
412 test_png_scanline_reader< gray_alpha16_image_t >( "BASN4A16.PNG" );
413
414 // BASN6a08 - 3x8 bits rgb color + 8 bit alpha-channel
415 test_file< rgba8_image_t >( "BASN6A08.PNG" );
416 test_png_scanline_reader< rgba8_image_t >( "BASN6A08.PNG" );
417
418 // BASN6a16 - 3x16 bits rgb color + 16 bit alpha-channel
419 test_file< rgba16_image_t >( "BASN6A16.PNG" );
420 test_png_scanline_reader< rgba16_image_t >( "BASN6A16.PNG" );
421 }
422
BOOST_AUTO_TEST_CASE(BASIc_format_interlaced_test)423 BOOST_AUTO_TEST_CASE( BASIc_format_interlaced_test )
424 {
425 // Basic format test files (Adam-7 interlaced)
426
427 // BASI0g01 - black & white
428 test_file< gray1_image_t >( "BASI0G01.PNG" );
429
430 // BASI0g02 - 2 bit (4 level) grayscale
431 test_file< gray2_image_t >( "BASI0G02.PNG" );
432
433 // BASI0g04 - 4 bit (16 level) grayscale
434 test_file< gray4_image_t >( "BASI0G04.PNG" );
435
436 // BASI0g08 - 8 bit (256 level) grayscale
437 test_file< gray8_image_t >( "BASI0G08.PNG" );
438
439 // BASI0g16 - 16 bit (64k level) grayscale
440 test_file< gray16_image_t >( "BASI0G16.PNG" );
441
442 // BASI2c08 - 3x8 bits rgb color
443 test_file< rgb8_image_t >( "BASI2C08.PNG" );
444
445 // BASI2c16 - 3x16 bits rgb color
446 test_file< rgb16_image_t >( "BASI2C16.PNG" );
447
448 // BASI3p01 - 1 bit (2 color) paletted
449 test_file< rgb8_image_t >( "BASI3P01.PNG" );
450
451 // BASI3p02 - 2 bit (4 color) paletted
452 test_file< rgb8_image_t >( "BASI3P02.PNG" );
453
454 // BASI3p04 - 4 bit (16 color) paletted
455 test_file< rgb8_image_t >( "BASI3P04.PNG" );
456
457 // BASI3p08 - 8 bit (256 color) paletted
458 test_file< rgb8_image_t >( "BASI3P08.PNG" );
459
460 // BASI4a08 - 8 bit grayscale + 8 bit alpha-channel
461 test_file< gray_alpha8_image_t >( "BASI4A08.PNG" );
462
463 // BASI4a16 - 16 bit grayscale + 16 bit alpha-channel
464 test_file< gray_alpha16_image_t >( "BASI4A16.PNG" );
465
466 // BASI6a08 - 3x8 bits rgb color + 8 bit alpha-channel
467 test_file< rgba8_image_t >( "BASI6A08.PNG" );
468
469 // BASI6a16 - 3x16 bits rgb color + 16 bit alpha-channel
470 test_file< rgba16_image_t >( "BASI6A16.PNG" );
471 }
472
BOOST_AUTO_TEST_CASE(odd_sizes_test)473 BOOST_AUTO_TEST_CASE( odd_sizes_test )
474 {
475 // S01I3P01 - 1x1 paletted file, interlaced
476 test_file< rgb8_image_t >( "S01I3P01.PNG" );
477
478 // S01N3P01 - 1x1 paletted file, no interlacing
479 test_file< rgb8_image_t >( "S01N3P01.PNG" );
480 test_png_scanline_reader< rgb8_image_t >( "S01N3P01.PNG" );
481
482 // S02I3P01 - 2x2 paletted file, interlaced
483 test_file< rgb8_image_t >( "S02I3P01.PNG" );
484
485 // S02N3P01 - 2x2 paletted file, no interlacing
486 test_file< rgb8_image_t >( "S02N3P01.PNG" );
487 test_png_scanline_reader< rgb8_image_t >( "S02N3P01.PNG" );
488
489 // S03I3P01 - 3x3 paletted file, interlaced
490 test_file< rgb8_image_t >( "S03I3P01.PNG" );
491
492 // S03N3P01 - 3x3 paletted file, no interlacing
493 test_file< rgb8_image_t >( "S03N3P01.PNG" );
494 test_png_scanline_reader< rgb8_image_t >( "S03N3P01.PNG" );
495
496 // S04I3P01 - 4x4 paletted file, interlaced
497 test_file< rgb8_image_t >( "S04I3P01.PNG" );
498
499 // S04N3P01 - 4x4 paletted file, no interlacing
500 test_file< rgb8_image_t >( "S04N3P01.PNG" );
501 test_png_scanline_reader< rgb8_image_t >( "S04N3P01.PNG" );
502
503 // S05I3P02 - 5x5 paletted file, interlaced
504 test_file< rgb8_image_t >( "S05I3P02.PNG" );
505
506 // S05N3P02 - 5x5 paletted file, no interlacing
507 test_file< rgb8_image_t >( "S05N3P02.PNG" );
508 test_png_scanline_reader< rgb8_image_t >( "S05N3P02.PNG" );
509
510 // S06I3P02 - 6x6 paletted file, interlaced
511 test_file< rgb8_image_t >( "S06I3P02.PNG" );
512
513 // S06N3P02 - 6x6 paletted file, no interlacing
514 test_file< rgb8_image_t >( "S06N3P02.PNG" );
515 test_png_scanline_reader< rgb8_image_t >( "S06N3P02.PNG" );
516
517 // S07I3P02 - 7x7 paletted file, interlaced
518 test_file< rgb8_image_t >( "S07I3P02.PNG" );
519
520 // S07N3P02 - 7x7 paletted file, no interlacing
521 test_file< rgb8_image_t >( "S07N3P02.PNG" );
522 test_png_scanline_reader< rgb8_image_t >( "S07N3P02.PNG" );
523
524 // S08I3P02 - 8x8 paletted file, interlaced
525 test_file< rgb8_image_t >( "S08I3P02.PNG" );
526
527 // S08N3P02 - 8x8 paletted file, no interlacing
528 test_file< rgb8_image_t >( "S08N3P02.PNG" );
529 test_png_scanline_reader< rgb8_image_t >( "S08N3P02.PNG" );
530
531 // S09I3P02 - 9x9 paletted file, interlaced
532 test_file< rgb8_image_t >( "S09I3P02.PNG" );
533
534 // S09N3P02 - 9x9 paletted file, no interlacing
535 test_file< rgb8_image_t >( "S09N3P02.PNG" );
536 test_png_scanline_reader< rgb8_image_t >( "S09N3P02.PNG" );
537
538 // S32I3P04 - 32x32 paletted file, interlaced
539 test_file< rgb8_image_t >( "S32I3P04.PNG" );
540
541 // S32N3P04 - 32x32 paletted file, no interlacing
542 test_file< rgb8_image_t >( "S32N3P04.PNG" );
543 test_png_scanline_reader< rgb8_image_t >( "S32N3P04.PNG" );
544
545 // S33I3P04 - 33x33 paletted file, interlaced
546 test_file< rgb8_image_t >( "S33I3P04.PNG" );
547
548 // S33N3P04 - 33x33 paletted file, no interlacing
549 test_file< rgb8_image_t >( "S33N3P04.PNG" );
550 test_png_scanline_reader< rgb8_image_t >( "S33N3P04.PNG" );
551
552 // S34I3P04 - 34x34 paletted file, interlaced
553 test_file< rgb8_image_t >( "S34I3P04.PNG" );
554
555 // S34N3P04 - 34x34 paletted file, no interlacing
556 test_file< rgb8_image_t >( "S34N3P04.PNG" );
557 test_png_scanline_reader< rgb8_image_t >( "S34N3P04.PNG" );
558
559 // S35I3P04 - 35x35 paletted file, interlaced
560 test_file< rgb8_image_t >( "S35I3P04.PNG" );
561
562 // S35N3P04 - 35x35 paletted file, no interlacing
563 test_file< rgb8_image_t >( "S35N3P04.PNG" );
564 test_png_scanline_reader< rgb8_image_t >( "S35N3P04.PNG" );
565
566 // S36I3P04 - 36x36 paletted file, interlaced
567 test_file< rgb8_image_t >( "S36I3P04.PNG" );
568
569 // S36N3P04 - 36x36 paletted file, no interlacing
570 test_file< rgb8_image_t >( "S36N3P04.PNG" );
571 test_png_scanline_reader< rgb8_image_t >( "S36N3P04.PNG" );
572
573 // S37I3P04 - 37x37 paletted file, interlaced
574 test_file< rgb8_image_t >( "S37I3P04.PNG" );
575
576 // S37N3P04 - 37x37 paletted file, no interlacing
577 test_file< rgb8_image_t >( "S37N3P04.PNG" );
578 test_png_scanline_reader< rgb8_image_t >( "S37N3P04.PNG" );
579
580 // S38I3P04 - 38x38 paletted file, interlaced
581 test_file< rgb8_image_t >( "S38I3P04.PNG" );
582
583 // S38N3P04 - 38x38 paletted file, no interlacing
584 test_file< rgb8_image_t >( "S38N3P04.PNG" );
585 test_png_scanline_reader< rgb8_image_t >( "S38N3P04.PNG" );
586
587 // S39I3P04 - 39x39 paletted file, interlaced
588 test_file< rgb8_image_t >( "S39I3P04.PNG" );
589
590 // S39N3P04 - 39x39 paletted file, no interlacing
591 test_file< rgb8_image_t >( "S39N3P04.PNG" );
592 test_png_scanline_reader< rgb8_image_t >( "S39N3P04.PNG" );
593
594 // S40I3P04 - 40x40 paletted file, interlaced
595 test_file< rgb8_image_t >( "S40I3P04.PNG" );
596
597 // S40N3P04 - 40x40 paletted file, no interlacing
598 test_file< rgb8_image_t >( "S40N3P04.PNG" );
599 test_png_scanline_reader< rgb8_image_t >( "S40N3P04.PNG" );
600 }
601
BOOST_AUTO_TEST_CASE(background_test)602 BOOST_AUTO_TEST_CASE( background_test )
603 {
604 // BGAI4A08 - 8 bit grayscale, alpha, no background chunk, interlaced
605 test_file< gray_alpha8_image_t >( "BGAI4A08.PNG" );
606
607 // BGAI4A16 - 16 bit grayscale, alpha, no background chunk, interlaced
608 test_file< gray_alpha16_image_t >( "BGAI4A16.PNG" );
609
610 // BGAN6A08 - 3x8 bits rgb color, alpha, no background chunk
611 test_file< rgba8_image_t >( "BGAN6A08.PNG" );
612
613 // BGAN6A16 - 3x16 bits rgb color, alpha, no background chunk
614 test_file< rgba16_image_t >( "BGAN6A16.PNG" );
615
616 // BGBN4A08 - 8 bit grayscale, alpha, black background chunk
617 test_file< gray_alpha8_image_t >( "BGBN4A08.PNG" );
618
619 // BGGN4A16 - 16 bit grayscale, alpha, gray background chunk
620 test_file< gray_alpha16_image_t >( "BGGN4A16.PNG" );
621
622 // BGWN6A08 - 3x8 bits rgb color, alpha, white background chunk
623 test_file< rgba8_image_t >( "BGWN6A08.PNG" );
624
625 // BGYN6A16 - 3x16 bits rgb color, alpha, yellow background chunk
626 test_file< rgba16_image_t >( "BGYN6A16.PNG" );
627 }
628
BOOST_AUTO_TEST_CASE(transparency_test)629 BOOST_AUTO_TEST_CASE( transparency_test )
630 {
631 // TBBN1G04 - transparent, black background chunk
632 // file missing
633 //test_file< gray_alpha8_image_t >( "TBBN1G04.PNG" );
634
635 // TBBN2C16 - transparent, blue background chunk
636 test_file< rgba16_image_t >( "TBBN2C16.PNG" );
637
638 // TBBN3P08 - transparent, black background chunk
639 test_file< rgba8_image_t >( "TBBN3P08.PNG" );
640
641 // TBGN2C16 - transparent, green background chunk
642 test_file< rgba16_image_t >( "TBGN2C16.PNG" );
643
644 // TBGN3P08 - transparent, light-gray background chunk
645 test_file< rgba8_image_t >( "TBGN3P08.PNG" );
646
647 // TBRN2C08 - transparent, red background chunk
648 test_file< rgba8_image_t >( "TBRN2C08.PNG" );
649
650 // TBWN1G16 - transparent, white background chunk
651 test_file< gray_alpha16_image_t >( "TBWN0G16.PNG" );
652
653 // TBWN3P08 - transparent, white background chunk
654 test_file< rgba8_image_t >( "TBWN3P08.PNG" );
655
656 // TBYN3P08 - transparent, yellow background chunk
657 test_file< rgba8_image_t >( "TBYN3P08.PNG" );
658
659 // TP0N1G08 - not transparent for reference (logo on gray)
660 test_file< gray8_image_t >( "TP0N0G08.PNG" );
661
662 // TP0N2C08 - not transparent for reference (logo on gray)
663 test_file< rgb8_image_t >( "TP0N2C08.PNG" );
664
665 // TP0N3P08 - not transparent for reference (logo on gray)
666 test_file< rgb8_image_t >( "TP0N3P08.PNG" );
667
668 // TP1N3P08 - transparent, but no background chunk
669 test_file< rgba8_image_t >( "TP1N3P08.PNG" );
670 }
671
BOOST_AUTO_TEST_CASE(gamma_test)672 BOOST_AUTO_TEST_CASE( gamma_test )
673 {
674 // G03N0G16 - grayscale, file-gamma = 0.35
675 test_file< gray16_image_t >( "G03N0G16.PNG" );
676
677 // G03N2C08 - color, file-gamma = 0.35
678 test_file< rgb8_image_t >( "G03N2C08.PNG" );
679
680 // G03N3P04 - paletted, file-gamma = 0.35
681 test_file< rgb8_image_t >( "G03N3P04.PNG" );
682
683 // G04N0G16 - grayscale, file-gamma = 0.45
684 test_file< gray16_image_t >( "G04N0G16.PNG" );
685
686 // G04N2C08 - color, file-gamma = 0.45
687 test_file< rgb8_image_t >( "G04N2C08.PNG" );
688
689 // G04N3P04 - paletted, file-gamma = 0.45
690 test_file< rgb8_image_t >( "G04N3P04.PNG" );
691
692 // G05N0G16 - grayscale, file-gamma = 0.55
693 test_file< gray16_image_t >( "G05N0G16.PNG" );
694
695 // G05N2C08 - color, file-gamma = 0.55
696 test_file< rgb8_image_t >( "G05N2C08.PNG" );
697
698 // G05N3P04 - paletted, file-gamma = 0.55
699 test_file< rgb8_image_t >( "G05N3P04.PNG" );
700
701 // G07N0G16 - grayscale, file-gamma = 0.70
702 test_file< gray16_image_t >( "G07N0G16.PNG" );
703
704 // G07N2C08 - color, file-gamma = 0.70
705 test_file< rgb8_image_t >( "G07N2C08.PNG" );
706
707 // G07N3P04 - paletted, file-gamma = 0.70
708 test_file< rgb8_image_t >( "G07N3P04.PNG" );
709
710 // G10N0G16 - grayscale, file-gamma = 1.00
711 test_file< gray16_image_t >( "G10N0G16.PNG" );
712
713 // G10N2C08 - color, file-gamma = 1.00
714 test_file< rgb8_image_t >( "G10N2C08.PNG" );
715
716 // G10N3P04 - paletted, file-gamma = 1.00
717 test_file< rgb8_image_t >( "G10N3P04.PNG" );
718
719 // G25N0G16 - grayscale, file-gamma = 2.50
720 test_file< gray16_image_t >( "G25N0G16.PNG" );
721
722 // G25N2C08 - color, file-gamma = 2.50
723 test_file< rgb8_image_t >( "G25N2C08.PNG" );
724
725 // G25N3P04 - paletted, file-gamma = 2.50
726 test_file< rgb8_image_t >( "G25N3P04.PNG" );
727 }
728
729 #endif // BOOST_GIL_IO_USE_PNG_TEST_SUITE_IMAGES
730
731 BOOST_AUTO_TEST_SUITE_END()
732