X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fvideo_examiner.h;h=4e5c6dc0a322c3fd57c024aa6611775178a68226;hp=87e9a04288a20fb13018391ad4c124a58b757e05;hb=8f12e84009d7c2685bb2eeb32665876463d4e6e5;hpb=04533b9cf34ce8089113015715083ee9c5b2b001 diff --git a/src/lib/video_examiner.h b/src/lib/video_examiner.h index 87e9a0428..4e5c6dc0a 100644 --- a/src/lib/video_examiner.h +++ b/src/lib/video_examiner.h @@ -1,19 +1,20 @@ /* - Copyright (C) 2013-2014 Carl Hetherington + Copyright (C) 2013-2016 Carl Hetherington - This program is free software; you can redistribute it and/or modify + This file is part of DCP-o-matic. + + DCP-o-matic is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - This program is distributed in the hope that it will be useful, + DCP-o-matic is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License - along with this program; if not, write to the Free Software - Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. + along with DCP-o-matic. If not, see . */ @@ -21,9 +22,9 @@ * @brief VideoExaminer class. */ -#include #include "types.h" #include "video_content.h" +#include /** @class VideoExaminer * @brief Parent for classes which examine video sources and obtain information about them. @@ -32,7 +33,20 @@ class VideoExaminer { public: virtual ~VideoExaminer () {} - virtual float video_frame_rate () const = 0; + + virtual bool has_video () const = 0; + + /** @return video frame rate (if known); must not be called if has_video() == false */ + virtual boost::optional video_frame_rate () const = 0; + /** @return video size; must not be called if has_video() == false */ virtual dcp::Size video_size () const = 0; - virtual ContentTime video_length () const = 0; + /** @return video length in frames; must not be called if has_video() == false */ + virtual Frame video_length () const = 0; + /** @return video sample aspect ratio (if known); must not be called if has_video() == false */ + virtual boost::optional sample_aspect_ratio () const { + return boost::optional (); + } + /** @return true if this video is in YUV; must not be called if has_video() == false */ + virtual bool yuv () const = 0; + virtual VideoRange range () const = 0; };