X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fj2k_image_proxy.h;h=d925bef864fe9129fc59dd8246b4b305325ea55e;hb=9a97c1b4116d7fb80e8ab145c0cc738dbf14d617;hp=3eccc213da41c348a73f431f7e5ac3f992b50698;hpb=2ea3a0d0e4066a166c0700bd1d53daa7f1c50dff;p=dcpomatic.git diff --git a/src/lib/j2k_image_proxy.h b/src/lib/j2k_image_proxy.h index 3eccc213d..d925bef86 100644 --- a/src/lib/j2k_image_proxy.h +++ b/src/lib/j2k_image_proxy.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2015-2017 Carl Hetherington + Copyright (C) 2015-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,49 +18,56 @@ */ + #include "image_proxy.h" #include #include #include + namespace dcp { class MonoPictureFrame; class StereoPictureFrame; } + class J2KImageProxy : public ImageProxy { public: J2KImageProxy (boost::filesystem::path path, dcp::Size, AVPixelFormat pixel_format); J2KImageProxy ( - boost::shared_ptr frame, + std::shared_ptr frame, dcp::Size, AVPixelFormat pixel_format, boost::optional forced_reduction ); J2KImageProxy ( - boost::shared_ptr frame, + std::shared_ptr frame, dcp::Size, dcp::Eye, AVPixelFormat pixel_format, boost::optional forced_reduction ); - J2KImageProxy (boost::shared_ptr xml, boost::shared_ptr socket); + 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; void add_metadata (xmlpp::Node *) const; - void write_to_socket (boost::shared_ptr) const; + void write_to_socket (std::shared_ptr) const; /** @return true if our image is definitely the same as another, false if it is probably not */ - bool same (boost::shared_ptr) const; - int prepare (boost::optional = boost::optional()) const; + bool same (std::shared_ptr) const; + int prepare (Image::Alignment alignment, boost::optional = boost::optional()) const; - boost::shared_ptr j2k () const { + std::shared_ptr j2k () const { return _data; } @@ -68,18 +75,17 @@ public: return _size; } + boost::optional eye () const { + return _eye; + } + size_t memory_used () const; private: - friend struct client_server_test_j2k; - - /* For tests */ - J2KImageProxy (dcp::ArrayData data, dcp::Size size, AVPixelFormat pixel_format); - - boost::shared_ptr _data; + std::shared_ptr _data; dcp::Size _size; boost::optional _eye; - mutable boost::shared_ptr _image; + mutable std::shared_ptr _image; mutable boost::optional _target_size; mutable boost::optional _reduce; AVPixelFormat _pixel_format;