X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Fvideo_examiner.h;h=4e5c6dc0a322c3fd57c024aa6611775178a68226;hb=cc09cc4b12d199d490217d7b60ed0af69afb90de;hp=2f713291b5a5165d42976196607ab396dd7fe50f;hpb=f1bf21a9c2581591ab80bfc997a22b93046f8c56;p=dcpomatic.git diff --git a/src/lib/video_examiner.h b/src/lib/video_examiner.h index 2f713291b..4e5c6dc0a 100644 --- a/src/lib/video_examiner.h +++ b/src/lib/video_examiner.h @@ -1,29 +1,52 @@ /* - Copyright (C) 2013 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 . */ -#include +/** @file src/lib/video_examiner.h + * @brief VideoExaminer class. + */ + #include "types.h" +#include "video_content.h" +#include +/** @class VideoExaminer + * @brief Parent for classes which examine video sources and obtain information about them. + */ class VideoExaminer { public: - virtual float video_frame_rate () const = 0; - virtual libdcp::Size video_size () const = 0; - virtual ContentVideoFrame video_length () const = 0; + virtual ~VideoExaminer () {} + + 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; + /** @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; };