X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fj2k_image_proxy.h;h=9666ea406784f9981780661e60ba39c7dcfb2c31;hb=b915348a8288d68e2ff114fb3dd89ad22e699969;hp=72815a0f6c57d8d3b1575c124816304e58b1d47d;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05;p=dcpomatic.git diff --git a/src/lib/j2k_image_proxy.h b/src/lib/j2k_image_proxy.h index 72815a0f6..9666ea406 100644 --- a/src/lib/j2k_image_proxy.h +++ b/src/lib/j2k_image_proxy.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2015 Carl Hetherington + Copyright (C) 2015-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,31 +18,56 @@ */ + #include "image_proxy.h" +#include #include -#include +#include + namespace dcp { class MonoPictureFrame; class StereoPictureFrame; } + class J2KImageProxy : public ImageProxy { public: - J2KImageProxy (boost::filesystem::path path, dcp::Size); - J2KImageProxy (boost::shared_ptr frame, dcp::Size); - J2KImageProxy (boost::shared_ptr frame, dcp::Size, dcp::Eye); - J2KImageProxy (boost::shared_ptr xml, boost::shared_ptr socket); - - boost::shared_ptr image (boost::optional note = boost::optional ()) const; - void add_metadata (xmlpp::Node *) const; - void send_binary (boost::shared_ptr) const; + J2KImageProxy (boost::filesystem::path path, dcp::Size, AVPixelFormat pixel_format); + + J2KImageProxy ( + std::shared_ptr frame, + dcp::Size, + AVPixelFormat pixel_format, + boost::optional forced_reduction + ); + + J2KImageProxy ( + std::shared_ptr frame, + dcp::Size, + dcp::Eye, + AVPixelFormat pixel_format, + boost::optional forced_reduction + ); + + J2KImageProxy (std::shared_ptr xml, std::shared_ptr socket); + + /* For tests */ + J2KImageProxy (dcp::ArrayData data, dcp::Size size, AVPixelFormat pixel_format); + + Result image ( + Image::Alignment alignment, + boost::optional size = boost::optional () + ) const override; + + void add_metadata (xmlpp::Node *) const override; + void write_to_socket (std::shared_ptr override) const override; /** @return true if our image is definitely the same as another, false if it is probably not */ - bool same (boost::shared_ptr) const; - AVPixelFormat pixel_format () const; + bool same (std::shared_ptr) const override; + int prepare (Image::Alignment alignment, boost::optional = boost::optional()) const override; - dcp::Data j2k () const { + std::shared_ptr j2k () const { return _data; } @@ -50,15 +75,22 @@ public: return _size; } -private: - friend struct client_server_test_j2k; + boost::optional eye () const { + return _eye; + } - /* For tests */ - J2KImageProxy (dcp::Data data, dcp::Size size); - void ensure_j2k () const; + size_t memory_used () const override; - dcp::Data _data; +private: + std::shared_ptr _data; dcp::Size _size; boost::optional _eye; - mutable boost::shared_ptr _j2k; + mutable std::shared_ptr _image; + mutable boost::optional _target_size; + mutable boost::optional _reduce; + AVPixelFormat _pixel_format; + mutable boost::mutex _mutex; + boost::optional _forced_reduction; + /** true if an error occurred while decoding the JPEG2000 data, false if not */ + mutable bool _error; };