| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367 |
- /*
- Copyright 2007-2012 Christian Henning, Andreas Pokorny, Lubomir Bourdev
- Use, modification and distribution are subject to 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).
- */
- /*************************************************************************************************/
- #ifndef BOOST_GIL_IO_READ_IMAGE_HPP
- #define BOOST_GIL_IO_READ_IMAGE_HPP
- ////////////////////////////////////////////////////////////////////////////////////////
- /// \file
- /// \brief
- /// \author Christian Henning, Andreas Pokorny, Lubomir Bourdev \n
- ///
- /// \date 2007-2012 \n
- ///
- ////////////////////////////////////////////////////////////////////////////////////////
- #include <boost/type_traits/is_base_and_derived.hpp>
- #include <boost/algorithm/string.hpp>
- #include <boost/mpl/and.hpp>
- #include <boost/utility/enable_if.hpp>
- #include <boost/gil/extension/toolbox/dynamic_images.hpp>
- #include <boost/gil/io/base.hpp>
- #include <boost/gil/io/device.hpp>
- #include <boost/gil/io/path_spec.hpp>
- #include <boost/gil/io/conversion_policies.hpp>
- namespace boost{ namespace gil {
- /// \ingroup IO
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param reader An image reader.
- /// \param img The image in which the data is read into. Must satisfy is_read_supported metafunction.
- /// \throw std::ios_base::failure
- template < typename Reader
- , typename Image
- >
- inline
- void read_image( Reader reader
- , Image& img
- , typename enable_if< mpl::and_< detail::is_reader< Reader >
- , is_format_tag< typename Reader::format_tag_t >
- , is_read_supported< typename get_pixel_type< typename Image::view_t >::type
- , typename Reader::format_tag_t
- >
- >
- >::type* /* ptr */ = 0
- )
- {
- reader.init_image( img
- , reader._settings
- );
- reader.apply( view( img ));
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file It's a device. Must satisfy is_input_device metafunction.
- /// \param img The image in which the data is read into. Must satisfy is_read_supported metafunction.
- /// \param settings Specifies read settings depending on the image format.
- /// \throw std::ios_base::failure
- template < typename Device
- , typename Image
- , typename FormatTag
- >
- inline
- void read_image( Device& file
- , Image& img
- , const image_read_settings< FormatTag >& settings
- , typename enable_if< mpl::and_< detail::is_read_device< FormatTag
- , Device
- >
- , is_format_tag< FormatTag >
- , is_read_supported< typename get_pixel_type< typename Image::view_t >::type
- , FormatTag
- >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_reader< Device
- , FormatTag
- , detail::read_and_no_convert
- >::type reader_t;
- reader_t reader = make_reader( file
- , settings
- , detail::read_and_no_convert()
- );
- read_image( reader
- , img
- );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file It's a device. Must satisfy is_input_device metafunction.
- /// \param img The image in which the data is read into. Must satisfy is_read_supported metafunction.
- /// \param tag Defines the image format. Must satisfy is_format_tag metafunction.
- /// \throw std::ios_base::failure
- template < typename Device
- , typename Image
- , typename FormatTag
- >
- inline
- void read_image( Device& file
- , Image& img
- , const FormatTag& tag
- , typename enable_if< mpl::and_< detail::is_read_device< FormatTag
- , Device
- >
- , is_format_tag< FormatTag >
- , is_read_supported< typename get_pixel_type< typename Image::view_t >::type
- , FormatTag
- >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_reader< Device
- , FormatTag
- , detail::read_and_no_convert
- >::type reader_t;
- reader_t reader = make_reader( file
- , tag
- , detail::read_and_no_convert()
- );
- read_image( reader
- , img
- );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
- /// \param img The image in which the data is read into. Must satisfy is_read_supported metafunction.
- /// \param settings Specifies read settings depending on the image format.
- /// \throw std::ios_base::failure
- template < typename String
- , typename Image
- , typename FormatTag
- >
- inline
- void read_image( const String& file_name
- , Image& img
- , const image_read_settings< FormatTag >& settings
- , typename enable_if< mpl::and_< detail::is_supported_path_spec< String >
- , is_format_tag< FormatTag >
- , is_read_supported< typename get_pixel_type< typename Image::view_t >::type
- , FormatTag
- >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_reader< String
- , FormatTag
- , detail::read_and_no_convert
- >::type reader_t;
- reader_t reader = make_reader( file_name
- , settings
- , detail::read_and_no_convert()
- );
- read_image( reader
- , img
- );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
- /// \param img The image in which the data is read into. Must satisfy is_read_supported metafunction.
- /// \param tag Defines the image format. Must satisfy is_format_tag metafunction.
- /// \throw std::ios_base::failure
- template < typename String
- , typename Image
- , typename FormatTag
- >
- inline
- void read_image( const String& file_name
- , Image& img
- , const FormatTag& tag
- , typename enable_if< mpl::and_< detail::is_supported_path_spec< String >
- , is_format_tag< FormatTag >
- , is_read_supported< typename get_pixel_type< typename Image::view_t >::type
- , FormatTag
- >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_reader< String
- , FormatTag
- , detail::read_and_no_convert
- >::type reader_t;
- reader_t reader = make_reader( file_name
- , tag
- , detail::read_and_no_convert()
- );
- read_image( reader
- , img
- );
- }
- ///
- template < typename Reader
- , typename Images
- >
- inline
- void read_image( Reader& reader
- , any_image< Images >& images
- , typename enable_if< mpl::and_< detail::is_dynamic_image_reader< Reader >
- , is_format_tag< typename Reader::format_tag_t >
- >
- >::type* /* ptr */ = 0
- )
- {
- reader.apply( images );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file It's a device. Must satisfy is_adaptable_input_device metafunction.
- /// \param images Dynamic image ( mpl::vector ). See boost::gil::dynamic_image extension.
- /// \param settings Specifies read settings depending on the image format.
- /// \throw std::ios_base::failure
- template < typename Device
- , typename Images
- , typename FormatTag
- >
- inline
- void read_image( Device& file
- , any_image< Images >& images
- , const image_read_settings< FormatTag >& settings
- , typename enable_if< mpl::and_< detail::is_read_device< FormatTag
- , Device
- >
- , is_format_tag< FormatTag >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_dynamic_image_reader< Device
- , FormatTag
- >::type reader_t;
- reader_t reader = make_dynamic_image_reader( file
- , settings
- );
- read_image( reader
- , images
- );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file It's a device. Must satisfy is_adaptable_input_device metafunction.
- /// \param images Dynamic image ( mpl::vector ). See boost::gil::dynamic_image extension.
- /// \param tag Defines the image format. Must satisfy is_format_tag metafunction.
- /// \throw std::ios_base::failure
- template < typename Device
- , typename Images
- , typename FormatTag
- >
- inline
- void read_image( Device& file
- , any_image< Images >& images
- , const FormatTag& tag
- , typename enable_if< mpl::and_< detail::is_read_device< FormatTag
- , Device
- >
- , is_format_tag< FormatTag >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_dynamic_image_reader< Device
- , FormatTag
- >::type reader_t;
- reader_t reader = make_dynamic_image_reader( file
- , tag
- );
- read_image( reader
- , images
- );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
- /// \param images Dynamic image ( mpl::vector ). See boost::gil::dynamic_image extension.
- /// \param settings Specifies read settings depending on the image format.
- /// \throw std::ios_base::failure
- template < typename String
- , typename Images
- , typename FormatTag
- >
- inline
- void read_image( const String& file_name
- , any_image< Images >& images
- , const image_read_settings< FormatTag >& settings
- , typename enable_if< mpl::and_< detail::is_supported_path_spec< String >
- , is_format_tag< FormatTag >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_dynamic_image_reader< String
- , FormatTag
- >::type reader_t;
- reader_t reader = make_dynamic_image_reader( file_name
- , settings
- );
- read_image( reader
- , images
- );
- }
- /// \brief Reads an image without conversion. Image memory is allocated.
- /// \param file_name File name. Must satisfy is_supported_path_spec metafunction.
- /// \param images Dynamic image ( mpl::vector ). See boost::gil::dynamic_image extension.
- /// \param tag Defines the image format. Must satisfy is_format_tag metafunction.
- /// \throw std::ios_base::failure
- template < typename String
- , typename Images
- , typename FormatTag
- >
- inline
- void read_image( const String& file_name
- , any_image< Images >& images
- , const FormatTag& tag
- , typename enable_if< mpl::and_< detail::is_supported_path_spec< String >
- , is_format_tag< FormatTag >
- >
- >::type* /* ptr */ = 0
- )
- {
- typedef typename get_dynamic_image_reader< String
- , FormatTag
- >::type reader_t;
- reader_t reader = make_dynamic_image_reader( file_name, tag );
- read_image( reader
- , images
- );
- }
- } // namespace gil
- } // namespace boost
- #endif
|