arduino-audio-tools
All Classes Namespaces Files Functions Variables Typedefs Enumerations Friends Modules Pages
Classes | Public Member Functions | Public Attributes | Protected Member Functions | Protected Attributes | List of all members
MultiDecoder Class Reference

Manage multiple decoders: the actual decoder is only opened when it has been selected. The relevant decoder is determined dynamically at the first write from the determined mime type. You can add your own custom mime type determination logic. More...

#include <MultiDecoder.h>

Inheritance diagram for MultiDecoder:
AudioDecoder AudioWriter AudioInfoSource AudioInfoSupport DecoderHelix

Classes

struct  DecoderInfo
 

Public Member Functions

 MultiDecoder ()=default
 Default constructor.
 
 MultiDecoder (AbstractURLStream &url)
 Provides a URLStream to look up the mime type from the http reply header.
 
void addDecoder (AudioDecoder &decoder, const char *mime)
 Adds a decoder that will be selected by it's mime type.
 
void addDecoder (AudioDecoder &decoder, const char *mime, bool(*check)(uint8_t *data, size_t len))
 
virtual void addNotifyAudioChange (AudioInfoSupport &bi)
 Adds target to be notified about audio changes.
 
virtual AudioInfo audioInfo ()
 provides the actual input AudioInfo
 
virtual AudioInfo audioInfoOut ()
 
bool begin () override
 Enables the automatic mime type determination.
 
virtual bool begin (AudioInfo info) override
 
virtual void clearNotifyAudioChange ()
 Deletes all change notify subscriptions.
 
void end () override
 closes the actual decoder
 
PrintgetOutput ()
 
bool isNotifyActive ()
 Checks if the automatic AudioInfo update is active.
 
virtual bool isResultPCM ()
 Returns true to indicate that the decoding result is PCM data.
 
virtual operator bool ()
 
virtual bool removeNotifyAudioChange (AudioInfoSupport &bi)
 Removes a target in order not to be notified about audio changes.
 
bool selectDecoder (const char *mime)
 
virtual void setAudioInfo (AudioInfo from) override
 for most decoders this is not needed
 
void setMimeSource (AbstractURLStream &url)
 Defines url stream from which we determine the mime type from the reply header.
 
void setNotifyActive (bool flag)
 Deactivate/Reactivate automatic AudioInfo updates: (default is active)
 
virtual void setOutput (AudioOutput &out_stream)
 Defines where the decoded result is written to.
 
virtual void setOutput (AudioStream &out_stream)
 Defines where the decoded result is written to.
 
virtual void setOutput (Print &out_stream) override
 Defines where the decoded result is written to.
 
size_t write (const uint8_t *data, size_t len) override
 

Public Attributes

int id
 custom id to be used by application
 

Protected Member Functions

void notifyAudioChange (AudioInfo info)
 
void writeBlocking (Print *out, uint8_t *data, size_t len)
 

Protected Attributes

struct audio_tools::MultiDecoder::DecoderInfo actual_decoder
 
Vector< DecoderInfodecoders {0}
 
AudioInfo info
 
bool is_first = true
 
bool is_notify_active = true
 
MimeDetector mime_detector
 
CodecNOP nop
 
Vector< AudioInfoSupport * > notify_vector
 
Printp_print = nullptr
 
AbstractURLStreamp_url_stream = nullptr
 

Detailed Description

Manage multiple decoders: the actual decoder is only opened when it has been selected. The relevant decoder is determined dynamically at the first write from the determined mime type. You can add your own custom mime type determination logic.

Author
Phil Schatzmann

Member Function Documentation

◆ addDecoder()

void addDecoder ( AudioDecoder decoder,
const char *  mime,
bool(*)(uint8_t *data, size_t len)  check 
)
inline

Adds a decoder that will be selected by it's mime type and defines the mime checking logic

◆ addNotifyAudioChange()

virtual void addNotifyAudioChange ( AudioInfoSupport bi)
inlinevirtualinherited

◆ audioInfo()

virtual AudioInfo audioInfo ( )
inlinevirtualinherited

◆ audioInfoOut()

virtual AudioInfo audioInfoOut ( )
inlinevirtualinherited

◆ begin() [1/2]

bool begin ( )
inlineoverridevirtual

Enables the automatic mime type determination.

Reimplemented from AudioDecoder.

◆ begin() [2/2]

virtual bool begin ( AudioInfo  info)
inlineoverridevirtualinherited

Reimplemented from AudioWriter.

◆ end()

void end ( )
inlineoverridevirtual

closes the actual decoder

Reimplemented from AudioDecoder.

◆ isResultPCM()

virtual bool isResultPCM ( )
inlinevirtualinherited

Returns true to indicate that the decoding result is PCM data.

Reimplemented in CopyDecoder, and GGWaveDecoder.

◆ operator bool()

virtual operator bool ( )
inlinevirtual

Implements AudioWriter.

◆ selectDecoder()

bool selectDecoder ( const char *  mime)
inline

selects the actual decoder by mime type - this is usually called automatically from the determined mime type

◆ setAudioInfo()

virtual void setAudioInfo ( AudioInfo  from)
inlineoverridevirtualinherited

for most decoders this is not needed

Implements AudioWriter.

Reimplemented in GGWaveDecoder, DecoderL8, OpusAudioDecoder, CodecNOP, AACDecoderHelix, and G7xxDecoder.

◆ setOutput() [1/3]

virtual void setOutput ( AudioOutput out_stream)
inlinevirtualinherited

Defines where the decoded result is written to.

Reimplemented in ADTSDecoder, MTSDecoder, MTSDecoderTSDemux, and MetaDataFilterDecoder.

◆ setOutput() [2/3]

virtual void setOutput ( AudioStream out_stream)
inlinevirtualinherited

Defines where the decoded result is written to.

Reimplemented in ADTSDecoder, MTSDecoder, MTSDecoderTSDemux, and MetaDataFilterDecoder.

◆ setOutput() [3/3]

virtual void setOutput ( Print out_stream)
inlineoverridevirtual

Defines where the decoded result is written to.

Reimplemented from AudioDecoder.

◆ write()

size_t write ( const uint8_t *  data,
size_t  len 
)
inlineoverridevirtual

Implements AudioWriter.


The documentation for this class was generated from the following file: