X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fdcp_video.h;h=33df0942cbb5e7a1e6c6c88b3edb3c9e2feb7ec2;hb=a60668a37f05a125954ac5e03db0530995ac5769;hp=81ddc4470c9e748f81289262a3da382eae11ee68;hpb=ad1ef39eda58b3a919ea3b7084401a0439409ec6;p=dcpomatic.git diff --git a/src/lib/dcp_video.h b/src/lib/dcp_video.h index 81ddc4470..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); - DCPVideo (boost::shared_ptr, cxml::ConstNodePtr); + 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::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,15 +62,15 @@ 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