X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=src%2Flib%2Faudio_decoder.h;h=ab6c4b8a931e12cfe892c8cb74d86ae7162d1a10;hb=77e4bcc1514fdeaa3838644f59439f34b064e33c;hp=3bf585f4de1f77259de867f218d66fa6fe4fe141;hpb=b1873c51b2e8265a01a8f0eced7fc3465f1677dc;p=dcpomatic.git diff --git a/src/lib/audio_decoder.h b/src/lib/audio_decoder.h index 3bf585f4d..ab6c4b8a9 100644 --- a/src/lib/audio_decoder.h +++ b/src/lib/audio_decoder.h @@ -21,38 +21,33 @@ * @brief Parent class for audio decoders. */ -#ifndef DVDOMATIC_AUDIO_DECODER_H -#define DVDOMATIC_AUDIO_DECODER_H +#ifndef DCPOMATIC_AUDIO_DECODER_H +#define DCPOMATIC_AUDIO_DECODER_H -#include "audio_source.h" -#include "stream.h" #include "decoder.h" +#include "content.h" +#include "audio_content.h" + +class AudioBuffers; /** @class AudioDecoder. * @brief Parent class for audio decoders. */ -class AudioDecoder : public AudioSource, public virtual Decoder +class AudioDecoder : public virtual Decoder { public: - AudioDecoder (boost::shared_ptr, DecodeOptions, Job *); - - virtual void set_audio_stream (boost::shared_ptr); + AudioDecoder (boost::shared_ptr, boost::shared_ptr); - /** @return Audio stream that we are using */ - boost::shared_ptr audio_stream () const { - return _audio_stream; - } + bool has_audio () const; - /** @return All available audio streams */ - std::vector > audio_streams () const { - return _audio_streams; - } + /** Emitted when some audio data is ready */ + boost::signals2::signal, AudioContent::Frame)> Audio; protected: - /** Audio stream that we are using */ - boost::shared_ptr _audio_stream; - /** All available audio streams */ - std::vector > _audio_streams; + + void audio (boost::shared_ptr, AudioContent::Frame); + boost::shared_ptr _audio_content; + AudioContent::Frame _audio_position; }; #endif