blob: a7ecefa5bbb0eadd792e8aa474f01e30c61eeda6 [file] [log] [blame]
<!-- 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: image.hpp Source File</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>&nbsp;&raquo&nbsp;<a class="el" href="g_i_l_0079.html">gil</a>
</div>
<div class="contents">
<h1>image.hpp</h1><a href="image_8hpp.html">Go to the documentation of this file.</a><div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">/*</span>
<a name="l00002"></a>00002 <span class="comment"> Copyright 2005-2007 Adobe Systems Incorporated</span>
<a name="l00003"></a>00003 <span class="comment"> </span>
<a name="l00004"></a>00004 <span class="comment"> Use, modification and distribution are subject to the Boost Software License,</span>
<a name="l00005"></a>00005 <span class="comment"> Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at</span>
<a name="l00006"></a>00006 <span class="comment"> http://www.boost.org/LICENSE_1_0.txt).</span>
<a name="l00007"></a>00007 <span class="comment"></span>
<a name="l00008"></a>00008 <span class="comment"> See http://opensource.adobe.com/gil for most recent version including documentation.</span>
<a name="l00009"></a>00009 <span class="comment">*/</span>
<a name="l00010"></a>00010 <span class="comment">/*************************************************************************************************/</span>
<a name="l00011"></a>00011
<a name="l00012"></a>00012 <span class="preprocessor">#ifndef GIL_IMAGE_H</span>
<a name="l00013"></a>00013 <span class="preprocessor"></span><span class="preprocessor">#define GIL_IMAGE_H</span>
<a name="l00014"></a>00014 <span class="preprocessor"></span>
<a name="l00023"></a>00023
<a name="l00024"></a>00024 <span class="preprocessor">#include &lt;cstddef&gt;</span>
<a name="l00025"></a>00025 <span class="preprocessor">#include &lt;memory&gt;</span>
<a name="l00026"></a>00026 <span class="preprocessor">#include "<a class="code" href="g_i_l_0094.html" title="GIL configuration file.">gil_config.hpp</a>"</span>
<a name="l00027"></a>00027 <span class="preprocessor">#include "<a class="code" href="g_i_l_0225.html" title="image view class">image_view.hpp</a>"</span>
<a name="l00028"></a>00028 <span class="preprocessor">#include "<a class="code" href="g_i_l_0238.html" title="metafunctions that construct types or return type properties">metafunctions.hpp</a>"</span>
<a name="l00029"></a>00029 <span class="preprocessor">#include "<a class="code" href="algorithm_8hpp.html" title="Some basic STL-style algorithms when applied to image views.">algorithm.hpp</a>"</span>
<a name="l00030"></a>00030
<a name="l00031"></a>00031 <span class="keyword">namespace </span>boost { <span class="keyword">namespace </span>gil {
<a name="l00032"></a>00032
<a name="l00033"></a>00033 <span class="comment">//#ifdef _MSC_VER</span>
<a name="l00034"></a>00034 <span class="comment">//#pragma warning(push)</span>
<a name="l00035"></a>00035 <span class="comment">//#pragma warning(disable : 4244) // conversion from 'gil::image&lt;V,Alloc&gt;::coord_t' to 'int', possible loss of data (visual studio compiler doesn't realize that the two types are the same)</span>
<a name="l00036"></a>00036 <span class="comment">//#endif</span>
<a name="l00037"></a>00037
<a name="l00049"></a>00049
<a name="l00050"></a>00050 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc=std::allocator&lt;<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>&gt; &gt;
<a name="l00051"></a><a class="code" href="g_i_l_0038.html">00051</a> <span class="keyword">class </span><a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a> {
<a name="l00052"></a>00052 <span class="keyword">public</span>:
<a name="l00053"></a>00053 <span class="keyword">typedef</span> <span class="keyword">typename</span> Alloc::template rebind&lt;unsigned char&gt;::other allocator_type;
<a name="l00054"></a>00054 <span class="keyword">typedef</span> <span class="keyword">typename</span> <a class="code" href="g_i_l_0635.html" title="Returns the type of a view the pixel type, whether it operates on planar data and...">view_type_from_pixel&lt;Pixel, IsPlanar&gt;::type</a> view_t;
<a name="l00055"></a>00055 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::const_t const_view_t;
<a name="l00056"></a>00056 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::point_t point_t;
<a name="l00057"></a>00057 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::coord_t coord_t;
<a name="l00058"></a>00058 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::value_type value_type;
<a name="l00059"></a>00059 <span class="keyword">typedef</span> coord_t x_coord_t;
<a name="l00060"></a>00060 <span class="keyword">typedef</span> coord_t y_coord_t;
<a name="l00061"></a>00061
<a name="l00062"></a>00062 <span class="keyword">const</span> point_t&amp; dimensions()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _view.dimensions(); }
<a name="l00063"></a>00063 x_coord_t width()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _view.width(); }
<a name="l00064"></a>00064 y_coord_t height()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _view.height(); }
<a name="l00065"></a>00065
<a name="l00066"></a>00066 <span class="keyword">explicit</span> <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(std::size_t alignment=0,
<a name="l00067"></a>00067 <span class="keyword">const</span> Alloc alloc_in = Alloc()) :
<a name="l00068"></a>00068 _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) {}
<a name="l00069"></a>00069
<a name="l00070"></a>00070 <span class="comment">// Create with dimensions and optional initial value and alignment</span>
<a name="l00071"></a>00071 <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(<span class="keyword">const</span> point_t&amp; dimensions,
<a name="l00072"></a>00072 std::size_t alignment=0,
<a name="l00073"></a>00073 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) {
<a name="l00074"></a>00074 allocate_and_default_construct(dimensions);
<a name="l00075"></a>00075 }
<a name="l00076"></a>00076 <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(x_coord_t width, y_coord_t height,
<a name="l00077"></a>00077 std::size_t alignment=0,
<a name="l00078"></a>00078 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) {
<a name="l00079"></a>00079 allocate_and_default_construct(point_t(width,height));
<a name="l00080"></a>00080 }
<a name="l00081"></a>00081 <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(<span class="keyword">const</span> point_t&amp; dimensions,
<a name="l00082"></a>00082 <span class="keyword">const</span> Pixel&amp; p_in,
<a name="l00083"></a>00083 std::size_t alignment,
<a name="l00084"></a>00084 <span class="keyword">const</span> Alloc alloc_in = Alloc()) :
<a name="l00085"></a>00085 _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) {
<a name="l00086"></a>00086 allocate_and_fill(dimensions, p_in);
<a name="l00087"></a>00087 }
<a name="l00088"></a>00088 <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(x_coord_t width, y_coord_t height,
<a name="l00089"></a>00089 <span class="keyword">const</span> Pixel&amp; p_in,
<a name="l00090"></a>00090 std::size_t alignment,
<a name="l00091"></a>00091 <span class="keyword">const</span> Alloc alloc_in = Alloc()) :
<a name="l00092"></a>00092 _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) {
<a name="l00093"></a>00093 allocate_and_fill(point_t(width,height),p_in);
<a name="l00094"></a>00094 }
<a name="l00095"></a>00095
<a name="l00096"></a>00096 <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(<span class="keyword">const</span> <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>&amp; img) :
<a name="l00097"></a>00097 _memory(0), _align_in_bytes(img.<a class="code" href="g_i_l_0038.html#7934d8e50af85934aa82c1c138803c94">_align_in_bytes</a>), _alloc(img.<a class="code" href="g_i_l_0038.html#20191ef8d73669d6e4df5667f5faf362">_alloc</a>) {
<a name="l00098"></a>00098 allocate_and_copy(img.<a class="code" href="g_i_l_0038.html#f723fb36aee62ac02924637371797b7a">dimensions</a>(),img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>);
<a name="l00099"></a>00099 }
<a name="l00100"></a>00100
<a name="l00101"></a>00101 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> P2, <span class="keywordtype">bool</span> IP2, <span class="keyword">typename</span> Alloc2&gt;
<a name="l00102"></a>00102 <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image</a>(<span class="keyword">const</span> <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;P2,IP2,Alloc2&gt;</a>&amp; img) :
<a name="l00103"></a>00103 _memory(0), _align_in_bytes(img.<a class="code" href="g_i_l_0038.html#7934d8e50af85934aa82c1c138803c94">_align_in_bytes</a>), _alloc(img.<a class="code" href="g_i_l_0038.html#20191ef8d73669d6e4df5667f5faf362">_alloc</a>) {
<a name="l00104"></a>00104 allocate_and_copy(img.<a class="code" href="g_i_l_0038.html#f723fb36aee62ac02924637371797b7a">dimensions</a>(),img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>);
<a name="l00105"></a>00105 }
<a name="l00106"></a>00106 image&amp; operator=(<span class="keyword">const</span> image&amp; img) {
<a name="l00107"></a>00107 <span class="keywordflow">if</span> (dimensions() == img.<a class="code" href="g_i_l_0038.html#f723fb36aee62ac02924637371797b7a">dimensions</a>())
<a name="l00108"></a>00108 <a class="code" href="g_i_l_0145.html#g16f18749152217a2b84733c330a2b415" title="std::copy for image views">copy_pixels</a>(img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>,_view);
<a name="l00109"></a>00109 <span class="keywordflow">else</span> {
<a name="l00110"></a>00110 image tmp(img);
<a name="l00111"></a>00111 swap(tmp);
<a name="l00112"></a>00112 }
<a name="l00113"></a>00113 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
<a name="l00114"></a>00114 }
<a name="l00115"></a>00115
<a name="l00116"></a>00116 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Img&gt;
<a name="l00117"></a>00117 image&amp; operator=(<span class="keyword">const</span> Img&amp; img) {
<a name="l00118"></a>00118 <span class="keywordflow">if</span> (dimensions() == img.dimensions())
<a name="l00119"></a>00119 <a class="code" href="g_i_l_0145.html#g16f18749152217a2b84733c330a2b415" title="std::copy for image views">copy_pixels</a>(img._view,_view);
<a name="l00120"></a>00120 <span class="keywordflow">else</span> {
<a name="l00121"></a>00121 image tmp(img);
<a name="l00122"></a>00122 swap(tmp);
<a name="l00123"></a>00123 }
<a name="l00124"></a>00124 <span class="keywordflow">return</span> *<span class="keyword">this</span>;
<a name="l00125"></a>00125 }
<a name="l00126"></a>00126
<a name="l00127"></a>00127 ~image() {
<a name="l00128"></a>00128 <a class="code" href="g_i_l_0147.html#g5c465a97a10e15d9ce18a3c2fff7f91d" title="Invokes the in-place destructor on every pixel of the view.">destruct_pixels</a>(_view);
<a name="l00129"></a>00129 deallocate(_view.dimensions());
<a name="l00130"></a>00130 }
<a name="l00131"></a>00131
<a name="l00132"></a>00132 Alloc&amp; allocator() { <span class="keywordflow">return</span> _alloc; }
<a name="l00133"></a>00133 Alloc <span class="keyword">const</span>&amp; allocator()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _alloc; }
<a name="l00134"></a>00134
<a name="l00135"></a>00135 <span class="keywordtype">void</span> swap(image&amp; img) { <span class="comment">// required by MutableContainerConcept</span>
<a name="l00136"></a>00136 <span class="keyword">using</span> std::swap;
<a name="l00137"></a>00137 swap(_align_in_bytes, img.<a class="code" href="g_i_l_0038.html#7934d8e50af85934aa82c1c138803c94">_align_in_bytes</a>);
<a name="l00138"></a>00138 swap(_memory, img.<a class="code" href="g_i_l_0038.html#4dac70d11e580dd17433c7cc64942596">_memory</a>);
<a name="l00139"></a>00139 swap(_view, img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>);
<a name="l00140"></a>00140 swap(_alloc, img.<a class="code" href="g_i_l_0038.html#20191ef8d73669d6e4df5667f5faf362">_alloc</a>);
<a name="l00141"></a>00141 }
<a name="l00142"></a>00142
<a name="l00143"></a>00143 <span class="keywordtype">void</span> recreate(<span class="keyword">const</span> point_t&amp; dims, std::size_t alignment=0, <span class="keyword">const</span> Alloc alloc_in = Alloc()) {
<a name="l00144"></a>00144 <span class="keywordflow">if</span> (dims!=_view.dimensions() || _align_in_bytes!=alignment || alloc_in!=_alloc) {
<a name="l00145"></a>00145 image tmp(dims, alignment, alloc_in);
<a name="l00146"></a>00146 swap(tmp);
<a name="l00147"></a>00147 }
<a name="l00148"></a>00148 }
<a name="l00149"></a>00149 <span class="keywordtype">void</span> recreate(x_coord_t width, y_coord_t height, std::size_t alignment=0, <span class="keyword">const</span> Alloc alloc_in = Alloc()) {
<a name="l00150"></a>00150 recreate(point_t(width,height),alignment,alloc_in);
<a name="l00151"></a>00151 }
<a name="l00152"></a>00152 <span class="keywordtype">void</span> recreate(<span class="keyword">const</span> point_t&amp; dims,
<a name="l00153"></a>00153 <span class="keyword">const</span> Pixel&amp; p_in, std::size_t alignment, <span class="keyword">const</span> Alloc alloc_in = Alloc()) {
<a name="l00154"></a>00154 <span class="keywordflow">if</span> (dims!=_view.dimensions() || _align_in_bytes!=alignment || alloc_in!=_alloc) {
<a name="l00155"></a>00155 image tmp(dims, p_in, alignment, alloc_in);
<a name="l00156"></a>00156 swap(tmp);
<a name="l00157"></a>00157 }
<a name="l00158"></a>00158 }
<a name="l00159"></a>00159 <span class="keywordtype">void</span> recreate(x_coord_t width, y_coord_t height,
<a name="l00160"></a>00160 <span class="keyword">const</span> Pixel&amp; p_in, std::size_t alignment, <span class="keyword">const</span> Alloc alloc_in = Alloc()) {
<a name="l00161"></a>00161 recreate(point_t(width,height),p_in,alignment,alloc_in);
<a name="l00162"></a>00162 }
<a name="l00163"></a>00163
<a name="l00164"></a>00164 view_t _view; <span class="comment">// contains pointer to the pixels, the image size and ways to navigate pixels</span>
<a name="l00165"></a>00165 <span class="keyword">private</span>:
<a name="l00166"></a>00166 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* _memory;
<a name="l00167"></a>00167 std::size_t _align_in_bytes;
<a name="l00168"></a>00168 allocator_type _alloc;
<a name="l00169"></a>00169
<a name="l00170"></a>00170 <span class="keywordtype">void</span> allocate_and_default_construct(<span class="keyword">const</span> point_t&amp; dimensions) {
<a name="l00171"></a>00171 <span class="keywordflow">try</span> {
<a name="l00172"></a>00172 allocate_(dimensions,mpl::bool_&lt;IsPlanar&gt;());
<a name="l00173"></a>00173 <a class="code" href="g_i_l_0146.html#g523e1cfd5c8023f14055cb52489431c8" title="Invokes the in-place default constructor on every pixel of the (uninitialized) view...">default_construct_pixels</a>(_view);
<a name="l00174"></a>00174 } <span class="keywordflow">catch</span>(...) { deallocate(dimensions); <span class="keywordflow">throw</span>; }
<a name="l00175"></a>00175 }
<a name="l00176"></a>00176
<a name="l00177"></a>00177 <span class="keywordtype">void</span> allocate_and_fill(<span class="keyword">const</span> point_t&amp; dimensions, <span class="keyword">const</span> Pixel&amp; p_in) {
<a name="l00178"></a>00178 <span class="keywordflow">try</span> {
<a name="l00179"></a>00179 allocate_(dimensions,mpl::bool_&lt;IsPlanar&gt;());
<a name="l00180"></a>00180 <a class="code" href="g_i_l_0156.html#g4f5edbc3fe6b776c6aa1939902333cf3" title="std::uninitialized_fill for image views. Does not support planar heterogeneous views...">uninitialized_fill_pixels</a>(_view, p_in);
<a name="l00181"></a>00181 } <span class="keywordflow">catch</span>(...) { deallocate(dimensions); <span class="keywordflow">throw</span>; }
<a name="l00182"></a>00182 }
<a name="l00183"></a>00183
<a name="l00184"></a>00184 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> View&gt;
<a name="l00185"></a>00185 <span class="keywordtype">void</span> allocate_and_copy(<span class="keyword">const</span> point_t&amp; dimensions, <span class="keyword">const</span> View&amp; v) {
<a name="l00186"></a>00186 <span class="keywordflow">try</span> {
<a name="l00187"></a>00187 allocate_(dimensions,mpl::bool_&lt;IsPlanar&gt;());
<a name="l00188"></a>00188 <a class="code" href="g_i_l_0155.html#ge33d703beb3b085809b3b3ca64cc8906" title="std::uninitialized_copy for image views. Does not support planar heterogeneous views...">uninitialized_copy_pixels</a>(v,_view);
<a name="l00189"></a>00189 } <span class="keywordflow">catch</span>(...) { deallocate(dimensions); <span class="keywordflow">throw</span>; }
<a name="l00190"></a>00190 }
<a name="l00191"></a>00191
<a name="l00192"></a>00192 <span class="keywordtype">void</span> deallocate(<span class="keyword">const</span> point_t&amp; dimensions) {
<a name="l00193"></a>00193 <span class="keywordflow">if</span> (_memory) _alloc.deallocate(_memory, total_allocated_size_in_bytes(dimensions));
<a name="l00194"></a>00194 }
<a name="l00195"></a>00195
<a name="l00196"></a>00196 std::size_t total_allocated_size_in_bytes(<span class="keyword">const</span> point_t&amp; dimensions)<span class="keyword"> const </span>{
<a name="l00197"></a>00197 std::size_t size_in_units = get_row_size_in_memunits(dimensions.x)*dimensions.y;
<a name="l00198"></a>00198 <span class="keywordflow">if</span> (IsPlanar)
<a name="l00199"></a>00199 size_in_units = size_in_units*<a class="code" href="g_i_l_0581.html" title="Returns the number of channels of a pixel-based GIL construct.">num_channels&lt;view_t&gt;::value</a>;
<a name="l00200"></a>00200
<a name="l00201"></a>00201 <span class="comment">// return the size rounded up to the nearest byte</span>
<a name="l00202"></a>00202 <span class="keywordflow">return</span> (size_in_units + <a class="code" href="g_i_l_0406.html">byte_to_memunit&lt;typename view_t::x_iterator&gt;::value</a> - 1) / <a class="code" href="g_i_l_0406.html">byte_to_memunit&lt;typename view_t::x_iterator&gt;::value</a>
<a name="l00203"></a>00203 + (_align_in_bytes&gt;0 ? _align_in_bytes-1:0); <span class="comment">// add extra padding in case we need to align the first image pixel</span>
<a name="l00204"></a>00204 }
<a name="l00205"></a>00205
<a name="l00206"></a>00206 std::size_t get_row_size_in_memunits(x_coord_t width)<span class="keyword"> const </span>{ <span class="comment">// number of units per row</span>
<a name="l00207"></a>00207 std::size_t size_in_memunits = width*memunit_step(<span class="keyword">typename</span> view_t::x_iterator());
<a name="l00208"></a>00208 <span class="keywordflow">if</span> (_align_in_bytes&gt;0) {
<a name="l00209"></a>00209 std::size_t alignment_in_memunits=_align_in_bytes*<a class="code" href="g_i_l_0406.html">byte_to_memunit&lt;typename view_t::x_iterator&gt;::value</a>;
<a name="l00210"></a>00210 <span class="keywordflow">return</span> align(size_in_memunits, alignment_in_memunits);
<a name="l00211"></a>00211 }
<a name="l00212"></a>00212 <span class="keywordflow">return</span> size_in_memunits;
<a name="l00213"></a>00213 }
<a name="l00214"></a>00214
<a name="l00215"></a>00215 <span class="keywordtype">void</span> allocate_(<span class="keyword">const</span> point_t&amp; dimensions, mpl::false_) { <span class="comment">// if it throws and _memory!=0 the client must deallocate _memory</span>
<a name="l00216"></a>00216 _memory=_alloc.allocate(total_allocated_size_in_bytes(dimensions));
<a name="l00217"></a>00217 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* tmp=(_align_in_bytes&gt;0) ? (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)align((std::size_t)_memory,_align_in_bytes) : _memory;
<a name="l00218"></a>00218 _view=view_t(dimensions,<span class="keyword">typename</span> view_t::locator(<span class="keyword">typename</span> view_t::x_iterator(tmp),get_row_size_in_memunits(dimensions.x)));
<a name="l00219"></a>00219 }
<a name="l00220"></a>00220
<a name="l00221"></a>00221 <span class="keywordtype">void</span> allocate_(<span class="keyword">const</span> point_t&amp; dimensions, mpl::true_) { <span class="comment">// if it throws and _memory!=0 the client must deallocate _memory</span>
<a name="l00222"></a>00222 std::size_t row_size=get_row_size_in_memunits(dimensions.x);
<a name="l00223"></a>00223 std::size_t plane_size=row_size*dimensions.y;
<a name="l00224"></a>00224 _memory=_alloc.allocate(total_allocated_size_in_bytes(dimensions));
<a name="l00225"></a>00225 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* tmp=(_align_in_bytes&gt;0) ? (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)align((std::size_t)_memory,_align_in_bytes) : _memory;
<a name="l00226"></a>00226 <span class="keyword">typename</span> view_t::x_iterator first;
<a name="l00227"></a>00227 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i=0; i&lt;num_channels&lt;view_t&gt;::value; ++i) {
<a name="l00228"></a>00228 dynamic_at_c(first,i) = (<span class="keyword">typename</span> channel_type&lt;view_t&gt;::type*)tmp;
<a name="l00229"></a>00229 memunit_advance(dynamic_at_c(first,i), plane_size*i);
<a name="l00230"></a>00230 }
<a name="l00231"></a>00231 _view=view_t(dimensions, <span class="keyword">typename</span> view_t::locator(first, row_size));
<a name="l00232"></a>00232 }
<a name="l00233"></a>00233 };
<a name="l00234"></a>00234
<a name="l00235"></a>00235 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt;
<a name="l00236"></a>00236 <span class="keywordtype">void</span> swap(<a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel, IsPlanar, Alloc&gt;</a>&amp; im1,<a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel, IsPlanar, Alloc&gt;</a>&amp; im2) {
<a name="l00237"></a>00237 im1.<a class="code" href="g_i_l_0038.html#ecbe6d01103834f8178f73465a19d58c">swap</a>(im2);
<a name="l00238"></a>00238 }
<a name="l00239"></a>00239
<a name="l00240"></a>00240 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel1, <span class="keywordtype">bool</span> IsPlanar1, <span class="keyword">typename</span> Alloc1, <span class="keyword">typename</span> Pixel2, <span class="keywordtype">bool</span> IsPlanar2, <span class="keyword">typename</span> Alloc2&gt;
<a name="l00241"></a>00241 <span class="keywordtype">bool</span> operator==(<span class="keyword">const</span> image&lt;Pixel1,IsPlanar1,Alloc1&gt;&amp; im1,<span class="keyword">const</span> image&lt;Pixel2,IsPlanar2,Alloc2&gt;&amp; im2) {
<a name="l00242"></a>00242 <span class="keywordflow">if</span> ((<span class="keywordtype">void</span>*)(&amp;im1)==(<span class="keywordtype">void</span>*)(&amp;im2)) <span class="keywordflow">return</span> <span class="keyword">true</span>;
<a name="l00243"></a>00243 <span class="keywordflow">if</span> (<a class="code" href="g_i_l_0135.html#g9e185237819e788838a0d337d21ab722" title="Returns the constant-pixel view of any image. The returned view is any view.">const_view</a>(im1).dimensions()!=<a class="code" href="g_i_l_0135.html#g9e185237819e788838a0d337d21ab722" title="Returns the constant-pixel view of any image. The returned view is any view.">const_view</a>(im2).dimensions()) <span class="keywordflow">return</span> <span class="keyword">false</span>;
<a name="l00244"></a>00244 <span class="keywordflow">return</span> equal_pixels(<a class="code" href="g_i_l_0135.html#g9e185237819e788838a0d337d21ab722" title="Returns the constant-pixel view of any image. The returned view is any view.">const_view</a>(im1),<a class="code" href="g_i_l_0135.html#g9e185237819e788838a0d337d21ab722" title="Returns the constant-pixel view of any image. The returned view is any view.">const_view</a>(im2));
<a name="l00245"></a>00245 }
<a name="l00246"></a>00246 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel1, <span class="keywordtype">bool</span> IsPlanar1, <span class="keyword">typename</span> Alloc1, <span class="keyword">typename</span> Pixel2, <span class="keywordtype">bool</span> IsPlanar2, <span class="keyword">typename</span> Alloc2&gt;
<a name="l00247"></a>00247 <span class="keywordtype">bool</span> operator!=(<span class="keyword">const</span> image&lt;Pixel1,IsPlanar1,Alloc1&gt;&amp; im1,<span class="keyword">const</span> image&lt;Pixel2,IsPlanar2,Alloc2&gt;&amp; im2) {<span class="keywordflow">return</span> !(im1==im2);}
<a name="l00248"></a>00248
<a name="l00252"></a>00252
<a name="l00254"></a>00254
<a name="l00256"></a>00256 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt; <span class="keyword">inline</span>
<a name="l00257"></a><a class="code" href="g_i_l_0135.html#gad0335b7d343667d626556681486f198">00257</a> <span class="keyword">const</span> <span class="keyword">typename</span> <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel,IsPlanar,Alloc&gt;::view_t</a>&amp; <a class="code" href="g_i_l_0135.html#g55e45a15dddfc0d870c2f7fb9739cb2e" title="Returns the non-constant-pixel view of any image. The returned view is any view.">view</a>(<a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel,IsPlanar,Alloc&gt;</a>&amp; img) { <span class="keywordflow">return</span> img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>; }
<a name="l00258"></a>00258
<a name="l00260"></a>00260 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt; <span class="keyword">inline</span>
<a name="l00261"></a><a class="code" href="g_i_l_0135.html#ged731349e60a30a3a241fd1809729996">00261</a> <span class="keyword">const</span> <span class="keyword">typename</span> <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel,IsPlanar,Alloc&gt;::const_view_t</a> <a class="code" href="g_i_l_0135.html#g9e185237819e788838a0d337d21ab722" title="Returns the constant-pixel view of any image. The returned view is any view.">const_view</a>(<span class="keyword">const</span> <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel,IsPlanar,Alloc&gt;</a>&amp; img) {
<a name="l00262"></a>00262 <span class="keywordflow">return</span> <span class="keyword">static_cast&lt;</span><span class="keyword">const </span>typename <a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image&lt;Pixel,IsPlanar,Alloc&gt;::const_view_t</a><span class="keyword">&gt;</span>(img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>);
<a name="l00263"></a>00263 }
<a name="l00265"></a>00265
<a name="l00267"></a>00267 <span class="comment">// PixelBasedConcept</span>
<a name="l00269"></a>00269 <span class="comment"></span>
<a name="l00270"></a>00270 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt;
<a name="l00271"></a>00271 <span class="keyword">struct </span>channel_type&lt;image&lt;Pixel,IsPlanar,Alloc&gt; &gt; : <span class="keyword">public</span> channel_type&lt;Pixel&gt; {};
<a name="l00272"></a>00272
<a name="l00273"></a>00273 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt;
<a name="l00274"></a>00274 <span class="keyword">struct </span>color_space_type&lt;image&lt;Pixel,IsPlanar,Alloc&gt; &gt; : <span class="keyword">public</span> color_space_type&lt;Pixel&gt; {};
<a name="l00275"></a>00275
<a name="l00276"></a>00276 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt;
<a name="l00277"></a>00277 <span class="keyword">struct </span>channel_mapping_type&lt;image&lt;Pixel,IsPlanar,Alloc&gt; &gt; : <span class="keyword">public</span> channel_mapping_type&lt;Pixel&gt; {};
<a name="l00278"></a>00278
<a name="l00279"></a>00279 <span class="keyword">template</span> &lt;<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc&gt;
<a name="l00280"></a>00280 <span class="keyword">struct </span>is_planar&lt;image&lt;Pixel,IsPlanar,Alloc&gt; &gt; : <span class="keyword">public</span> mpl::bool_&lt;IsPlanar&gt; {};
<a name="l00281"></a>00281
<a name="l00282"></a>00282 <span class="comment">//#ifdef _MSC_VER</span>
<a name="l00283"></a>00283 <span class="comment">//#pragma warning(pop)</span>
<a name="l00284"></a>00284 <span class="comment">//#endif</span>
<a name="l00285"></a>00285
<a name="l00286"></a>00286 } } <span class="comment">// namespace boost::gil</span>
<a name="l00287"></a>00287
<a name="l00288"></a>00288 <span class="preprocessor">#endif</span>
</pre></div></div>
<hr size="1"><address style="text-align: right;"><small>Generated on Sat May 2 13:50:14 2009 for Generic Image Library by&nbsp;
<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>