ESPHome 2026.6.0-dev
Loading...
Searching...
No Matches
esphome::mixer_speaker::MixerSpeaker Class Reference

#include <mixer_speaker.h>

Inheritance diagram for esphome::mixer_speaker::MixerSpeaker:
esphome::Component

Public Member Functions

void dump_config () override
 
void setup () override
 
void loop () override
 
void init_source_speakers (size_t count)
 
void add_source_speaker (SourceSpeaker *source_speaker)
 
esp_err_t start (audio::AudioStreamInfo &stream_info)
 Starts the mixer task.
 
void set_output_channels (uint8_t output_channels)
 
void set_output_bits_per_sample (uint8_t output_bits_per_sample)
 
void set_output_speaker (speaker::Speaker *speaker)
 
void set_queue_mode (bool queue_mode)
 
void set_task_stack_in_psram (bool task_stack_in_psram)
 
speaker::Speakerget_output_speaker () const
 
uint32_t get_frames_in_pipeline () const
 Returns the current number of frames in the output pipeline (written but not yet played)
 
- Public Member Functions inherited from esphome::Component
virtual float get_setup_priority () const
 priority of setup().
 
float get_actual_setup_priority () const
 
void set_setup_priority (float priority)
 
void call ()
 
virtual void on_shutdown ()
 
virtual void on_safe_shutdown ()
 
virtual bool teardown ()
 Called during teardown to allow component to gracefully finish operations.
 
virtual void on_powerdown ()
 Called after teardown is complete to power down hardware.
 
uint8_t get_component_state () const
 
void reset_to_construction_state ()
 Reset this component back to the construction state to allow setup to run again.
 
bool is_in_loop_state () const
 Check if this component has completed setup and is in the loop state.
 
bool is_idle () const
 Check if this component is idle.
 
void mark_failed ()
 Mark this component as failed.
 
void mark_failed (const LogString *message)
 
void disable_loop ()
 Disable this component's loop.
 
void enable_loop ()
 Enable this component's loop.
 
void enable_loop_soon_any_context ()
 Thread and ISR-safe version of enable_loop() that can be called from any context.
 
bool is_failed () const
 
bool is_ready () const
 
virtual bool can_proceed ()
 
bool status_has_warning () const
 
bool status_has_error () const
 
void status_set_warning ()
 
void status_set_warning (const char *message)
 
void status_set_warning (const LogString *message)
 
void status_set_error ()
 
void status_set_error (const LogString *message)
 
void status_clear_warning ()
 
void status_clear_error ()
 
void status_momentary_warning (const char *name, uint32_t length=5000)
 Set warning status flag and automatically clear it after a timeout.
 
void status_momentary_error (const char *name, uint32_t length=5000)
 Set error status flag and automatically clear it after a timeout.
 
bool has_overridden_loop () const
 
const LogString * get_component_log_str () const ESPHOME_ALWAYS_INLINE
 Get the integration where this component was declared as a LogString for logging.
 
bool should_warn_of_blocking (uint32_t blocking_time)
 

Static Protected Member Functions

static void audio_mixer_task (void *params)
 

Protected Attributes

EventGroupHandle_t event_group_ {nullptr}
 
FixedVector< SourceSpeaker * > source_speakers_
 
speaker::Speakeroutput_speaker_ {nullptr}
 
uint8_t output_bits_per_sample_
 
uint8_t output_channels_
 
bool queue_mode_
 
bool task_stack_in_psram_ {false}
 
StaticTask task_
 
optional< audio::AudioStreamInfoaudio_stream_info_
 
std::atomic< uint32_tframes_in_pipeline_ {0}
 
uint32_t all_stopped_since_ms_ {0}
 
- Protected Attributes inherited from esphome::Component
ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") void set_interval(const std voi set_interval )(const char *name, uint32_t interval, std::function< void()> &&f)
 Set an interval function with a unique name.
 
ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") bool cancel_interval(const std boo cancel_interval )(const char *name)
 Cancel an interval function.
 
ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t initial_wait_time
 
ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t uint8_t max_attempts
 
ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t uint8_t std::function< RetryResult(uint8_t)> && f
 
ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std uint32_t uint8_t std::function< RetryResult(uint8_t)> float backoff_increase_factor = 1.0f)
 
uint32_t initial_wait_time
 
uint32_t uint8_t max_attempts
 
uint32_t uint8_t std::function< RetryResult(uint8_t)> && f
 
uint32_t uint8_t std::function< RetryResult(uint8_t)> float backoff_increase_factor = 1.0f)
 
uint8_t max_attempts
 
uint8_t std::function< RetryResult(uint8_t)> && f
 
uint8_t std::function< RetryResult(uint8_t)> float backoff_increase_factor = 1.0f)
 
ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") void set_timeout(const std voi set_timeout )(const char *name, uint32_t timeout, std::function< void()> &&f)
 Set a timeout function with a unique name.
 
ESPDEPRECATED("Use const char* or uint32_t overload instead. Removed in 2026.7.0", "2026.1.0") bool cancel_timeout(const std boo cancel_timeout )(const char *name)
 Cancel a timeout function.
 
ESPDEPRECATED("Use const char* overload instead. Removed in 2026.7.0", "2026.1.0") void defer(const std voi defer )(const char *name, std::function< void()> &&f)
 Defer a callback to the next loop() call.
 
ESPDEPRECATED("Use const char* overload instead. Removed in 2026.7.0", "2026.1.0") bool cancel_defer(const std boo cancel_defer )(const char *name)
 Cancel a defer callback using the specified name, name must not be empty.
 
uint8_t component_source_index_ {0}
 Index into component source PROGMEM lookup table (0 = not set)
 
uint8_t warn_if_blocking_over_ {WARN_IF_BLOCKING_OVER_CS}
 Warn threshold in centiseconds (max 2550ms)
 
uint8_t component_state_ {0x00}
 State of this component - each bit has a purpose: Bits 0-2: Component state (0x00=CONSTRUCTION, 0x01=SETUP, 0x02=LOOP, 0x03=FAILED, 0x04=LOOP_DONE) Bit 3: STATUS_LED_WARNING Bit 4: STATUS_LED_ERROR Bit 5: Has overridden loop() (set at registration time) Bits 6-7: Unused - reserved for future expansion.
 
volatile bool pending_enable_loop_ {false}
 ISR-safe flag for enable_loop_soon_any_context.
 
ComponentRuntimeStats runtime_stats_
 

Additional Inherited Members

- Protected Member Functions inherited from esphome::Component
friend void::setup ()
 
friend void::original_setup ()
 
void set_component_source_ (uint8_t index)
 Set where this component was loaded from for some debug messages.
 
virtual void call_setup ()
 
void call_dump_config_ ()
 
void enable_loop_slow_path_ ()
 
void set_component_state_ (uint8_t state)
 Helper to set component state (clears state bits and sets new state)
 
bool set_status_flag_ (uint8_t flag)
 Helper to set a status LED flag on both this component and the app.
 
void set_interval (uint32_t id, uint32_t interval, std::function< void()> &&f)
 Set an interval function with a numeric ID (zero heap allocation).
 
void set_interval (InternalSchedulerID id, uint32_t interval, std::function< void()> &&f)
 
void set_interval (uint32_t interval, std::function< void()> &&f)
 
bool cancel_interval (uint32_t id)
 
bool cancel_interval (InternalSchedulerID id)
 
ESPDEPRECATED("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const std ESPDEPRECATED ("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(const char *name
 
 ESPDEPRECATED ("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(uint32_t id
 
 ESPDEPRECATED ("set_retry is deprecated and will be removed in 2026.8.0. Use set_timeout or set_interval instead.", "2026.2.0") void set_retry(uint32_t initial_wait_time
 
ESPDEPRECATED("cancel_retry is deprecated and will be removed in 2026.8.0.", "2026.2.0") bool cancel_retry(const std ESPDEPRECATED ("cancel_retry is deprecated and will be removed in 2026.8.0.", "2026.2.0") bool cancel_retry(const char *name)
 
 ESPDEPRECATED ("cancel_retry is deprecated and will be removed in 2026.8.0.", "2026.2.0") bool cancel_retry(uint32_t id)
 
void set_timeout (uint32_t id, uint32_t timeout, std::function< void()> &&f)
 Set a timeout function with a numeric ID (zero heap allocation).
 
void set_timeout (InternalSchedulerID id, uint32_t timeout, std::function< void()> &&f)
 
void set_timeout (uint32_t timeout, std::function< void()> &&f)
 
bool cancel_timeout (uint32_t id)
 
bool cancel_timeout (InternalSchedulerID id)
 
void defer (std::function< void()> &&f)
 Defer a callback to the next loop() call.
 
void defer (uint32_t id, std::function< void()> &&f)
 Defer a callback with a numeric ID (zero heap allocation)
 
bool cancel_defer (uint32_t id)
 
void status_clear_warning_slow_path_ ()
 
void status_clear_error_slow_path_ ()
 

Detailed Description

Definition at line 121 of file mixer_speaker.h.

Member Function Documentation

◆ add_source_speaker()

void esphome::mixer_speaker::MixerSpeaker::add_source_speaker ( SourceSpeaker * source_speaker)
inline

Definition at line 128 of file mixer_speaker.h.

◆ audio_mixer_task()

void esphome::mixer_speaker::MixerSpeaker::audio_mixer_task ( void * params)
staticprotected

Definition at line 453 of file mixer_speaker.cpp.

◆ dump_config()

void esphome::mixer_speaker::MixerSpeaker::dump_config ( )
overridevirtual

Reimplemented from esphome::Component.

Definition at line 328 of file mixer_speaker.cpp.

◆ get_frames_in_pipeline()

uint32_t esphome::mixer_speaker::MixerSpeaker::get_frames_in_pipeline ( ) const
inline

Returns the current number of frames in the output pipeline (written but not yet played)

Definition at line 147 of file mixer_speaker.h.

◆ get_output_speaker()

speaker::Speaker * esphome::mixer_speaker::MixerSpeaker::get_output_speaker ( ) const
inline

Definition at line 144 of file mixer_speaker.h.

◆ init_source_speakers()

void esphome::mixer_speaker::MixerSpeaker::init_source_speakers ( size_t count)
inline

Definition at line 127 of file mixer_speaker.h.

◆ loop()

void esphome::mixer_speaker::MixerSpeaker::loop ( )
overridevirtual

Reimplemented from esphome::Component.

Definition at line 350 of file mixer_speaker.cpp.

◆ set_output_bits_per_sample()

void esphome::mixer_speaker::MixerSpeaker::set_output_bits_per_sample ( uint8_t output_bits_per_sample)
inline

Definition at line 137 of file mixer_speaker.h.

◆ set_output_channels()

void esphome::mixer_speaker::MixerSpeaker::set_output_channels ( uint8_t output_channels)
inline

Definition at line 136 of file mixer_speaker.h.

◆ set_output_speaker()

void esphome::mixer_speaker::MixerSpeaker::set_output_speaker ( speaker::Speaker * speaker)
inline

Definition at line 140 of file mixer_speaker.h.

◆ set_queue_mode()

void esphome::mixer_speaker::MixerSpeaker::set_queue_mode ( bool queue_mode)
inline

Definition at line 141 of file mixer_speaker.h.

◆ set_task_stack_in_psram()

void esphome::mixer_speaker::MixerSpeaker::set_task_stack_in_psram ( bool task_stack_in_psram)
inline

Definition at line 142 of file mixer_speaker.h.

◆ setup()

void esphome::mixer_speaker::MixerSpeaker::setup ( )
overridevirtual

Reimplemented from esphome::Component.

Definition at line 336 of file mixer_speaker.cpp.

◆ start()

esp_err_t esphome::mixer_speaker::MixerSpeaker::start ( audio::AudioStreamInfo & stream_info)

Starts the mixer task.

Called by a source speaker giving the current audio stream information

Parameters
stream_infoThe calling source speaker's audio stream information
Returns
ESP_ERR_INVALID_ARG if the incoming stream is incompatible to be mixed with the other input audio stream ESP_OK if the incoming stream is compatible and the mixer task starts

Definition at line 425 of file mixer_speaker.cpp.

Field Documentation

◆ all_stopped_since_ms_

uint32_t esphome::mixer_speaker::MixerSpeaker::all_stopped_since_ms_ {0}
protected

Definition at line 167 of file mixer_speaker.h.

◆ audio_stream_info_

optional<audio::AudioStreamInfo> esphome::mixer_speaker::MixerSpeaker::audio_stream_info_
protected

Definition at line 164 of file mixer_speaker.h.

◆ event_group_

EventGroupHandle_t esphome::mixer_speaker::MixerSpeaker::event_group_ {nullptr}
protected

Definition at line 152 of file mixer_speaker.h.

◆ frames_in_pipeline_

std::atomic<uint32_t> esphome::mixer_speaker::MixerSpeaker::frames_in_pipeline_ {0}
protected

Definition at line 166 of file mixer_speaker.h.

◆ output_bits_per_sample_

uint8_t esphome::mixer_speaker::MixerSpeaker::output_bits_per_sample_
protected

Definition at line 157 of file mixer_speaker.h.

◆ output_channels_

uint8_t esphome::mixer_speaker::MixerSpeaker::output_channels_
protected

Definition at line 158 of file mixer_speaker.h.

◆ output_speaker_

speaker::Speaker* esphome::mixer_speaker::MixerSpeaker::output_speaker_ {nullptr}
protected

Definition at line 155 of file mixer_speaker.h.

◆ queue_mode_

bool esphome::mixer_speaker::MixerSpeaker::queue_mode_
protected

Definition at line 159 of file mixer_speaker.h.

◆ source_speakers_

FixedVector<SourceSpeaker *> esphome::mixer_speaker::MixerSpeaker::source_speakers_
protected

Definition at line 154 of file mixer_speaker.h.

◆ task_

StaticTask esphome::mixer_speaker::MixerSpeaker::task_
protected

Definition at line 162 of file mixer_speaker.h.

◆ task_stack_in_psram_

bool esphome::mixer_speaker::MixerSpeaker::task_stack_in_psram_ {false}
protected

Definition at line 160 of file mixer_speaker.h.


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