X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fimage.h;h=2d267f861e72a64cd337036bfe815943350a077a;hb=3b932abd0c7634483911e1d5361e12b2d094ae6f;hp=3220a23b4adba6b42632edc4df3355898516d180;hpb=1629bd7df2150156109afbc7a16677cb29e82adf;p=dcpomatic.git diff --git a/src/lib/image.h b/src/lib/image.h index 3220a23b4..2d267f861 100644 --- a/src/lib/image.h +++ b/src/lib/image.h @@ -24,20 +24,19 @@ #ifndef DCPOMATIC_IMAGE_H #define DCPOMATIC_IMAGE_H -#include -#include -#include +#include "position.h" +#include "position_image.h" +#include "types.h" extern "C" { -#include -#include +#include } -#include -#include "util.h" -#include "position.h" +#include +#include -class Scaler; +struct AVFrame; +class Socket; -class Image : public dcp::Image +class Image { public: Image (AVPixelFormat, dcp::Size, bool); @@ -46,43 +45,44 @@ public: Image (boost::shared_ptr, bool); Image& operator= (Image const &); ~Image (); - - uint8_t ** data () const; - int * line_size () const; - int * stride () const; + + uint8_t * const * data () const; + int const * line_size () const; + int const * stride () const; dcp::Size size () const; bool aligned () const; + int planes () const; int components () const; int line_factor (int) const; - int lines (int) const; + dcp::Size sample_size (int) const; - boost::shared_ptr scale (dcp::Size, Scaler const *, AVPixelFormat, bool aligned) const; - boost::shared_ptr post_process (std::string, bool aligned) const; - boost::shared_ptr crop (Crop c, bool aligned) const; + boost::shared_ptr scale (dcp::Size, dcp::YUVToRGB yuv_to_rgb, AVPixelFormat, bool aligned) const; + boost::shared_ptr crop_scale_window (Crop c, dcp::Size, dcp::Size, dcp::YUVToRGB yuv_to_rgb, AVPixelFormat, bool aligned) const; - boost::shared_ptr crop_scale_window (Crop c, dcp::Size, dcp::Size, Scaler const *, AVPixelFormat, bool aligned) const; - void make_black (); + void make_transparent (); void alpha_blend (boost::shared_ptr image, Position pos); void copy (boost::shared_ptr image, Position pos); + void fade (float); void read_from_socket (boost::shared_ptr); void write_to_socket (boost::shared_ptr) const; - + AVPixelFormat pixel_format () const { return _pixel_format; } private: - friend class pixel_formats_test; - + friend struct pixel_formats_test; + void allocate (); void swap (Image &); float bytes_per_pixel (int) const; void yuv_16_black (uint16_t, bool); static uint16_t swap_16 (uint16_t); - + + 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 pixels (without any alignment padding bytes) @@ -90,4 +90,7 @@ private: bool _aligned; }; +extern PositionImage merge (std::list images); +extern bool operator== (Image const & a, Image const & b); + #endif