X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fj2k_image_proxy.h;h=ec99e71a938c19c0b39d9af4c26d4a9baccf8f78;hb=3b31d2d8a129ae6d8d267427bd6b5bc444b40b2a;hp=8fc9040d5a8eda0eccf621fbaeddcce1c1ded1f5;hpb=5bbf16e87ca09369174c9d2bb7f7fe94b6d70275;p=dcpomatic.git diff --git a/src/lib/j2k_image_proxy.h b/src/lib/j2k_image_proxy.h index 8fc9040d5..ec99e71a9 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-2017 Carl Hetherington This file is part of DCP-o-matic. @@ -21,6 +21,7 @@ #include "image_proxy.h" #include #include +#include namespace dcp { class MonoPictureFrame; @@ -31,12 +32,25 @@ class J2KImageProxy : public ImageProxy { public: J2KImageProxy (boost::filesystem::path path, dcp::Size, AVPixelFormat pixel_format); - J2KImageProxy (boost::shared_ptr frame, dcp::Size, AVPixelFormat pixel_format); - J2KImageProxy (boost::shared_ptr frame, dcp::Size, dcp::Eye, AVPixelFormat pixel_format); + + J2KImageProxy ( + boost::shared_ptr frame, + dcp::Size, + AVPixelFormat pixel_format, + boost::optional forced_reduction + ); + + J2KImageProxy ( + boost::shared_ptr frame, + dcp::Size, + dcp::Eye, + AVPixelFormat pixel_format, + boost::optional forced_reduction + ); + J2KImageProxy (boost::shared_ptr xml, boost::shared_ptr socket); - boost::shared_ptr image ( - boost::optional note = boost::optional (), + Result image ( boost::optional size = boost::optional () ) const; @@ -44,9 +58,7 @@ public: void send_binary (boost::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; - AVPixelFormat pixel_format () const { - return _pixel_format; - } + int prepare (boost::optional = boost::optional()) const; dcp::Data j2k () const { return _data; @@ -56,6 +68,8 @@ public: return _size; } + size_t memory_used () const; + private: friend struct client_server_test_j2k; @@ -65,7 +79,10 @@ private: dcp::Data _data; dcp::Size _size; boost::optional _eye; - mutable boost::shared_ptr _j2k; - mutable boost::optional _j2k_target_size; + mutable boost::shared_ptr _image; + mutable boost::optional _target_size; + mutable boost::optional _reduce; AVPixelFormat _pixel_format; + mutable boost::mutex _mutex; + boost::optional _forced_reduction; };