X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_content.h;h=79dba9fdaf340716c0ca8745ae5890c8ce2b6c32;hb=0a93237cb5e4642d3b698ff9b7d0cfae5401478c;hp=1ceb01f780edd20cb91fc4849527e9d27df64d5a;hpb=39bc73fe192f932ed6695eb87b19de446e8b4f55;p=dcpomatic.git diff --git a/src/lib/audio_content.h b/src/lib/audio_content.h index 1ceb01f78..79dba9fda 100644 --- a/src/lib/audio_content.h +++ b/src/lib/audio_content.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2014 Carl Hetherington + Copyright (C) 2013-2015 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 @@ -25,21 +25,22 @@ #define DCPOMATIC_AUDIO_CONTENT_H #include "content.h" +#include "audio_stream.h" #include "audio_mapping.h" namespace cxml { class Node; } +/** @class AudioContentProperty + * @brief Names for properties of AudioContent. + */ class AudioContentProperty { public: - static int const AUDIO_CHANNELS; - static int const AUDIO_LENGTH; - static int const AUDIO_FRAME_RATE; + static int const AUDIO_STREAMS; static int const AUDIO_GAIN; static int const AUDIO_DELAY; - static int const AUDIO_MAPPING; }; /** @class AudioContent @@ -48,8 +49,7 @@ public: 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, cxml::ConstNodePtr); @@ -58,24 +58,20 @@ public: 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; - /** @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); - virtual boost::filesystem::path audio_analysis_path () const; + virtual std::vector audio_streams () const = 0; + AudioMapping audio_mapping () const; + void set_audio_mapping (AudioMapping); + boost::filesystem::path audio_analysis_path () const; int resampled_audio_frame_rate () const; + bool has_rate_above_48k () const; boost::signals2::connection analyse_audio (boost::function); - void set_audio_gain (float); + void set_audio_gain (double); void set_audio_delay (int); - float audio_gain () const { + double audio_gain () const { boost::mutex::scoped_lock lm (_mutex); return _audio_gain; } @@ -85,9 +81,11 @@ public: return _audio_delay; } + std::string processing_description () const; + 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; };