X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Ftypes.h;h=4eb3d927e5090c8af08ef0c3cdc1167e9fe88929;hb=7d93aa13507094e87bc9086986b36edd96a613b0;hp=d6136fc3e2778d08dbbba65392827e704a2c3bc3;hpb=2c4023c4f8e9ed5c09a30e28cc0bf8633b7635a3;p=dcpomatic.git diff --git a/src/lib/types.h b/src/lib/types.h index d6136fc3e..4eb3d927e 100644 --- a/src/lib/types.h +++ b/src/lib/types.h @@ -26,6 +26,25 @@ #include class Content; +class VideoContent; +class AudioContent; +class SubtitleContent; +class FFmpegContent; +class AudioBuffers; + +namespace cxml { + class Node; +} + +namespace xmlpp { + class Node; +} + +/** The version number of the protocol used to communicate + * with servers. Intended to be bumped when incompatibilities + * are introduced. + */ +#define SERVER_LINK_VERSION 2 typedef int64_t Time; #define TIME_MAX INT64_MAX @@ -33,11 +52,37 @@ typedef int64_t Time; typedef int64_t OutputAudioFrame; typedef int OutputVideoFrame; typedef std::vector > ContentList; +typedef std::vector > VideoContentList; +typedef std::vector > AudioContentList; +typedef std::vector > SubtitleContentList; +typedef std::vector > FFmpegContentList; + +template +struct TimedAudioBuffers +{ + TimedAudioBuffers () + : time (0) + {} + + TimedAudioBuffers (boost::shared_ptr a, T t) + : audio (a) + , time (t) + {} + + boost::shared_ptr audio; + T time; +}; enum VideoFrameType { VIDEO_FRAME_TYPE_2D, - VIDEO_FRAME_TYPE_3D_LEFT_RIGHT + VIDEO_FRAME_TYPE_3D_LEFT_RIGHT, + VIDEO_FRAME_TYPE_3D_TOP_BOTTOM, + VIDEO_FRAME_TYPE_3D_ALTERNATE, + /** This content is all the left frames of some 3D */ + VIDEO_FRAME_TYPE_3D_LEFT, + /** This content is all the right frames of some 3D */ + VIDEO_FRAME_TYPE_3D_RIGHT }; enum Eyes @@ -48,6 +93,15 @@ enum Eyes EYES_COUNT }; +enum Part +{ + PART_LEFT_HALF, + PART_RIGHT_HALF, + PART_TOP_HALF, + PART_BOTTOM_HALF, + PART_WHOLE +}; + /** @struct Crop * @brief A description of the crop of an image or video. */ @@ -55,6 +109,7 @@ struct Crop { Crop () : left (0), right (0), top (0), bottom (0) {} Crop (int l, int r, int t, int b) : left (l), right (r), top (t), bottom (b) {} + Crop (boost::shared_ptr); /** Number of pixels to remove from the left-hand side */ int left; @@ -64,6 +119,38 @@ struct Crop int top; /** Number of pixels to remove from the bottom */ int bottom; + + libdcp::Size apply (libdcp::Size s, int minimum = 4) const { + s.width -= left + right; + s.height -= top + bottom; + + if (s.width < minimum) { + s.width = minimum; + } + + if (s.height < minimum) { + s.height = minimum; + } + + return s; + } + + void as_xml (xmlpp::Node *) const; +}; + +struct CPLSummary +{ + CPLSummary (std::string d, std::string i, std::string a, boost::filesystem::path f) + : dcp_directory (d) + , cpl_id (i) + , cpl_annotation_text (a) + , cpl_file (f) + {} + + std::string dcp_directory; + std::string cpl_id; + std::string cpl_annotation_text; + boost::filesystem::path cpl_file; }; extern bool operator== (Crop const & a, Crop const & b);