X-Git-Url: https://main.carlh.net/gitweb/?p=dcpomatic.git;a=blobdiff_plain;f=src%2Flib%2Fvideo_examiner.h;h=86dd9345a5e75b7e5dd0f511fdcaeeb7f0fd62be;hp=87e9a04288a20fb13018391ad4c124a58b757e05;hb=HEAD;hpb=d2137ac5db409e686b4d9b3fa567935a5e416d41 diff --git a/src/lib/video_examiner.h b/src/lib/video_examiner.h index 87e9a0428..b670dafc5 100644 --- a/src/lib/video_examiner.h +++ b/src/lib/video_examiner.h @@ -1,29 +1,33 @@ /* - Copyright (C) 2013-2014 Carl Hetherington + Copyright (C) 2013-2021 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 . */ + /** @file src/lib/video_examiner.h * @brief VideoExaminer class. */ -#include -#include "types.h" + +#include "pixel_quanta.h" #include "video_content.h" +#include + /** @class VideoExaminer * @brief Parent for classes which examine video sources and obtain information about them. @@ -32,7 +36,21 @@ class VideoExaminer { public: virtual ~VideoExaminer () {} - virtual float video_frame_rate () const = 0; - virtual dcp::Size video_size () const = 0; - virtual ContentTime video_length () 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 (if known) */ + virtual boost::optional video_size() 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 {}; + } + /** @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; + virtual PixelQuanta pixel_quanta () const = 0; };