X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_video.h;h=33df0942cbb5e7a1e6c6c88b3edb3c9e2feb7ec2;hb=53d0a9a844841fe10b2720543c032a687c548108;hp=32cd1a1699ac56382ee547c04830af88b0808777;hpb=3828baf56467224f5d44049bf1e7a7ed11f43a05;p=dcpomatic.git diff --git a/src/lib/dcp_video.h b/src/lib/dcp_video.h index 32cd1a169..33df0942c 100644 --- a/src/lib/dcp_video.h +++ b/src/lib/dcp_video.h @@ -18,18 +18,23 @@ */ -#include "types.h" + #include "encode_server_description.h" +#include "resolution.h" #include -#include +#include +#include + /** @file src/dcp_video_frame.h * @brief A single frame of video destined for a DCP. */ + class Log; class PlayerVideo; + /** @class DCPVideo * @brief A single frame of video destined for a DCP. * @@ -39,14 +44,17 @@ class PlayerVideo; * Objects of this class are used for the queue that we keep * of images that require encoding. */ -class DCPVideo : public boost::noncopyable +class DCPVideo { public: - DCPVideo (boost::shared_ptr, int, int, int, Resolution, boost::shared_ptr); - DCPVideo (boost::shared_ptr, cxml::ConstNodePtr, boost::shared_ptr); + DCPVideo (std::shared_ptr, int index, int dcp_fps, int bandwidth, Resolution r); + DCPVideo (std::shared_ptr, cxml::ConstNodePtr); + + DCPVideo (DCPVideo const&) = default; + DCPVideo& operator= (DCPVideo const&) = default; - dcp::Data encode_locally (dcp::NoteHandler note); - dcp::Data encode_remotely (EncodeServerDescription, int timeout = 30); + dcp::ArrayData encode_locally () const; + dcp::ArrayData encode_remotely (EncodeServerDescription, int timeout = 30) const; int index () const { return _index; @@ -54,19 +62,17 @@ public: Eyes eyes () const; - bool same (boost::shared_ptr other) const; + bool same (std::shared_ptr other) const; - static boost::shared_ptr convert_to_xyz (boost::shared_ptr frame, dcp::NoteHandler note); + static std::shared_ptr convert_to_xyz (std::shared_ptr frame, dcp::NoteHandler note); private: void add_metadata (xmlpp::Element *) const; - boost::shared_ptr _frame; + std::shared_ptr _frame; int _index; ///< frame index within the DCP's intrinsic duration int _frames_per_second; ///< Frames per second that we will use for the DCP int _j2k_bandwidth; ///< J2K bandwidth to use Resolution _resolution; ///< Resolution (2K or 4K) - - boost::shared_ptr _log; ///< log };