X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_content.h;h=2a140b3e4f772bef453dde1d0899b0237d55159d;hb=6d95d9689831a74fade32038a808f206c03d8aa2;hp=92491bf89414745648a3658b6a022fe01fd06139;hpb=ca436a8e96e02f982790d4168ac3dfe1d589451c;p=dcpomatic.git diff --git a/src/lib/audio_content.h b/src/lib/audio_content.h index 92491bf89..2a140b3e4 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 "audio_stream.h" +#include "content_part.h" +#include "named_channel.h" + /** @class AudioContentProperty * @brief Names for properties of AudioContent. @@ -38,24 +43,31 @@ public: static int const STREAMS; static int const GAIN; static int const DELAY; + static int const FADE_IN; + static int const FADE_OUT; + static int const USE_SAME_FADES_AS_VIDEO; }; + class AudioContent : public ContentPart { public: - AudioContent (Content* parent); - AudioContent (Content* parent, std::vector >); + explicit AudioContent (Content* parent); + AudioContent (Content* parent, std::vector>); + AudioContent (Content* parent, cxml::ConstNodePtr); - void as_xml (xmlpp::Node *) const; + void as_xml(xmlpp::Element*) const; std::string technical_summary () const; + void take_settings_from (std::shared_ptr c); AudioMapping mapping () const; void set_mapping (AudioMapping); - int resampled_frame_rate () 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; + /** Set gain in dB */ void set_gain (double); + /** Set delay in milliseconds (positive moves audio later) */ void set_delay (int); double gain () const { @@ -68,7 +80,14 @@ public: return _delay; } - std::string processing_description () const; + dcpomatic::ContentTime fade_in () const; + dcpomatic::ContentTime fade_out () const; + + void set_fade_in (dcpomatic::ContentTime time); + void set_fade_out (dcpomatic::ContentTime time); + void set_use_same_fades_as_video (bool s); + + std::string processing_description (std::shared_ptr film) const; std::vector streams () const { boost::mutex::scoped_lock lm (_mutex); @@ -77,21 +96,31 @@ public: void add_stream (AudioStreamPtr stream); void set_stream (AudioStreamPtr stream); - void set_streams (std::vector streams); AudioStreamPtr stream () const; - void add_properties (std::list &) const; + void add_properties (std::shared_ptr film, std::list &) const; - static boost::shared_ptr from_xml (Content* parent, cxml::ConstNodePtr, int version); + void modify_position (std::shared_ptr film, dcpomatic::DCPTime& pos) const; + void modify_trim_start(std::shared_ptr film, dcpomatic::ContentTime& pos) const; -private: + /** @param frame frame within the whole (untrimmed) content. + * @param frame_rate The frame rate of the audio (it may have been resampled). + * @return a fade coefficient for @ref length samples starting at an offset @frame within + * the content, or an empty vector if the given section has no fade. + */ + std::vector fade (AudioStreamPtr stream, Frame frame, Frame length, int frame_rate) const; - AudioContent (Content* parent, cxml::ConstNodePtr); + static std::shared_ptr from_xml (Content* parent, cxml::ConstNodePtr, int version); + +private: /** 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; + dcpomatic::ContentTime _fade_in; + dcpomatic::ContentTime _fade_out; + bool _use_same_fades_as_video = false; std::vector _streams; };