| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 120
 121
 122
 123
 124
 125
 126
 127
 128
 129
 130
 131
 132
 133
 134
 135
 136
 137
 138
 139
 140
 141
 142
 143
 144
 145
 146
 147
 148
 149
 150
 151
 152
 153
 154
 155
 
 | <!-- Copyright 2008 Lubomir Bourdev and Hailin Jin
     Distributed under the Boost Software License, Version 1.0.
     (See accompanying file LICENSE_1_0.txt or copy at
     http://www.boost.org/LICENSE_1_0.txt)
  -->
<!--
    Copyright 2005-2007 Adobe Systems Incorporated
    Distributed under the MIT License (see accompanying file LICENSE_1_0_0.txt
    or a copy at http://stlab.adobe.com/licenses.html)
    Some files are held under additional license.
    Please see "http://stlab.adobe.com/licenses.html" for more information.
-->
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
        "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en">
<head>
    <TITLE>Generic Image Library: png_io.hpp File Reference</TITLE>
    <META HTTP-EQUIV="content-type" CONTENT="text/html;charset=ISO-8859-1"/>
    <LINK TYPE="text/css" REL="stylesheet" HREF="adobe_source.css"/>
</head>
<body>
<table border="0" cellspacing="0" cellpadding="0" style='width: 100%; margin: 0; padding: 0'><tr>
<td width="100%" valign="top" style='padding-left: 10px; padding-right: 10px; padding-bottom: 10px'>
<div class="qindex"><a class="qindex" href="index.html">Modules</a> 
                  | <a class="qindex" href="classes.html">Alphabetical List</a> 
                  | <a class="qindex" href="annotated.html">Class List</a> 
                  | <a class="qindex" href="dirs.html">Directories</a> 
                  | <a class="qindex" href="files.html">File List</a> 
                  | <a class="qindex" href="../index.html">GIL Home Page</a> 
</div>
<!-- End Header -->
<!-- Generated by Doxygen 1.5.6 -->
  <div class="navpath"><a class="el" href="g_i_l_0076.html">boost</a> » <a class="el" href="g_i_l_0079.html">gil</a> » <a class="el" href="g_i_l_0078.html">extension</a> » <a class="el" href="g_i_l_0077.html">io</a>
  </div>
<div class="contents">
<h1>png_io.hpp File Reference</h1><hr><a name="_details"></a><h2>Detailed Description</h2>
Support for reading and writing PNG files Requires libpng and zlib! 
<p>
<p>
<code>#include <stdio.h></code><br>
<code>#include <string></code><br>
<code>#include "png.h"</code><br>
<code>#include <boost/static_assert.hpp></code><br>
<code>#include "<a class="el" href="g_i_l_0093.html">../../gil_config.hpp</a>"</code><br>
<code>#include "<a class="el" href="g_i_l_0642.html">../../utilities.hpp</a>"</code><br>
<code>#include "<a class="el" href="g_i_l_0228.html">io_error.hpp</a>"</code><br>
<code>#include "<a class="el" href="g_i_l_0253.html">png_io_private.hpp</a>"</code><br>
<p>
<a href="g_i_l_0252.html">Go to the source code of this file.</a><table border="0" cellpadding="0" cellspacing="0">
<tr><td></td></tr>
<tr><td colspan="2"><br><h2>Namespaces</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">namespace  </td><td class="memItemRight" valign="bottom"><a class="el" href="namespaceboost.html">boost</a></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">namespace  </td><td class="memItemRight" valign="bottom"><b>boost::gil</b></td></tr>
<tr><td colspan="2"><br><h2>Classes</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">struct  </td><td class="memItemRight" valign="bottom"><a class="el" href="g_i_l_0613.html">png_read_support</a></td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Determines whether the given view type is supported for reading.  <a href="g_i_l_0613.html#_details">More...</a><br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top">struct  </td><td class="memItemRight" valign="bottom"><a class="el" href="g_i_l_0615.html">png_write_support</a></td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Determines whether the given view type is supported for writing.  <a href="g_i_l_0615.html#_details">More...</a><br></td></tr>
<tr><td colspan="2"><br><h2>Functions</h2></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="g7a75144b324bb509ca6a5803b8669310"></a><!-- doxytag: member="png_io.hpp::png_read_dimensions" ref="g7a75144b324bb509ca6a5803b8669310" args="(const char *filename)" -->
point2< std::ptrdiff_t > </td><td class="memItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g7a75144b324bb509ca6a5803b8669310">png_read_dimensions</a> (const char *filename)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Returns the width and height of the PNG file at the specified location. Throws std::ios_base::failure if the location does not correspond to a valid PNG file. <br></td></tr>
<tr><td class="memItemLeft" nowrap align="right" valign="top"><a class="anchor" name="g5c20a2a469cdec4f530e02acab11e53e"></a><!-- doxytag: member="png_io.hpp::png_read_dimensions" ref="g5c20a2a469cdec4f530e02acab11e53e" args="(const std::string &filename)" -->
point2< std::ptrdiff_t > </td><td class="memItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g5c20a2a469cdec4f530e02acab11e53e">png_read_dimensions</a> (const std::string &filename)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Returns the width and height of the PNG file at the specified location. Throws std::ios_base::failure if the location does not correspond to a valid PNG file. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="gd38a3931f62a6341bd3d6f5a8a9575cc"></a><!-- doxytag: member="png_io.hpp::png_read_view" ref="gd38a3931f62a6341bd3d6f5a8a9575cc" args="(const char *filename, const View &view)" -->
template<typename View> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#gd38a3931f62a6341bd3d6f5a8a9575cc">png_read_view</a> (const char *filename, const View &view)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Loads the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name into the given view. Triggers a compile assert if the view color space and channel depth are not supported by the PNG library or by the I/O extension. Throws std::ios_base::failure if the file is not a valid PNG file, or if its color space or channel depth are not compatible with the ones specified by View, or if its dimensions don't match the ones of the view. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="g26a89c06bf3915307483129fb655a205"></a><!-- doxytag: member="png_io.hpp::png_read_view" ref="g26a89c06bf3915307483129fb655a205" args="(const std::string &filename, const View &view)" -->
template<typename View> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g26a89c06bf3915307483129fb655a205">png_read_view</a> (const std::string &filename, const View &view)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Loads the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name into the given view. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="gc295fb9e9c9cdaf7b570705a0e385ec6"></a><!-- doxytag: member="png_io.hpp::png_read_image" ref="gc295fb9e9c9cdaf7b570705a0e385ec6" args="(const char *filename, Image &im)" -->
template<typename Image> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#gc295fb9e9c9cdaf7b570705a0e385ec6">png_read_image</a> (const char *filename, Image &im)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Allocates a new <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> whose dimensions are determined by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file, and loads the pixels into it. Triggers a compile assert if the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> color space or channel depth are not supported by the PNG library or by the I/O extension. Throws std::ios_base::failure if the file is not a valid PNG file, or if its color space or channel depth are not compatible with the ones specified by Image. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="ge9a35f15e2544de801e23b3c481612a9"></a><!-- doxytag: member="png_io.hpp::png_read_image" ref="ge9a35f15e2544de801e23b3c481612a9" args="(const std::string &filename, Image &im)" -->
template<typename Image> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#ge9a35f15e2544de801e23b3c481612a9">png_read_image</a> (const std::string &filename, Image &im)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Allocates a new <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> whose dimensions are determined by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file, and loads the pixels into it. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="g98fb4592762b73fbf1f982159677d069"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_view" ref="g98fb4592762b73fbf1f982159677d069" args="(const char *filename, const View &view, CC cc)" -->
template<typename View, typename CC> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g98fb4592762b73fbf1f982159677d069">png_read_and_convert_view</a> (const char *filename, const View &view, CC cc)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Loads the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name and color-converts it into the given view. Throws std::ios_base::failure if the file is not a valid PNG file, or if its dimensions don't match the ones of the view. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="gdde60e9455374235470eb50affd92f1c"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_view" ref="gdde60e9455374235470eb50affd92f1c" args="(const char *filename, const View &view)" -->
template<typename View> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#gdde60e9455374235470eb50affd92f1c">png_read_and_convert_view</a> (const char *filename, const View &view)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Loads the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name and color-converts it into the given view. Throws std::ios_base::failure if the file is not a valid PNG file, or if its dimensions don't match the ones of the view. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="g14f5371946862331ccde3e67651df78a"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_view" ref="g14f5371946862331ccde3e67651df78a" args="(const std::string &filename, const View &view, CC cc)" -->
template<typename View, typename CC> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g14f5371946862331ccde3e67651df78a">png_read_and_convert_view</a> (const std::string &filename, const View &view, CC cc)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Loads the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name and color-converts it into the given view. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="gf26951df731c0669918fed7f372b7aca"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_view" ref="gf26951df731c0669918fed7f372b7aca" args="(const std::string &filename, const View &view)" -->
template<typename View> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#gf26951df731c0669918fed7f372b7aca">png_read_and_convert_view</a> (const std::string &filename, const View &view)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Loads the <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name and color-converts it into the given view. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="g7b9a2c89929e9400a85814548f1d3002"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_image" ref="g7b9a2c89929e9400a85814548f1d3002" args="(const char *filename, Image &im, CC cc)" -->
template<typename Image, typename CC> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g7b9a2c89929e9400a85814548f1d3002">png_read_and_convert_image</a> (const char *filename, Image &im, CC cc)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Allocates a new <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> whose dimensions are determined by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file, loads and color-converts the pixels into it. Throws std::ios_base::failure if the file is not a valid PNG file. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="gc5c5c8b057f342c96c410e03cea63b62"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_image" ref="gc5c5c8b057f342c96c410e03cea63b62" args="(const char *filename, Image &im)" -->
template<typename Image> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#gc5c5c8b057f342c96c410e03cea63b62">png_read_and_convert_image</a> (const char *filename, Image &im)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Allocates a new <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> whose dimensions are determined by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file, loads and color-converts the pixels into it. Throws std::ios_base::failure if the file is not a valid PNG file. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="g215e558f6c06c6e91a20367f07cbb208"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_image" ref="g215e558f6c06c6e91a20367f07cbb208" args="(const std::string &filename, Image &im, CC cc)" -->
template<typename Image, typename CC> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g215e558f6c06c6e91a20367f07cbb208">png_read_and_convert_image</a> (const std::string &filename, Image &im, CC cc)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Allocates a new <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> whose dimensions are determined by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file, loads and color-converts the pixels into it. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="g086e5851f7d0e6067cdbe4037bd39b28"></a><!-- doxytag: member="png_io.hpp::png_read_and_convert_image" ref="g086e5851f7d0e6067cdbe4037bd39b28" args="(const std::string &filename, Image &im)" -->
template<typename Image> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#g086e5851f7d0e6067cdbe4037bd39b28">png_read_and_convert_image</a> (const std::string &filename, Image &im)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Allocates a new <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> whose dimensions are determined by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file, loads and color-converts the pixels into it. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="ga3fb5aa5c76f3cf2ecbb35e9cc82a83a"></a><!-- doxytag: member="png_io.hpp::png_write_view" ref="ga3fb5aa5c76f3cf2ecbb35e9cc82a83a" args="(const char *filename, const View &view)" -->
template<typename View> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#ga3fb5aa5c76f3cf2ecbb35e9cc82a83a">png_write_view</a> (const char *filename, const View &view)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Saves the view to a png file specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name. Triggers a compile assert if the view color space and channel depth are not supported by the PNG library or by the I/O extension. Throws std::ios_base::failure if it fails to create the file. <br></td></tr>
<tr><td class="memTemplParams" nowrap colspan="2"><a class="anchor" name="gb8c6c4c3b78627324ac5983e348008de"></a><!-- doxytag: member="png_io.hpp::png_write_view" ref="gb8c6c4c3b78627324ac5983e348008de" args="(const std::string &filename, const View &view)" -->
template<typename View> </td></tr>
<tr><td class="memTemplItemLeft" nowrap align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="g_i_l_0174.html#gb8c6c4c3b78627324ac5983e348008de">png_write_view</a> (const std::string &filename, const View &view)</td></tr>
<tr><td class="mdescLeft"> </td><td class="mdescRight">Saves the view to a png file specified by the given png <a class="el" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> file name. <br></td></tr>
</table>
</div>
<hr size="1"><address style="text-align: right;"><small>Generated on Sat May 2 13:50:16 2009 for Generic Image Library by 
<a href="http://www.doxygen.org/index.html">
<img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address>
</body>
</html>
 |