• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 //
2 // Copyright 2007-2012 Christian Henning, Andreas Pokorny, Lubomir Bourdev
3 //
4 // Distributed under the Boost Software License, Version 1.0
5 // See accompanying file LICENSE_1_0.txt or copy at
6 // http://www.boost.org/LICENSE_1_0.txt
7 //
8 #ifndef BOOST_GIL_IO_READ_AND_CONVERT_VIEW_HPP
9 #define BOOST_GIL_IO_READ_AND_CONVERT_VIEW_HPP
10 
11 #include <boost/gil/io/base.hpp>
12 #include <boost/gil/io/conversion_policies.hpp>
13 #include <boost/gil/io/device.hpp>
14 #include <boost/gil/io/get_reader.hpp>
15 #include <boost/gil/io/path_spec.hpp>
16 #include <boost/gil/detail/mp11.hpp>
17 
18 #include <type_traits>
19 
20 namespace boost{ namespace gil {
21 
22 /// \ingroup IO
23 
24 /// \brief Reads and color-converts an image view. No memory is allocated.
25 /// \param reader    An image reader.
26 /// \param img       The image in which the data is read into.
27 /// \param settings  Specifies read settings depending on the image format.
28 /// \param cc        Color converter function object.
29 /// \throw std::ios_base::failure
30 template <typename Reader, typename View>
31 inline
read_and_convert_view(Reader & reader,View const & view,typename std::enable_if<mp11::mp_and<detail::is_reader<Reader>,is_format_tag<typename Reader::format_tag_t>>::value>::type * =nullptr)32 void read_and_convert_view(Reader& reader, View const& view,
33     typename std::enable_if
34     <
35         mp11::mp_and
36         <
37             detail::is_reader<Reader>,
38             is_format_tag<typename Reader::format_tag_t>
39         >::value
40     >::type* /*dummy*/ = nullptr)
41 {
42     reader.check_image_size(view.dimensions());
43     reader.init_view(view, reader._settings);
44     reader.apply(view);
45 }
46 
47 /// \brief Reads and color-converts an image view. No memory is allocated.
48 /// \param file      It's a device. Must satisfy is_input_device metafunction.
49 /// \param view      The image view in which the data is read into.
50 /// \param settings  Specifies read settings depending on the image format.
51 /// \param cc        Color converter function object.
52 /// \throw std::ios_base::failure
53 template <typename Device, typename View, typename ColorConverter, typename FormatTag>
54 inline
read_and_convert_view(Device & device,View const & view,image_read_settings<FormatTag> const & settings,ColorConverter const & cc,typename std::enable_if<mp11::mp_and<detail::is_read_device<FormatTag,Device>,is_format_tag<FormatTag>>::value>::type * =nullptr)55 void read_and_convert_view(
56     Device& device,
57     View const& view,
58     image_read_settings<FormatTag> const& settings,
59     ColorConverter const& cc,
60     typename std::enable_if
61     <
62         mp11::mp_and
63         <
64             detail::is_read_device<FormatTag, Device>,
65             is_format_tag<FormatTag>
66         >::value
67     >::type* /*dummy*/ = nullptr)
68 {
69     using read_and_convert_t = detail::read_and_convert<ColorConverter>;
70     using reader_t = typename get_reader<Device, FormatTag, read_and_convert_t>::type;
71 
72     reader_t reader = make_reader(device, settings, read_and_convert_t{cc});
73     read_and_convert_view(reader, view);
74 }
75 
76 /// \brief Reads and color-converts an image view. No memory is allocated.
77 /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
78 /// \param view      The image view in which the data is read into.
79 /// \param settings  Specifies read settings depending on the image format.
80 /// \param cc        Color converter function object.
81 /// \throw std::ios_base::failure
82 template <typename String, typename View, typename ColorConverter, typename FormatTag>
83 inline
read_and_convert_view(String const & file_name,View const & view,image_read_settings<FormatTag> const & settings,ColorConverter const & cc,typename std::enable_if<mp11::mp_and<is_format_tag<FormatTag>,detail::is_supported_path_spec<String>>::value>::type * =nullptr)84 void read_and_convert_view(
85     String const& file_name,
86     View const& view,
87     image_read_settings<FormatTag> const& settings,
88     ColorConverter const& cc,
89     typename std::enable_if
90     <
91         mp11::mp_and
92         <
93             is_format_tag<FormatTag>,
94             detail::is_supported_path_spec<String>
95         >::value
96     >::type* /*dummy*/ = nullptr)
97 {
98     using read_and_convert_t = detail::read_and_convert<ColorConverter>;
99     using reader_t = typename get_reader<String, FormatTag, read_and_convert_t>::type;
100 
101     reader_t reader = make_reader(file_name, settings, read_and_convert_t{cc});
102     read_and_convert_view(reader, view);
103 }
104 
105 /// \brief Reads and color-converts an image view. No memory is allocated.
106 /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
107 /// \param view      The image view in which the data is read into.
108 /// \param cc        Color converter function object.
109 /// \param tag       Defines the image format. Must satisfy is_format_tag metafunction.
110 /// \throw std::ios_base::failure
111 template <typename String, typename View, typename ColorConverter, typename FormatTag>
112 inline
read_and_convert_view(String const & file_name,View const & view,ColorConverter const & cc,FormatTag const & tag,typename std::enable_if<mp11::mp_and<is_format_tag<FormatTag>,detail::is_supported_path_spec<String>>::value>::type * =nullptr)113 void read_and_convert_view(
114     String const& file_name,
115     View const& view,
116     ColorConverter const& cc,
117     FormatTag const& tag,
118     typename std::enable_if
119     <
120         mp11::mp_and
121         <
122             is_format_tag<FormatTag>,
123             detail::is_supported_path_spec<String>
124         >::value
125     >::type* /*dummy*/ = nullptr)
126 {
127     using read_and_convert_t = detail::read_and_convert<ColorConverter>;
128     using reader_t = typename get_reader<String, FormatTag, read_and_convert_t>::type;
129 
130     reader_t reader = make_reader(file_name, tag, read_and_convert_t{cc});
131     read_and_convert_view(reader, view);
132 }
133 
134 /// \brief Reads and color-converts an image view. No memory is allocated.
135 /// \param file It's a device. Must satisfy is_input_device metafunction or is_adaptable_input_device.
136 /// \param view The image view in which the data is read into.
137 /// \param cc   Color converter function object.
138 /// \param tag  Defines the image format. Must satisfy is_format_tag metafunction.
139 /// \throw std::ios_base::failure
140 template <typename Device, typename View, typename ColorConverter, typename FormatTag>
141 inline
read_and_convert_view(Device & device,View const & view,ColorConverter const & cc,FormatTag const & tag,typename std::enable_if<mp11::mp_and<detail::is_read_device<FormatTag,Device>,is_format_tag<FormatTag>>::value>::type * =nullptr)142 void read_and_convert_view(
143     Device& device,
144     View const& view,
145     ColorConverter const& cc,
146     FormatTag const& tag,
147     typename std::enable_if
148     <
149         mp11::mp_and
150         <
151             detail::is_read_device<FormatTag, Device>,
152             is_format_tag<FormatTag>
153         >::value
154     >::type* /*dummy*/ = nullptr)
155 {
156     using read_and_convert_t = detail::read_and_convert<ColorConverter>;
157     using reader_t = typename get_reader<Device, FormatTag, read_and_convert_t>::type;
158 
159     reader_t reader = make_reader(device, tag, read_and_convert_t{cc});
160     read_and_convert_view(reader, view);
161 }
162 
163 /// \brief Reads and color-converts an image view. No memory is allocated.
164 /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
165 /// \param view      The image view in which the data is read into.
166 /// \param settings  Specifies read settings depending on the image format.
167 /// \throw std::ios_base::failure
168 template <typename String, typename View, typename FormatTag>
169 inline
read_and_convert_view(String const & file_name,View const & view,image_read_settings<FormatTag> const & settings,typename std::enable_if<mp11::mp_and<is_format_tag<FormatTag>,detail::is_supported_path_spec<String>>::value>::type * =nullptr)170 void read_and_convert_view(
171     String const& file_name,
172     View const& view,
173     image_read_settings<FormatTag> const& settings,
174     typename std::enable_if
175     <
176         mp11::mp_and
177         <
178             is_format_tag<FormatTag>,
179             detail::is_supported_path_spec<String>
180         >::value
181     >::type* /*dummy*/ = nullptr)
182 {
183     using read_and_convert_t = detail::read_and_convert<default_color_converter>;
184     using reader_t = typename get_reader<String, FormatTag, read_and_convert_t>::type;
185 
186     reader_t reader = make_reader(file_name, settings, read_and_convert_t{});
187     read_and_convert_view(reader, view);
188 }
189 
190 /// \brief Reads and color-converts an image view. No memory is allocated.
191 /// \param file      It's a device. Must satisfy is_input_device metafunction or is_adaptable_input_device.
192 /// \param view      The image view in which the data is read into.
193 /// \param settings  Specifies read settings depending on the image format.
194 /// \throw std::ios_base::failure
195 template <typename Device, typename View, typename FormatTag>
196 inline
read_and_convert_view(Device & device,View const & view,image_read_settings<FormatTag> const & settings,typename std::enable_if<mp11::mp_and<detail::is_read_device<FormatTag,Device>,is_format_tag<FormatTag>>::value>::type * =nullptr)197 void read_and_convert_view(
198     Device& device,
199     View const& view,
200     image_read_settings<FormatTag> const& settings,
201     typename std::enable_if
202     <
203         mp11::mp_and
204         <
205             detail::is_read_device<FormatTag, Device>,
206             is_format_tag<FormatTag>
207         >::value
208     >::type* /*dummy*/ = nullptr)
209 {
210     using read_and_convert_t = detail::read_and_convert<default_color_converter>;
211     using reader_t = typename get_reader<Device, FormatTag, read_and_convert_t>::type;
212 
213     reader_t reader = make_reader(device, settings, read_and_convert_t{});
214     read_and_convert_view(reader, view);
215 }
216 
217 /// \brief Reads and color-converts an image view. No memory is allocated.
218 /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
219 /// \param view      The image view in which the data is read into.
220 /// \param tag       Defines the image format. Must satisfy is_format_tag metafunction.
221 /// \throw std::ios_base::failure
222 template <typename String, typename View, typename FormatTag>
223 inline
read_and_convert_view(String const & file_name,View const & view,FormatTag const & tag,typename std::enable_if<mp11::mp_and<is_format_tag<FormatTag>,detail::is_supported_path_spec<String>>::value>::type * =nullptr)224 void read_and_convert_view(
225     String const& file_name,
226     View const& view,
227     FormatTag const& tag,
228     typename std::enable_if
229     <
230         mp11::mp_and
231         <
232             is_format_tag<FormatTag>,
233             detail::is_supported_path_spec<String>
234         >::value
235     >::type* /*dummy*/ = nullptr)
236 {
237     using read_and_convert_t = detail::read_and_convert<default_color_converter>;
238     using reader_t = typename get_reader<String, FormatTag, read_and_convert_t>::type;
239 
240     reader_t reader = make_reader(file_name, tag, read_and_convert_t{});
241     read_and_convert_view(reader, view);
242 }
243 
244 /// \brief Reads and color-converts an image view. No memory is allocated.
245 /// \param file It's a device. Must satisfy is_input_device metafunction or is_adaptable_input_device.
246 /// \param view The image view in which the data is read into.
247 /// \param tag  Defines the image format. Must satisfy is_format_tag metafunction.
248 /// \throw std::ios_base::failure
249 template <typename Device, typename View, typename FormatTag>
250 inline
read_and_convert_view(Device & device,View const & view,FormatTag const & tag,typename std::enable_if<mp11::mp_and<detail::is_read_device<FormatTag,Device>,is_format_tag<FormatTag>>::value>::type * =nullptr)251 void read_and_convert_view(
252     Device& device,
253     View const& view,
254     FormatTag const& tag,
255     typename std::enable_if
256     <
257         mp11::mp_and
258         <
259             detail::is_read_device<FormatTag, Device>,
260             is_format_tag<FormatTag>
261         >::value
262     >::type* /*dummy*/ = nullptr)
263 {
264     using read_and_convert_t = detail::read_and_convert<default_color_converter>;
265     using reader_t = typename get_reader<Device, FormatTag, read_and_convert_t>::type;
266 
267     reader_t reader = make_reader(device, tag, read_and_convert_t{});
268     read_and_convert_view(reader, view);
269 }
270 
271 }} // namespace boost::gill
272 
273 #endif
274