Sophie

Sophie

distrib > Fedora > 14 > i386 > by-pkgid > 623999701586b0ea103ff2ccad7954a6 > files > 6350

boost-doc-1.44.0-1.fc14.noarch.rpm

<!-- 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>