Decoder for the Opus audio format. Each Opus frame must be provided with one write() call. Therefore, Opus is usually encapsulated in a container format (e.g., Ogg) that splits the stream into frames.
More...
#include <CodecOpus.h>
|
int | id |
| custom id to be used by application
|
|
|
bool | isValidRate (int rate) |
|
void | notifyAudioChange (AudioInfo info) |
|
void | writeBlocking (Print *out, uint8_t *data, size_t len) |
|
|
bool | active = false |
|
OpusSettings | cfg |
|
OpusDecoder * | dec = nullptr |
|
Vector< uint8_t > | decbuf {0} |
|
AudioInfo | info |
|
bool | is_notify_active = true |
|
Vector< AudioInfoSupport * > | notify_vector |
|
Vector< uint8_t > | outbuf {0} |
|
Print * | p_print = nullptr |
|
bool | release_on_end = false |
|
const uint32_t | valid_rates [5] = {8000, 12000, 16000, 24000, 48000} |
|
Decoder for the Opus audio format. Each Opus frame must be provided with one write() call. Therefore, Opus is usually encapsulated in a container format (e.g., Ogg) that splits the stream into frames.
Depends on https://github.com/pschatzmann/arduino-libopus.git
- Author
- Phil Schatzmann
- Copyright
- GPLv3
◆ OpusAudioDecoder()
Construct a new OpusDecoder object.
- Parameters
-
out_stream | Output Stream to which we write the decoded result |
◆ addNotifyAudioChange()
Adds target to be notified about audio changes.
Reimplemented in CodecNOP, EncodedAudioOutput, EncodedAudioStream, AACDecoderFDK, DecoderBasic, CodecChain, MP3DecoderHelix, MP3DecoderMAD, OggContainerDecoder, RTSPClient< TcpClient, UdpSocket >, Pipeline, and Pipeline::ModifyingStreamAdapter.
◆ audioInfo()
◆ audioInfoOut()
provides the actual output AudioInfo: this is usually the same as audioInfo() unless we use a transforming stream
Reimplemented in PureDataStream, PWMAudioOutput, ChannelFormatConverterStreamT< T >, ChannelFormatConverterStream, NumberFormatConverterStreamT< TFrom, TTo >, NumberFormatConverterStream, FormatConverterStream, Pipeline, ResampleStream, and ResampleStreamT< TInterpolator >.
◆ begin() [1/2]
◆ begin() [2/2]
|
inlineoverridevirtualinherited |
◆ clearNotifyAudioChange()
virtual void clearNotifyAudioChange |
( |
| ) |
|
|
inlinevirtualinherited |
◆ end()
◆ isResultPCM()
virtual bool isResultPCM |
( |
| ) |
|
|
inlinevirtualinherited |
◆ operator bool()
◆ removeNotifyAudioChange()
◆ setAudioInfo()
for most decoders this is not needed
Reimplemented from AudioDecoder.
◆ setCodecConfig()
virtual bool setCodecConfig |
( |
const uint8_t * |
data, |
|
|
size_t |
len |
|
) |
| |
|
inlinevirtualinherited |
Some decoders need e.g. a magic cookie to provide the relevant info for decoding.
Reimplemented in DecoderALAC, and MultiDecoder.
◆ setOutput() [1/3]
◆ setOutput() [2/3]
◆ setOutput() [3/3]
void setOutput |
( |
Print & |
out_stream | ) |
|
|
inlineoverridevirtual |
◆ setReleaseOnEnd()
void setReleaseOnEnd |
( |
bool |
flag | ) |
|
|
inline |
Defines if the resources should be released when the stream is closed (default: false)
◆ write()
size_t write |
( |
const uint8_t * |
data, |
|
|
size_t |
len |
|
) |
| |
|
inlineoverridevirtual |
The documentation for this class was generated from the following file: