X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fimage.h;h=f71a47b0c7c9a1c3cf9f4e66105f817689a29fb9;hb=c6871fe8617b3de03662b7630355059393bf8043;hp=fabcb5675f676bafa0cfcb5b7d83062297e11de3;hpb=a978f3ac575f1af017002c861480d5203cf0a34e;p=dcpomatic.git diff --git a/src/lib/image.h b/src/lib/image.h index fabcb5675..f71a47b0c 100644 --- a/src/lib/image.h +++ b/src/lib/image.h @@ -1,19 +1,20 @@ /* - Copyright (C) 2012 Carl Hetherington + Copyright (C) 2012-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ @@ -27,23 +28,21 @@ #include "position.h" #include "position_image.h" #include "types.h" -#include extern "C" { -#include -#include +#include } +#include #include -#include -#include +struct AVFrame; class Socket; class Image { public: - Image (AVPixelFormat, dcp::Size, bool); - Image (AVFrame *); - Image (Image const &); + Image (AVPixelFormat p, dcp::Size s, bool aligned, int extra_pixels = 0); + explicit Image (AVFrame *); + explicit Image (Image const &); Image (boost::shared_ptr, bool); Image& operator= (Image const &); ~Image (); @@ -55,12 +54,16 @@ public: bool aligned () const; int planes () const; - int components () const; - int line_factor (int) const; + int vertical_factor (int) const; + int horizontal_factor (int) const; dcp::Size sample_size (int) const; + float bytes_per_pixel (int) 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 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 ( + Crop crop, dcp::Size inter_size, dcp::Size out_size, dcp::YUVToRGB yuv_to_rgb, AVPixelFormat out_format, bool aligned, bool fast + ) const; void make_black (); void make_transparent (); @@ -75,21 +78,25 @@ public: return _pixel_format; } + size_t memory_used () const; + + static boost::shared_ptr ensure_aligned (boost::shared_ptr image); + private: 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) - int* _stride; ///< array of strides for each line (including any alignment padding bytes) + 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; + int _extra_pixels; }; extern PositionImage merge (std::list images);