]>
Commit | Line | Data |
---|---|---|
1 | <!-- Copyright 2008 Lubomir Bourdev and Hailin Jin | |
2 | ||
3 | Distributed under the Boost Software License, Version 1.0. | |
4 | (See accompanying file LICENSE_1_0.txt or copy at | |
5 | http://www.boost.org/LICENSE_1_0.txt) | |
6 | --> | |
7 | ||
8 | <!-- | |
9 | Copyright 2005-2007 Adobe Systems Incorporated | |
10 | Distributed under the MIT License (see accompanying file LICENSE_1_0_0.txt | |
11 | or a copy at http://stlab.adobe.com/licenses.html) | |
12 | ||
13 | Some files are held under additional license. | |
14 | Please see "http://stlab.adobe.com/licenses.html" for more information. | |
15 | --> | |
16 | ||
17 | <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" | |
18 | "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> | |
19 | <html xmlns="http://www.w3.org/1999/xhtml" lang="en" xml:lang="en"> | |
20 | ||
21 | <head> | |
22 | <TITLE>Generic Image Library: image.hpp Source File</TITLE> | |
23 | <META HTTP-EQUIV="content-type" CONTENT="text/html;charset=ISO-8859-1"/> | |
24 | <LINK TYPE="text/css" REL="stylesheet" HREF="adobe_source.css"/> | |
25 | </head> | |
26 | <body> | |
27 | <table border="0" cellspacing="0" cellpadding="0" style='width: 100%; margin: 0; padding: 0'><tr> | |
28 | <td width="100%" valign="top" style='padding-left: 10px; padding-right: 10px; padding-bottom: 10px'> | |
29 | <div class="qindex"><a class="qindex" href="index.html">Modules</a> | |
30 | | <a class="qindex" href="classes.html">Alphabetical List</a> | |
31 | | <a class="qindex" href="annotated.html">Class List</a> | |
32 | | <a class="qindex" href="dirs.html">Directories</a> | |
33 | | <a class="qindex" href="files.html">File List</a> | |
34 | | <a class="qindex" href="../index.html">GIL Home Page</a> | |
35 | </div> | |
36 | <!-- End Header --> | |
37 | <!-- Generated by Doxygen 1.5.6 --> | |
38 | <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> | |
39 | </div> | |
40 | <div class="contents"> | |
41 | <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> | |
42 | <a name="l00002"></a>00002 <span class="comment"> Copyright 2005-2007 Adobe Systems Incorporated</span> | |
43 | <a name="l00003"></a>00003 <span class="comment"> </span> | |
44 | <a name="l00004"></a>00004 <span class="comment"> Use, modification and distribution are subject to the Boost Software License,</span> | |
45 | <a name="l00005"></a>00005 <span class="comment"> Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at</span> | |
46 | <a name="l00006"></a>00006 <span class="comment"> http://www.boost.org/LICENSE_1_0.txt).</span> | |
47 | <a name="l00007"></a>00007 <span class="comment"></span> | |
48 | <a name="l00008"></a>00008 <span class="comment"> See http://opensource.adobe.com/gil for most recent version including documentation.</span> | |
49 | <a name="l00009"></a>00009 <span class="comment">*/</span> | |
50 | <a name="l00010"></a>00010 <span class="comment">/*************************************************************************************************/</span> | |
51 | <a name="l00011"></a>00011 | |
52 | <a name="l00012"></a>00012 <span class="preprocessor">#ifndef GIL_IMAGE_H</span> | |
53 | <a name="l00013"></a>00013 <span class="preprocessor"></span><span class="preprocessor">#define GIL_IMAGE_H</span> | |
54 | <a name="l00014"></a>00014 <span class="preprocessor"></span> | |
55 | <a name="l00023"></a>00023 | |
56 | <a name="l00024"></a>00024 <span class="preprocessor">#include <cstddef></span> | |
57 | <a name="l00025"></a>00025 <span class="preprocessor">#include <memory></span> | |
58 | <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> | |
59 | <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> | |
60 | <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> | |
61 | <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> | |
62 | <a name="l00030"></a>00030 | |
63 | <a name="l00031"></a>00031 <span class="keyword">namespace </span>boost { <span class="keyword">namespace </span>gil { | |
64 | <a name="l00032"></a>00032 | |
65 | <a name="l00033"></a>00033 <span class="comment">//#ifdef _MSC_VER</span> | |
66 | <a name="l00034"></a>00034 <span class="comment">//#pragma warning(push)</span> | |
67 | <a name="l00035"></a>00035 <span class="comment">//#pragma warning(disable : 4244) // conversion from 'gil::image<V,Alloc>::coord_t' to 'int', possible loss of data (visual studio compiler doesn't realize that the two types are the same)</span> | |
68 | <a name="l00036"></a>00036 <span class="comment">//#endif</span> | |
69 | <a name="l00037"></a>00037 | |
70 | <a name="l00049"></a>00049 | |
71 | <a name="l00050"></a>00050 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc=std::allocator<<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>> > | |
72 | <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> { | |
73 | <a name="l00052"></a>00052 <span class="keyword">public</span>: | |
74 | <a name="l00053"></a>00053 <span class="keyword">typedef</span> <span class="keyword">typename</span> Alloc::template rebind<unsigned char>::other allocator_type; | |
75 | <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<Pixel, IsPlanar>::type</a> view_t; | |
76 | <a name="l00055"></a>00055 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::const_t const_view_t; | |
77 | <a name="l00056"></a>00056 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::point_t point_t; | |
78 | <a name="l00057"></a>00057 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::coord_t coord_t; | |
79 | <a name="l00058"></a>00058 <span class="keyword">typedef</span> <span class="keyword">typename</span> view_t::value_type value_type; | |
80 | <a name="l00059"></a>00059 <span class="keyword">typedef</span> coord_t x_coord_t; | |
81 | <a name="l00060"></a>00060 <span class="keyword">typedef</span> coord_t y_coord_t; | |
82 | <a name="l00061"></a>00061 | |
83 | <a name="l00062"></a>00062 <span class="keyword">const</span> point_t& dimensions()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _view.dimensions(); } | |
84 | <a name="l00063"></a>00063 x_coord_t width()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _view.width(); } | |
85 | <a name="l00064"></a>00064 y_coord_t height()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _view.height(); } | |
86 | <a name="l00065"></a>00065 | |
87 | <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, | |
88 | <a name="l00067"></a>00067 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : | |
89 | <a name="l00068"></a>00068 _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) {} | |
90 | <a name="l00069"></a>00069 | |
91 | <a name="l00070"></a>00070 <span class="comment">// Create with dimensions and optional initial value and alignment</span> | |
92 | <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& dimensions, | |
93 | <a name="l00072"></a>00072 std::size_t alignment=0, | |
94 | <a name="l00073"></a>00073 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) { | |
95 | <a name="l00074"></a>00074 allocate_and_default_construct(dimensions); | |
96 | <a name="l00075"></a>00075 } | |
97 | <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, | |
98 | <a name="l00077"></a>00077 std::size_t alignment=0, | |
99 | <a name="l00078"></a>00078 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) { | |
100 | <a name="l00079"></a>00079 allocate_and_default_construct(point_t(width,height)); | |
101 | <a name="l00080"></a>00080 } | |
102 | <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& dimensions, | |
103 | <a name="l00082"></a>00082 <span class="keyword">const</span> Pixel& p_in, | |
104 | <a name="l00083"></a>00083 std::size_t alignment, | |
105 | <a name="l00084"></a>00084 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : | |
106 | <a name="l00085"></a>00085 _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) { | |
107 | <a name="l00086"></a>00086 allocate_and_fill(dimensions, p_in); | |
108 | <a name="l00087"></a>00087 } | |
109 | <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, | |
110 | <a name="l00089"></a>00089 <span class="keyword">const</span> Pixel& p_in, | |
111 | <a name="l00090"></a>00090 std::size_t alignment, | |
112 | <a name="l00091"></a>00091 <span class="keyword">const</span> Alloc alloc_in = Alloc()) : | |
113 | <a name="l00092"></a>00092 _memory(0), _align_in_bytes(alignment), _alloc(alloc_in) { | |
114 | <a name="l00093"></a>00093 allocate_and_fill(point_t(width,height),p_in); | |
115 | <a name="l00094"></a>00094 } | |
116 | <a name="l00095"></a>00095 | |
117 | <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>& img) : | |
118 | <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>) { | |
119 | <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>); | |
120 | <a name="l00099"></a>00099 } | |
121 | <a name="l00100"></a>00100 | |
122 | <a name="l00101"></a>00101 <span class="keyword">template</span> <<span class="keyword">typename</span> P2, <span class="keywordtype">bool</span> IP2, <span class="keyword">typename</span> Alloc2> | |
123 | <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<P2,IP2,Alloc2></a>& img) : | |
124 | <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>) { | |
125 | <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>); | |
126 | <a name="l00105"></a>00105 } | |
127 | <a name="l00106"></a>00106 image& operator=(<span class="keyword">const</span> image& img) { | |
128 | <a name="l00107"></a>00107 <span class="keywordflow">if</span> (dimensions() == img.<a class="code" href="g_i_l_0038.html#f723fb36aee62ac02924637371797b7a">dimensions</a>()) | |
129 | <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); | |
130 | <a name="l00109"></a>00109 <span class="keywordflow">else</span> { | |
131 | <a name="l00110"></a>00110 image tmp(img); | |
132 | <a name="l00111"></a>00111 swap(tmp); | |
133 | <a name="l00112"></a>00112 } | |
134 | <a name="l00113"></a>00113 <span class="keywordflow">return</span> *<span class="keyword">this</span>; | |
135 | <a name="l00114"></a>00114 } | |
136 | <a name="l00115"></a>00115 | |
137 | <a name="l00116"></a>00116 <span class="keyword">template</span> <<span class="keyword">typename</span> Img> | |
138 | <a name="l00117"></a>00117 image& operator=(<span class="keyword">const</span> Img& img) { | |
139 | <a name="l00118"></a>00118 <span class="keywordflow">if</span> (dimensions() == img.dimensions()) | |
140 | <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); | |
141 | <a name="l00120"></a>00120 <span class="keywordflow">else</span> { | |
142 | <a name="l00121"></a>00121 image tmp(img); | |
143 | <a name="l00122"></a>00122 swap(tmp); | |
144 | <a name="l00123"></a>00123 } | |
145 | <a name="l00124"></a>00124 <span class="keywordflow">return</span> *<span class="keyword">this</span>; | |
146 | <a name="l00125"></a>00125 } | |
147 | <a name="l00126"></a>00126 | |
148 | <a name="l00127"></a>00127 ~image() { | |
149 | <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); | |
150 | <a name="l00129"></a>00129 deallocate(_view.dimensions()); | |
151 | <a name="l00130"></a>00130 } | |
152 | <a name="l00131"></a>00131 | |
153 | <a name="l00132"></a>00132 Alloc& allocator() { <span class="keywordflow">return</span> _alloc; } | |
154 | <a name="l00133"></a>00133 Alloc <span class="keyword">const</span>& allocator()<span class="keyword"> const </span>{ <span class="keywordflow">return</span> _alloc; } | |
155 | <a name="l00134"></a>00134 | |
156 | <a name="l00135"></a>00135 <span class="keywordtype">void</span> swap(image& img) { <span class="comment">// required by MutableContainerConcept</span> | |
157 | <a name="l00136"></a>00136 <span class="keyword">using</span> std::swap; | |
158 | <a name="l00137"></a>00137 swap(_align_in_bytes, img.<a class="code" href="g_i_l_0038.html#7934d8e50af85934aa82c1c138803c94">_align_in_bytes</a>); | |
159 | <a name="l00138"></a>00138 swap(_memory, img.<a class="code" href="g_i_l_0038.html#4dac70d11e580dd17433c7cc64942596">_memory</a>); | |
160 | <a name="l00139"></a>00139 swap(_view, img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>); | |
161 | <a name="l00140"></a>00140 swap(_alloc, img.<a class="code" href="g_i_l_0038.html#20191ef8d73669d6e4df5667f5faf362">_alloc</a>); | |
162 | <a name="l00141"></a>00141 } | |
163 | <a name="l00142"></a>00142 | |
164 | <a name="l00143"></a>00143 <span class="keywordtype">void</span> recreate(<span class="keyword">const</span> point_t& dims, std::size_t alignment=0, <span class="keyword">const</span> Alloc alloc_in = Alloc()) { | |
165 | <a name="l00144"></a>00144 <span class="keywordflow">if</span> (dims!=_view.dimensions() || _align_in_bytes!=alignment || alloc_in!=_alloc) { | |
166 | <a name="l00145"></a>00145 image tmp(dims, alignment, alloc_in); | |
167 | <a name="l00146"></a>00146 swap(tmp); | |
168 | <a name="l00147"></a>00147 } | |
169 | <a name="l00148"></a>00148 } | |
170 | <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()) { | |
171 | <a name="l00150"></a>00150 recreate(point_t(width,height),alignment,alloc_in); | |
172 | <a name="l00151"></a>00151 } | |
173 | <a name="l00152"></a>00152 <span class="keywordtype">void</span> recreate(<span class="keyword">const</span> point_t& dims, | |
174 | <a name="l00153"></a>00153 <span class="keyword">const</span> Pixel& p_in, std::size_t alignment, <span class="keyword">const</span> Alloc alloc_in = Alloc()) { | |
175 | <a name="l00154"></a>00154 <span class="keywordflow">if</span> (dims!=_view.dimensions() || _align_in_bytes!=alignment || alloc_in!=_alloc) { | |
176 | <a name="l00155"></a>00155 image tmp(dims, p_in, alignment, alloc_in); | |
177 | <a name="l00156"></a>00156 swap(tmp); | |
178 | <a name="l00157"></a>00157 } | |
179 | <a name="l00158"></a>00158 } | |
180 | <a name="l00159"></a>00159 <span class="keywordtype">void</span> recreate(x_coord_t width, y_coord_t height, | |
181 | <a name="l00160"></a>00160 <span class="keyword">const</span> Pixel& p_in, std::size_t alignment, <span class="keyword">const</span> Alloc alloc_in = Alloc()) { | |
182 | <a name="l00161"></a>00161 recreate(point_t(width,height),p_in,alignment,alloc_in); | |
183 | <a name="l00162"></a>00162 } | |
184 | <a name="l00163"></a>00163 | |
185 | <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> | |
186 | <a name="l00165"></a>00165 <span class="keyword">private</span>: | |
187 | <a name="l00166"></a>00166 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* _memory; | |
188 | <a name="l00167"></a>00167 std::size_t _align_in_bytes; | |
189 | <a name="l00168"></a>00168 allocator_type _alloc; | |
190 | <a name="l00169"></a>00169 | |
191 | <a name="l00170"></a>00170 <span class="keywordtype">void</span> allocate_and_default_construct(<span class="keyword">const</span> point_t& dimensions) { | |
192 | <a name="l00171"></a>00171 <span class="keywordflow">try</span> { | |
193 | <a name="l00172"></a>00172 allocate_(dimensions,mpl::bool_<IsPlanar>()); | |
194 | <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); | |
195 | <a name="l00174"></a>00174 } <span class="keywordflow">catch</span>(...) { deallocate(dimensions); <span class="keywordflow">throw</span>; } | |
196 | <a name="l00175"></a>00175 } | |
197 | <a name="l00176"></a>00176 | |
198 | <a name="l00177"></a>00177 <span class="keywordtype">void</span> allocate_and_fill(<span class="keyword">const</span> point_t& dimensions, <span class="keyword">const</span> Pixel& p_in) { | |
199 | <a name="l00178"></a>00178 <span class="keywordflow">try</span> { | |
200 | <a name="l00179"></a>00179 allocate_(dimensions,mpl::bool_<IsPlanar>()); | |
201 | <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); | |
202 | <a name="l00181"></a>00181 } <span class="keywordflow">catch</span>(...) { deallocate(dimensions); <span class="keywordflow">throw</span>; } | |
203 | <a name="l00182"></a>00182 } | |
204 | <a name="l00183"></a>00183 | |
205 | <a name="l00184"></a>00184 <span class="keyword">template</span> <<span class="keyword">typename</span> View> | |
206 | <a name="l00185"></a>00185 <span class="keywordtype">void</span> allocate_and_copy(<span class="keyword">const</span> point_t& dimensions, <span class="keyword">const</span> View& v) { | |
207 | <a name="l00186"></a>00186 <span class="keywordflow">try</span> { | |
208 | <a name="l00187"></a>00187 allocate_(dimensions,mpl::bool_<IsPlanar>()); | |
209 | <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); | |
210 | <a name="l00189"></a>00189 } <span class="keywordflow">catch</span>(...) { deallocate(dimensions); <span class="keywordflow">throw</span>; } | |
211 | <a name="l00190"></a>00190 } | |
212 | <a name="l00191"></a>00191 | |
213 | <a name="l00192"></a>00192 <span class="keywordtype">void</span> deallocate(<span class="keyword">const</span> point_t& dimensions) { | |
214 | <a name="l00193"></a>00193 <span class="keywordflow">if</span> (_memory) _alloc.deallocate(_memory, total_allocated_size_in_bytes(dimensions)); | |
215 | <a name="l00194"></a>00194 } | |
216 | <a name="l00195"></a>00195 | |
217 | <a name="l00196"></a>00196 std::size_t total_allocated_size_in_bytes(<span class="keyword">const</span> point_t& dimensions)<span class="keyword"> const </span>{ | |
218 | <a name="l00197"></a>00197 std::size_t size_in_units = get_row_size_in_memunits(dimensions.x)*dimensions.y; | |
219 | <a name="l00198"></a>00198 <span class="keywordflow">if</span> (IsPlanar) | |
220 | <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<view_t>::value</a>; | |
221 | <a name="l00200"></a>00200 | |
222 | <a name="l00201"></a>00201 <span class="comment">// return the size rounded up to the nearest byte</span> | |
223 | <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<typename view_t::x_iterator>::value</a> - 1) / <a class="code" href="g_i_l_0406.html">byte_to_memunit<typename view_t::x_iterator>::value</a> | |
224 | <a name="l00203"></a>00203 + (_align_in_bytes>0 ? _align_in_bytes-1:0); <span class="comment">// add extra padding in case we need to align the first image pixel</span> | |
225 | <a name="l00204"></a>00204 } | |
226 | <a name="l00205"></a>00205 | |
227 | <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> | |
228 | <a name="l00207"></a>00207 std::size_t size_in_memunits = width*memunit_step(<span class="keyword">typename</span> view_t::x_iterator()); | |
229 | <a name="l00208"></a>00208 <span class="keywordflow">if</span> (_align_in_bytes>0) { | |
230 | <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<typename view_t::x_iterator>::value</a>; | |
231 | <a name="l00210"></a>00210 <span class="keywordflow">return</span> align(size_in_memunits, alignment_in_memunits); | |
232 | <a name="l00211"></a>00211 } | |
233 | <a name="l00212"></a>00212 <span class="keywordflow">return</span> size_in_memunits; | |
234 | <a name="l00213"></a>00213 } | |
235 | <a name="l00214"></a>00214 | |
236 | <a name="l00215"></a>00215 <span class="keywordtype">void</span> allocate_(<span class="keyword">const</span> point_t& dimensions, mpl::false_) { <span class="comment">// if it throws and _memory!=0 the client must deallocate _memory</span> | |
237 | <a name="l00216"></a>00216 _memory=_alloc.allocate(total_allocated_size_in_bytes(dimensions)); | |
238 | <a name="l00217"></a>00217 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* tmp=(_align_in_bytes>0) ? (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)align((std::size_t)_memory,_align_in_bytes) : _memory; | |
239 | <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))); | |
240 | <a name="l00219"></a>00219 } | |
241 | <a name="l00220"></a>00220 | |
242 | <a name="l00221"></a>00221 <span class="keywordtype">void</span> allocate_(<span class="keyword">const</span> point_t& dimensions, mpl::true_) { <span class="comment">// if it throws and _memory!=0 the client must deallocate _memory</span> | |
243 | <a name="l00222"></a>00222 std::size_t row_size=get_row_size_in_memunits(dimensions.x); | |
244 | <a name="l00223"></a>00223 std::size_t plane_size=row_size*dimensions.y; | |
245 | <a name="l00224"></a>00224 _memory=_alloc.allocate(total_allocated_size_in_bytes(dimensions)); | |
246 | <a name="l00225"></a>00225 <span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>* tmp=(_align_in_bytes>0) ? (<span class="keywordtype">unsigned</span> <span class="keywordtype">char</span>*)align((std::size_t)_memory,_align_in_bytes) : _memory; | |
247 | <a name="l00226"></a>00226 <span class="keyword">typename</span> view_t::x_iterator first; | |
248 | <a name="l00227"></a>00227 <span class="keywordflow">for</span> (<span class="keywordtype">int</span> i=0; i<num_channels<view_t>::value; ++i) { | |
249 | <a name="l00228"></a>00228 dynamic_at_c(first,i) = (<span class="keyword">typename</span> channel_type<view_t>::type*)tmp; | |
250 | <a name="l00229"></a>00229 memunit_advance(dynamic_at_c(first,i), plane_size*i); | |
251 | <a name="l00230"></a>00230 } | |
252 | <a name="l00231"></a>00231 _view=view_t(dimensions, <span class="keyword">typename</span> view_t::locator(first, row_size)); | |
253 | <a name="l00232"></a>00232 } | |
254 | <a name="l00233"></a>00233 }; | |
255 | <a name="l00234"></a>00234 | |
256 | <a name="l00235"></a>00235 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> | |
257 | <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<Pixel, IsPlanar, Alloc></a>& im1,<a class="code" href="g_i_l_0038.html" title="container interface over image view. Models ImageConcept, PixelBasedConcept">image<Pixel, IsPlanar, Alloc></a>& im2) { | |
258 | <a name="l00237"></a>00237 im1.<a class="code" href="g_i_l_0038.html#ecbe6d01103834f8178f73465a19d58c">swap</a>(im2); | |
259 | <a name="l00238"></a>00238 } | |
260 | <a name="l00239"></a>00239 | |
261 | <a name="l00240"></a>00240 <span class="keyword">template</span> <<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> | |
262 | <a name="l00241"></a>00241 <span class="keywordtype">bool</span> operator==(<span class="keyword">const</span> image<Pixel1,IsPlanar1,Alloc1>& im1,<span class="keyword">const</span> image<Pixel2,IsPlanar2,Alloc2>& im2) { | |
263 | <a name="l00242"></a>00242 <span class="keywordflow">if</span> ((<span class="keywordtype">void</span>*)(&im1)==(<span class="keywordtype">void</span>*)(&im2)) <span class="keywordflow">return</span> <span class="keyword">true</span>; | |
264 | <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>; | |
265 | <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)); | |
266 | <a name="l00245"></a>00245 } | |
267 | <a name="l00246"></a>00246 <span class="keyword">template</span> <<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> | |
268 | <a name="l00247"></a>00247 <span class="keywordtype">bool</span> operator!=(<span class="keyword">const</span> image<Pixel1,IsPlanar1,Alloc1>& im1,<span class="keyword">const</span> image<Pixel2,IsPlanar2,Alloc2>& im2) {<span class="keywordflow">return</span> !(im1==im2);} | |
269 | <a name="l00248"></a>00248 | |
270 | <a name="l00252"></a>00252 | |
271 | <a name="l00254"></a>00254 | |
272 | <a name="l00256"></a>00256 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> <span class="keyword">inline</span> | |
273 | <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<Pixel,IsPlanar,Alloc>::view_t</a>& <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<Pixel,IsPlanar,Alloc></a>& img) { <span class="keywordflow">return</span> img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>; } | |
274 | <a name="l00258"></a>00258 | |
275 | <a name="l00260"></a>00260 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> <span class="keyword">inline</span> | |
276 | <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<Pixel,IsPlanar,Alloc>::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<Pixel,IsPlanar,Alloc></a>& img) { | |
277 | <a name="l00262"></a>00262 <span class="keywordflow">return</span> <span class="keyword">static_cast<</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<Pixel,IsPlanar,Alloc>::const_view_t</a><span class="keyword">></span>(img.<a class="code" href="g_i_l_0038.html#f0b0c4c1267ee1f0ec635a4b2d00ec98">_view</a>); | |
278 | <a name="l00263"></a>00263 } | |
279 | <a name="l00265"></a>00265 | |
280 | <a name="l00267"></a>00267 <span class="comment">// PixelBasedConcept</span> | |
281 | <a name="l00269"></a>00269 <span class="comment"></span> | |
282 | <a name="l00270"></a>00270 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> | |
283 | <a name="l00271"></a>00271 <span class="keyword">struct </span>channel_type<image<Pixel,IsPlanar,Alloc> > : <span class="keyword">public</span> channel_type<Pixel> {}; | |
284 | <a name="l00272"></a>00272 | |
285 | <a name="l00273"></a>00273 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> | |
286 | <a name="l00274"></a>00274 <span class="keyword">struct </span>color_space_type<image<Pixel,IsPlanar,Alloc> > : <span class="keyword">public</span> color_space_type<Pixel> {}; | |
287 | <a name="l00275"></a>00275 | |
288 | <a name="l00276"></a>00276 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> | |
289 | <a name="l00277"></a>00277 <span class="keyword">struct </span>channel_mapping_type<image<Pixel,IsPlanar,Alloc> > : <span class="keyword">public</span> channel_mapping_type<Pixel> {}; | |
290 | <a name="l00278"></a>00278 | |
291 | <a name="l00279"></a>00279 <span class="keyword">template</span> <<span class="keyword">typename</span> Pixel, <span class="keywordtype">bool</span> IsPlanar, <span class="keyword">typename</span> Alloc> | |
292 | <a name="l00280"></a>00280 <span class="keyword">struct </span>is_planar<image<Pixel,IsPlanar,Alloc> > : <span class="keyword">public</span> mpl::bool_<IsPlanar> {}; | |
293 | <a name="l00281"></a>00281 | |
294 | <a name="l00282"></a>00282 <span class="comment">//#ifdef _MSC_VER</span> | |
295 | <a name="l00283"></a>00283 <span class="comment">//#pragma warning(pop)</span> | |
296 | <a name="l00284"></a>00284 <span class="comment">//#endif</span> | |
297 | <a name="l00285"></a>00285 | |
298 | <a name="l00286"></a>00286 } } <span class="comment">// namespace boost::gil</span> | |
299 | <a name="l00287"></a>00287 | |
300 | <a name="l00288"></a>00288 <span class="preprocessor">#endif</span> | |
301 | </pre></div></div> | |
302 | <hr size="1"><address style="text-align: right;"><small>Generated on Sat May 2 13:50:14 2009 for Generic Image Library by | |
303 | <a href="http://www.doxygen.org/index.html"> | |
304 | <img src="doxygen.png" alt="doxygen" align="middle" border="0"></a> 1.5.6 </small></address> | |
305 | </body> | |
306 | </html> |