X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fimage.h;h=3cba8f7e501ae0478f0cfcb247ebce2877eaa260;hb=9bfa07293928c371d59db2091ba2b7e715ce5994;hp=7dd633f617c8a7166c4e2baa6d4119e62fe1cc20;hpb=b057363e69b77119137c0c8b07402828096e03aa;p=dcpomatic.git diff --git a/src/lib/image.h b/src/lib/image.h index 7dd633f61..3cba8f7e5 100644 --- a/src/lib/image.h +++ b/src/lib/image.h @@ -33,19 +33,17 @@ extern "C" { } #include #include -#include -#include struct AVFrame; class Socket; -class Image : public boost::enable_shared_from_this +class Image : public std::enable_shared_from_this { public: Image (AVPixelFormat p, dcp::Size s, bool aligned); - explicit Image (AVFrame *); + explicit Image (AVFrame const *, bool aligned); explicit Image (Image const &); - Image (boost::shared_ptr, bool); + Image (std::shared_ptr, bool); Image& operator= (Image const &); ~Image (); @@ -63,9 +61,9 @@ public: dcp::Size sample_size (int) const; float bytes_per_pixel (int) const; - boost::shared_ptr convert_pixel_format (dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, bool aligned, bool fast) const; - boost::shared_ptr scale (dcp::Size out_size, dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, bool aligned, bool fast) const; - boost::shared_ptr crop_scale_window ( + std::shared_ptr convert_pixel_format (dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, bool aligned, bool fast) const; + std::shared_ptr scale (dcp::Size out_size, dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, bool aligned, bool fast) const; + std::shared_ptr crop_scale_window ( Crop crop, dcp::Size inter_size, dcp::Size out_size, @@ -79,13 +77,12 @@ public: void make_black (); void make_transparent (); - void alpha_blend (boost::shared_ptr image, Position pos); - void copy (boost::shared_ptr image, Position pos); + void alpha_blend (std::shared_ptr image, Position pos); + void copy (std::shared_ptr image, Position pos); void fade (float); - void video_range_to_full_range (); - void read_from_socket (boost::shared_ptr); - void write_to_socket (boost::shared_ptr) const; + void read_from_socket (std::shared_ptr); + void write_to_socket (std::shared_ptr) const; AVPixelFormat pixel_format () const { return _pixel_format; @@ -97,16 +94,18 @@ public: void png_error (char const * message); - static boost::shared_ptr ensure_aligned (boost::shared_ptr image); + static std::shared_ptr ensure_aligned (std::shared_ptr image, bool aligned); private: friend struct pixel_formats_test; + friend struct make_part_black_test; void allocate (); void swap (Image &); void make_part_black (int x, int w); void yuv_16_black (uint16_t, bool); static uint16_t swap_16 (uint16_t); + void video_range_to_full_range (); dcp::Size _size; AVPixelFormat _pixel_format; ///< FFmpeg's way of describing the pixel format of this Image @@ -116,7 +115,7 @@ private: bool _aligned; }; -extern PositionImage merge (std::list images); +extern PositionImage merge (std::list images, bool aligned); extern bool operator== (Image const & a, Image const & b); #endif