X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2Flib%2Faudio_content.h;h=adb5c9556151e0aa02d876374042e8b6cd3f2b8b;hb=8336cba4e6a8c594680696d2337ddc800d84c267;hp=051fc8db8941f137fdd54d90f457dd709204aa42;hpb=254b3044d72de6b033d7c584f5abd2b9aa70aad5;p=dcpomatic.git diff --git a/src/lib/audio_content.h b/src/lib/audio_content.h index 051fc8db8..adb5c9556 100644 --- a/src/lib/audio_content.h +++ b/src/lib/audio_content.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2013-2016 Carl Hetherington + Copyright (C) 2013-2021 Carl Hetherington This file is part of DCP-o-matic. @@ -18,16 +18,21 @@ */ + /** @file src/lib/audio_content.h * @brief AudioContent and AudioContentProperty classes. */ + #ifndef DCPOMATIC_AUDIO_CONTENT_H #define DCPOMATIC_AUDIO_CONTENT_H + #include "content_part.h" #include "audio_stream.h" #include "audio_mapping.h" +#include + /** @class AudioContentProperty * @brief Names for properties of AudioContent. @@ -38,26 +43,29 @@ public: static int const STREAMS; static int const GAIN; static int const DELAY; + static int const LANGUAGE; }; + class AudioContent : public ContentPart { public: explicit AudioContent (Content* parent); - AudioContent (Content* parent, std::vector >); + AudioContent (Content* parent, std::vector>); + AudioContent (Content* parent, cxml::ConstNodePtr); void as_xml (xmlpp::Node *) const; std::string technical_summary () const; - void take_settings_from (boost::shared_ptr c); + void take_settings_from (std::shared_ptr c); AudioMapping mapping () const; void set_mapping (AudioMapping); - int resampled_frame_rate (boost::shared_ptr film) const; - bool has_rate_above_48k () const; - std::vector channel_names () const; + int resampled_frame_rate (std::shared_ptr film) const; + std::vector channel_names () const; void set_gain (double); void set_delay (int); + void set_language (boost::optional langauge); double gain () const { boost::mutex::scoped_lock lm (_mutex); @@ -69,7 +77,12 @@ public: return _delay; } - std::string processing_description (boost::shared_ptr film) const; + boost::optional language () const { + boost::mutex::scoped_lock lm (_mutex); + return _language; + } + + std::string processing_description (std::shared_ptr film) const; std::vector streams () const { boost::mutex::scoped_lock lm (_mutex); @@ -81,22 +94,21 @@ public: void set_streams (std::vector streams); AudioStreamPtr stream () const; - void add_properties (boost::shared_ptr film, std::list &) const; + void add_properties (std::shared_ptr film, std::list &) const; - void modify_position (boost::shared_ptr film, DCPTime& pos) const; - void modify_trim_start (ContentTime& pos) const; + void modify_position (std::shared_ptr film, dcpomatic::DCPTime& pos) const; + void modify_trim_start (dcpomatic::ContentTime& pos) const; - static boost::shared_ptr from_xml (Content* parent, cxml::ConstNodePtr, int version); + static std::shared_ptr from_xml (Content* parent, cxml::ConstNodePtr, int version); private: - AudioContent (Content* parent, cxml::ConstNodePtr); - /** Gain to apply to audio in dB */ - double _gain; + double _gain = 0; /** Delay to apply to audio (positive moves audio later) in milliseconds */ - int _delay; + int _delay = 0; std::vector _streams; + boost::optional _language; }; #endif