X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fimage.h;h=0237b3d1b8fc259c793a695694e9c8a3a75ebdee;hb=653259931770513238720cf3031fcaea6d02aead;hp=2ef7d07974d21432979e82cea840a35ab5a9967b;hpb=fb82d2523dd0663478450016784f4ef40f1f1590;p=dcpomatic.git diff --git a/src/lib/image.h b/src/lib/image.h index 2ef7d0797..0237b3d1b 100644 --- a/src/lib/image.h +++ b/src/lib/image.h @@ -25,25 +25,34 @@ #ifndef DCPOMATIC_IMAGE_H #define DCPOMATIC_IMAGE_H + +#include "crop.h" #include "position.h" #include "position_image.h" -#include "types.h" +#include "video_range.h" extern "C" { #include } #include #include + struct AVFrame; class Socket; + class Image : public std::enable_shared_from_this { public: - Image (AVPixelFormat p, dcp::Size s, bool aligned); - explicit Image (AVFrame const *); + enum class Alignment { + COMPACT, + PADDED + }; + + Image (AVPixelFormat p, dcp::Size s, Alignment alignment); + explicit Image (AVFrame const *, Alignment alignment); explicit Image (Image const &); - Image (std::shared_ptr, bool); + Image (std::shared_ptr, Alignment alignment); Image& operator= (Image const &); ~Image (); @@ -53,7 +62,7 @@ public: /** @return array of sizes of the data in each line, in bytes (including any alignment padding) */ int const * stride () const; dcp::Size size () const; - bool aligned () const; + Alignment alignment () const; int planes () const; int vertical_factor (int) const; @@ -61,8 +70,8 @@ public: dcp::Size sample_size (int) const; float bytes_per_pixel (int) const; - 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 convert_pixel_format (dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, Alignment alignment, bool fast) const; + std::shared_ptr scale (dcp::Size out_size, dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, Alignment alignment, bool fast) const; std::shared_ptr crop_scale_window ( Crop crop, dcp::Size inter_size, @@ -71,7 +80,7 @@ public: VideoRange video_range, AVPixelFormat out_format, VideoRange out_video_range, - bool aligned, + Alignment alignment, bool fast ) const; @@ -80,7 +89,6 @@ public: 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 (std::shared_ptr); void write_to_socket (std::shared_ptr) const; @@ -91,11 +99,7 @@ public: size_t memory_used () const; - dcp::ArrayData as_png () const; - - void png_error (char const * message); - - static std::shared_ptr ensure_aligned (std::shared_ptr image); + static std::shared_ptr ensure_alignment (std::shared_ptr image, Alignment alignment); private: friend struct pixel_formats_test; @@ -106,16 +110,17 @@ private: 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 uint8_t** _data; ///< array of pointers to components int* _line_size; ///< array of sizes of the data in each line, in bytes (without any alignment padding bytes) int* _stride; ///< array of strides for each line, in bytes (including any alignment padding bytes) - bool _aligned; + Alignment _alignment; }; -extern PositionImage merge (std::list images); +extern PositionImage merge (std::list images, Image::Alignment alignment); extern bool operator== (Image const & a, Image const & b); #endif