X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_content.h;h=540839d695241be94e769bb6e42218b4128e3d50;hb=d2137ac5db409e686b4d9b3fa567935a5e416d41;hp=0b2ee2e461fe6b001d98509b6481efb61a214657;hpb=e8c1880a2b9a40eb11ee259feee3edd799139a43;p=dcpomatic.git diff --git a/src/lib/audio_content.h b/src/lib/audio_content.h index 0b2ee2e46..540839d69 100644 --- a/src/lib/audio_content.h +++ b/src/lib/audio_content.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013 Carl Hetherington + Copyright (C) 2013-2014 Carl Hetherington This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,6 +17,10 @@ */ +/** @file src/lib/audio_content.h + * @brief AudioContent and AudioContentProperty classes. + */ + #ifndef DCPOMATIC_AUDIO_CONTENT_H #define DCPOMATIC_AUDIO_CONTENT_H @@ -27,6 +31,8 @@ namespace cxml { class Node; } +class AudioProcessor; + class AudioContentProperty { public: @@ -36,35 +42,46 @@ public: static int const AUDIO_GAIN; static int const AUDIO_DELAY; static int const AUDIO_MAPPING; + static int const AUDIO_PROCESSOR; }; +/** @class AudioContent + * @brief Parent class for content which may contain audio data. + */ class AudioContent : public virtual Content { public: typedef int64_t Frame; + AudioContent (boost::shared_ptr); AudioContent (boost::shared_ptr, DCPTime); AudioContent (boost::shared_ptr, boost::filesystem::path); - AudioContent (boost::shared_ptr, boost::shared_ptr); + AudioContent (boost::shared_ptr, cxml::ConstNodePtr); AudioContent (boost::shared_ptr, std::vector >); void as_xml (xmlpp::Node *) const; std::string technical_summary () const; + /** @return number of audio channels in the content */ virtual int audio_channels () const = 0; - virtual AudioFrame audio_length () const = 0; - virtual int content_audio_frame_rate () const = 0; - virtual int output_audio_frame_rate () const = 0; + /** @return the length of the audio in the content */ + virtual ContentTime audio_length () const = 0; + /** @return the frame rate of the content */ + virtual int audio_frame_rate () const = 0; virtual AudioMapping audio_mapping () const = 0; - virtual void set_audio_mapping (AudioMapping) = 0; + virtual void set_audio_mapping (AudioMapping); + virtual boost::filesystem::path audio_analysis_path () const; + + int resampled_audio_frame_rate () const; + int processed_audio_channels () const; boost::signals2::connection analyse_audio (boost::function); - boost::filesystem::path audio_analysis_path () const; - void set_audio_gain (float); + void set_audio_gain (double); void set_audio_delay (int); + void set_audio_processor (AudioProcessor const *); - float audio_gain () const { + double audio_gain () const { boost::mutex::scoped_lock lm (_mutex); return _audio_gain; } @@ -74,13 +91,17 @@ public: return _audio_delay; } - Frame time_to_content_audio_frames (DCPTime, DCPTime) const; + AudioProcessor const * audio_processor () const { + boost::mutex::scoped_lock lm (_mutex); + return _audio_processor; + } private: /** Gain to apply to audio in dB */ - float _audio_gain; + double _audio_gain; /** Delay to apply to audio (positive moves audio later) in milliseconds */ int _audio_delay; + AudioProcessor const * _audio_processor; }; #endif