ESPHome  2025.2.0
Public Member Functions | Protected Member Functions | Protected Attributes
esphome::speaker::SpeakerMediaPlayer Class Reference

#include <speaker_media_player.h>

Inheritance diagram for esphome::speaker::SpeakerMediaPlayer:
esphome::Component esphome::media_player::MediaPlayer esphome::EntityBase

Public Member Functions

float get_setup_priority () const override
 
void setup () override
 
void loop () override
 
media_player::MediaPlayerTraits get_traits () override
 
bool is_muted () const override
 
void set_buffer_size (size_t buffer_size)
 
void set_task_stack_in_psram (bool task_stack_in_psram)
 
void set_volume_increment (float volume_increment)
 
void set_volume_max (float volume_max)
 
void set_volume_min (float volume_min)
 
void set_announcement_speaker (Speaker *announcement_speaker)
 
void set_announcement_format (const media_player::MediaPlayerSupportedFormat &announcement_format)
 
void set_media_speaker (Speaker *media_speaker)
 
void set_media_format (const media_player::MediaPlayerSupportedFormat &media_format)
 
Triggerget_mute_trigger () const
 
Triggerget_unmute_trigger () const
 
Trigger< float > * get_volume_trigger () const
 
void play_file (audio::AudioFile *media_file, bool announcement, bool enqueue)
 
uint32_t get_playback_ms () const
 
uint32_t get_playback_us () const
 
uint32_t get_decoded_playback_ms () const
 
void set_playlist_delay_ms (AudioPipelineType pipeline_type, uint32_t delay_ms)
 
- Public Member Functions inherited from esphome::Component
virtual void dump_config ()
 
float get_actual_setup_priority () const
 
void set_setup_priority (float priority)
 
virtual float get_loop_priority () const
 priority of loop(). More...
 
void call ()
 
virtual void on_shutdown ()
 
virtual void on_safe_shutdown ()
 
uint32_t get_component_state () const
 
virtual void mark_failed ()
 Mark this component as failed. More...
 
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 (const char *message="unspecified")
 
void status_set_error (const char *message="unspecified")
 
void status_clear_warning ()
 
void status_clear_error ()
 
void status_momentary_warning (const std::string &name, uint32_t length=5000)
 
void status_momentary_error (const std::string &name, uint32_t length=5000)
 
bool has_overridden_loop () const
 
void set_component_source (const char *source)
 Set where this component was loaded from for some debug messages. More...
 
const char * get_component_source () const
 Get the integration where this component was declared as a string. More...
 
- Public Member Functions inherited from esphome::media_player::MediaPlayer
MediaPlayerCall make_call ()
 
void publish_state ()
 
void add_on_state_callback (std::function< void()> &&callback)
 
- Public Member Functions inherited from esphome::EntityBase
const StringRefget_name () const
 
void set_name (const char *name)
 
bool has_own_name () const
 
std::string get_object_id () const
 
void set_object_id (const char *object_id)
 
uint32_t get_object_id_hash ()
 
bool is_internal () const
 
void set_internal (bool internal)
 
bool is_disabled_by_default () const
 
void set_disabled_by_default (bool disabled_by_default)
 
EntityCategory get_entity_category () const
 
void set_entity_category (EntityCategory entity_category)
 
std::string get_icon () const
 
void set_icon (const char *icon)
 

Protected Member Functions

void control (const media_player::MediaPlayerCall &call) override
 
void set_volume_ (float volume, bool publish=true)
 Updates this->volume and saves volume/mute state to flash for restortation if publish is true. More...
 
void set_mute_state_ (bool mute_state)
 Sets the mute state. More...
 
void save_volume_restore_state_ ()
 Saves the current volume and mute state to the flash for restoration. More...
 
bool single_pipeline_ ()
 Returns true if the media player has only the announcement pipeline defined, false if both the announcement and media pipelines are defined. More...
 
void watch_media_commands_ ()
 
- Protected Member Functions inherited from esphome::Component
virtual void call_loop ()
 
virtual void call_setup ()
 
virtual void call_dump_config ()
 
void set_interval (const std::string &name, uint32_t interval, std::function< void()> &&f)
 Set an interval function with a unique name. More...
 
void set_interval (uint32_t interval, std::function< void()> &&f)
 
bool cancel_interval (const std::string &name)
 Cancel an interval function. More...
 
void set_retry (const std::string &name, uint32_t initial_wait_time, uint8_t max_attempts, std::function< RetryResult(uint8_t)> &&f, float backoff_increase_factor=1.0f)
 Set an retry function with a unique name. More...
 
void set_retry (uint32_t initial_wait_time, uint8_t max_attempts, std::function< RetryResult(uint8_t)> &&f, float backoff_increase_factor=1.0f)
 
bool cancel_retry (const std::string &name)
 Cancel a retry function. More...
 
void set_timeout (const std::string &name, uint32_t timeout, std::function< void()> &&f)
 Set a timeout function with a unique name. More...
 
void set_timeout (uint32_t timeout, std::function< void()> &&f)
 
bool cancel_timeout (const std::string &name)
 Cancel a timeout function. More...
 
void defer (const std::string &name, std::function< void()> &&f)
 Defer a callback to the next loop() call. More...
 
void defer (std::function< void()> &&f)
 Defer a callback to the next loop() call. More...
 
bool cancel_defer (const std::string &name)
 Cancel a defer callback using the specified name, name must not be empty. More...
 
- Protected Member Functions inherited from esphome::EntityBase
virtual uint32_t hash_base ()
 The hash_base() function has been deprecated. More...
 
void calc_object_id_ ()
 

Protected Attributes

std::unique_ptr< AudioPipelineannouncement_pipeline_
 
std::unique_ptr< AudioPipelinemedia_pipeline_
 
Speakermedia_speaker_ {nullptr}
 
Speakerannouncement_speaker_ {nullptr}
 
optional< media_player::MediaPlayerSupportedFormatmedia_format_
 
AudioPipelineState media_pipeline_state_ {AudioPipelineState::STOPPED}
 
std::string media_url_ {}
 
audio::AudioFilemedia_file_ {}
 
bool media_repeat_one_ {false}
 
uint32_t media_playlist_delay_ms_ {0}
 
optional< media_player::MediaPlayerSupportedFormatannouncement_format_
 
AudioPipelineState announcement_pipeline_state_ {AudioPipelineState::STOPPED}
 
std::string announcement_url_ {}
 
audio::AudioFileannouncement_file_ {}
 
bool announcement_repeat_one_ {false}
 
uint32_t announcement_playlist_delay_ms_ {0}
 
QueueHandle_t media_control_command_queue_
 
std::deque< PlaylistItemannouncement_playlist_
 
std::deque< PlaylistItemmedia_playlist_
 
size_t buffer_size_
 
bool task_stack_in_psram_
 
bool is_paused_ {false}
 
bool is_muted_ {false}
 
float volume_increment_
 
float volume_max_
 
float volume_min_
 
ESPPreferenceObject pref_
 
Triggermute_trigger_ = new Trigger<>()
 
Triggerunmute_trigger_ = new Trigger<>()
 
Trigger< float > * volume_trigger_ = new Trigger<float>()
 
uint32_t decoded_playback_ms_ {0}
 
uint32_t playback_us_ {0}
 
uint32_t playback_ms_ {0}
 
uint32_t remainder_us_ {0}
 
uint32_t pending_ms_ {0}
 
uint32_t last_audio_write_timestamp_ {0}
 
- Protected Attributes inherited from esphome::Component
uint32_t component_state_ {0x0000}
 State of this component. More...
 
float setup_priority_override_ {NAN}
 
const char * component_source_ {nullptr}
 
- Protected Attributes inherited from esphome::media_player::MediaPlayer
friend MediaPlayerCall
 
CallbackManager< void()> state_callback_ {}
 
- Protected Attributes inherited from esphome::EntityBase
StringRef name_
 
const char * object_id_c_str_ {nullptr}
 
const char * icon_c_str_ {nullptr}
 
uint32_t object_id_hash_
 
bool has_own_name_ {false}
 
bool internal_ {false}
 
bool disabled_by_default_ {false}
 
EntityCategory entity_category_ {ENTITY_CATEGORY_NONE}
 

Additional Inherited Members

- Data Fields inherited from esphome::media_player::MediaPlayer
MediaPlayerState state {MEDIA_PLAYER_STATE_NONE}
 
float volume {1.0f}
 

Detailed Description

Definition at line 42 of file speaker_media_player.h.

Member Function Documentation

◆ control()

void esphome::speaker::SpeakerMediaPlayer::control ( const media_player::MediaPlayerCall call)
overrideprotectedvirtual

Implements esphome::media_player::MediaPlayer.

Definition at line 444 of file speaker_media_player.cpp.

◆ get_decoded_playback_ms()

uint32_t esphome::speaker::SpeakerMediaPlayer::get_decoded_playback_ms ( ) const
inline

Definition at line 78 of file speaker_media_player.h.

◆ get_mute_trigger()

Trigger* esphome::speaker::SpeakerMediaPlayer::get_mute_trigger ( ) const
inline

Definition at line 70 of file speaker_media_player.h.

◆ get_playback_ms()

uint32_t esphome::speaker::SpeakerMediaPlayer::get_playback_ms ( ) const
inline

Definition at line 76 of file speaker_media_player.h.

◆ get_playback_us()

uint32_t esphome::speaker::SpeakerMediaPlayer::get_playback_us ( ) const
inline

Definition at line 77 of file speaker_media_player.h.

◆ get_setup_priority()

float esphome::speaker::SpeakerMediaPlayer::get_setup_priority ( ) const
inlineoverridevirtual

Reimplemented from esphome::Component.

Definition at line 44 of file speaker_media_player.h.

◆ get_traits()

media_player::MediaPlayerTraits esphome::speaker::SpeakerMediaPlayer::get_traits ( )
overridevirtual

Implements esphome::media_player::MediaPlayer.

Definition at line 497 of file speaker_media_player.cpp.

◆ get_unmute_trigger()

Trigger* esphome::speaker::SpeakerMediaPlayer::get_unmute_trigger ( ) const
inline

Definition at line 71 of file speaker_media_player.h.

◆ get_volume_trigger()

Trigger<float>* esphome::speaker::SpeakerMediaPlayer::get_volume_trigger ( ) const
inline

Definition at line 72 of file speaker_media_player.h.

◆ is_muted()

bool esphome::speaker::SpeakerMediaPlayer::is_muted ( ) const
inlineoverridevirtual

Reimplemented from esphome::media_player::MediaPlayer.

Definition at line 50 of file speaker_media_player.h.

◆ loop()

void esphome::speaker::SpeakerMediaPlayer::loop ( )
overridevirtual

Reimplemented from esphome::Component.

Definition at line 310 of file speaker_media_player.cpp.

◆ play_file()

void esphome::speaker::SpeakerMediaPlayer::play_file ( audio::AudioFile media_file,
bool  announcement,
bool  enqueue 
)

Definition at line 424 of file speaker_media_player.cpp.

◆ save_volume_restore_state_()

void esphome::speaker::SpeakerMediaPlayer::save_volume_restore_state_ ( )
protected

Saves the current volume and mute state to the flash for restoration.

Definition at line 518 of file speaker_media_player.cpp.

◆ set_announcement_format()

void esphome::speaker::SpeakerMediaPlayer::set_announcement_format ( const media_player::MediaPlayerSupportedFormat announcement_format)
inline

Definition at line 62 of file speaker_media_player.h.

◆ set_announcement_speaker()

void esphome::speaker::SpeakerMediaPlayer::set_announcement_speaker ( Speaker announcement_speaker)
inline

Definition at line 61 of file speaker_media_player.h.

◆ set_buffer_size()

void esphome::speaker::SpeakerMediaPlayer::set_buffer_size ( size_t  buffer_size)
inline

Definition at line 52 of file speaker_media_player.h.

◆ set_media_format()

void esphome::speaker::SpeakerMediaPlayer::set_media_format ( const media_player::MediaPlayerSupportedFormat media_format)
inline

Definition at line 66 of file speaker_media_player.h.

◆ set_media_speaker()

void esphome::speaker::SpeakerMediaPlayer::set_media_speaker ( Speaker media_speaker)
inline

Definition at line 65 of file speaker_media_player.h.

◆ set_mute_state_()

void esphome::speaker::SpeakerMediaPlayer::set_mute_state_ ( bool  mute_state)
protected

Sets the mute state.

Restores previous volume if unmuting. Always saves volume/mute state to flash for restoration.

Parameters
mute_stateIf true, audio will be muted. If false, audio will be unmuted

Definition at line 525 of file speaker_media_player.cpp.

◆ set_playlist_delay_ms()

void esphome::speaker::SpeakerMediaPlayer::set_playlist_delay_ms ( AudioPipelineType  pipeline_type,
uint32_t  delay_ms 
)

Definition at line 124 of file speaker_media_player.cpp.

◆ set_task_stack_in_psram()

void esphome::speaker::SpeakerMediaPlayer::set_task_stack_in_psram ( bool  task_stack_in_psram)
inline

Definition at line 53 of file speaker_media_player.h.

◆ set_volume_()

void esphome::speaker::SpeakerMediaPlayer::set_volume_ ( float  volume,
bool  publish = true 
)
protected

Updates this->volume and saves volume/mute state to flash for restortation if publish is true.

Definition at line 547 of file speaker_media_player.cpp.

◆ set_volume_increment()

void esphome::speaker::SpeakerMediaPlayer::set_volume_increment ( float  volume_increment)
inline

Definition at line 56 of file speaker_media_player.h.

◆ set_volume_max()

void esphome::speaker::SpeakerMediaPlayer::set_volume_max ( float  volume_max)
inline

Definition at line 58 of file speaker_media_player.h.

◆ set_volume_min()

void esphome::speaker::SpeakerMediaPlayer::set_volume_min ( float  volume_min)
inline

Definition at line 59 of file speaker_media_player.h.

◆ setup()

void esphome::speaker::SpeakerMediaPlayer::setup ( )
overridevirtual

Reimplemented from esphome::Component.

Definition at line 55 of file speaker_media_player.cpp.

◆ single_pipeline_()

bool esphome::speaker::SpeakerMediaPlayer::single_pipeline_ ( )
inlineprotected

Returns true if the media player has only the announcement pipeline defined, false if both the announcement and media pipelines are defined.

Definition at line 100 of file speaker_media_player.h.

◆ watch_media_commands_()

void esphome::speaker::SpeakerMediaPlayer::watch_media_commands_ ( )
protected

Definition at line 135 of file speaker_media_player.cpp.

Field Documentation

◆ announcement_file_

audio::AudioFile* esphome::speaker::SpeakerMediaPlayer::announcement_file_ {}
protected

Definition at line 120 of file speaker_media_player.h.

◆ announcement_format_

optional<media_player::MediaPlayerSupportedFormat> esphome::speaker::SpeakerMediaPlayer::announcement_format_
protected

Definition at line 117 of file speaker_media_player.h.

◆ announcement_pipeline_

std::unique_ptr<AudioPipeline> esphome::speaker::SpeakerMediaPlayer::announcement_pipeline_
protected

Definition at line 105 of file speaker_media_player.h.

◆ announcement_pipeline_state_

AudioPipelineState esphome::speaker::SpeakerMediaPlayer::announcement_pipeline_state_ {AudioPipelineState::STOPPED}
protected

Definition at line 118 of file speaker_media_player.h.

◆ announcement_playlist_

std::deque<PlaylistItem> esphome::speaker::SpeakerMediaPlayer::announcement_playlist_
protected

Definition at line 126 of file speaker_media_player.h.

◆ announcement_playlist_delay_ms_

uint32_t esphome::speaker::SpeakerMediaPlayer::announcement_playlist_delay_ms_ {0}
protected

Definition at line 122 of file speaker_media_player.h.

◆ announcement_repeat_one_

bool esphome::speaker::SpeakerMediaPlayer::announcement_repeat_one_ {false}
protected

Definition at line 121 of file speaker_media_player.h.

◆ announcement_speaker_

Speaker* esphome::speaker::SpeakerMediaPlayer::announcement_speaker_ {nullptr}
protected

Definition at line 108 of file speaker_media_player.h.

◆ announcement_url_

std::string esphome::speaker::SpeakerMediaPlayer::announcement_url_ {}
protected

Definition at line 119 of file speaker_media_player.h.

◆ buffer_size_

size_t esphome::speaker::SpeakerMediaPlayer::buffer_size_
protected

Definition at line 129 of file speaker_media_player.h.

◆ decoded_playback_ms_

uint32_t esphome::speaker::SpeakerMediaPlayer::decoded_playback_ms_ {0}
protected

Definition at line 149 of file speaker_media_player.h.

◆ is_muted_

bool esphome::speaker::SpeakerMediaPlayer::is_muted_ {false}
protected

Definition at line 134 of file speaker_media_player.h.

◆ is_paused_

bool esphome::speaker::SpeakerMediaPlayer::is_paused_ {false}
protected

Definition at line 133 of file speaker_media_player.h.

◆ last_audio_write_timestamp_

uint32_t esphome::speaker::SpeakerMediaPlayer::last_audio_write_timestamp_ {0}
protected

Definition at line 154 of file speaker_media_player.h.

◆ media_control_command_queue_

QueueHandle_t esphome::speaker::SpeakerMediaPlayer::media_control_command_queue_
protected

Definition at line 124 of file speaker_media_player.h.

◆ media_file_

audio::AudioFile* esphome::speaker::SpeakerMediaPlayer::media_file_ {}
protected

Definition at line 113 of file speaker_media_player.h.

◆ media_format_

optional<media_player::MediaPlayerSupportedFormat> esphome::speaker::SpeakerMediaPlayer::media_format_
protected

Definition at line 110 of file speaker_media_player.h.

◆ media_pipeline_

std::unique_ptr<AudioPipeline> esphome::speaker::SpeakerMediaPlayer::media_pipeline_
protected

Definition at line 106 of file speaker_media_player.h.

◆ media_pipeline_state_

AudioPipelineState esphome::speaker::SpeakerMediaPlayer::media_pipeline_state_ {AudioPipelineState::STOPPED}
protected

Definition at line 111 of file speaker_media_player.h.

◆ media_playlist_

std::deque<PlaylistItem> esphome::speaker::SpeakerMediaPlayer::media_playlist_
protected

Definition at line 127 of file speaker_media_player.h.

◆ media_playlist_delay_ms_

uint32_t esphome::speaker::SpeakerMediaPlayer::media_playlist_delay_ms_ {0}
protected

Definition at line 115 of file speaker_media_player.h.

◆ media_repeat_one_

bool esphome::speaker::SpeakerMediaPlayer::media_repeat_one_ {false}
protected

Definition at line 114 of file speaker_media_player.h.

◆ media_speaker_

Speaker* esphome::speaker::SpeakerMediaPlayer::media_speaker_ {nullptr}
protected

Definition at line 107 of file speaker_media_player.h.

◆ media_url_

std::string esphome::speaker::SpeakerMediaPlayer::media_url_ {}
protected

Definition at line 112 of file speaker_media_player.h.

◆ mute_trigger_

Trigger* esphome::speaker::SpeakerMediaPlayer::mute_trigger_ = new Trigger<>()
protected

Definition at line 145 of file speaker_media_player.h.

◆ pending_ms_

uint32_t esphome::speaker::SpeakerMediaPlayer::pending_ms_ {0}
protected

Definition at line 153 of file speaker_media_player.h.

◆ playback_ms_

uint32_t esphome::speaker::SpeakerMediaPlayer::playback_ms_ {0}
protected

Definition at line 151 of file speaker_media_player.h.

◆ playback_us_

uint32_t esphome::speaker::SpeakerMediaPlayer::playback_us_ {0}
protected

Definition at line 150 of file speaker_media_player.h.

◆ pref_

ESPPreferenceObject esphome::speaker::SpeakerMediaPlayer::pref_
protected

Definition at line 143 of file speaker_media_player.h.

◆ remainder_us_

uint32_t esphome::speaker::SpeakerMediaPlayer::remainder_us_ {0}
protected

Definition at line 152 of file speaker_media_player.h.

◆ task_stack_in_psram_

bool esphome::speaker::SpeakerMediaPlayer::task_stack_in_psram_
protected

Definition at line 131 of file speaker_media_player.h.

◆ unmute_trigger_

Trigger* esphome::speaker::SpeakerMediaPlayer::unmute_trigger_ = new Trigger<>()
protected

Definition at line 146 of file speaker_media_player.h.

◆ volume_increment_

float esphome::speaker::SpeakerMediaPlayer::volume_increment_
protected

Definition at line 137 of file speaker_media_player.h.

◆ volume_max_

float esphome::speaker::SpeakerMediaPlayer::volume_max_
protected

Definition at line 139 of file speaker_media_player.h.

◆ volume_min_

float esphome::speaker::SpeakerMediaPlayer::volume_min_
protected

Definition at line 140 of file speaker_media_player.h.

◆ volume_trigger_

Trigger<float>* esphome::speaker::SpeakerMediaPlayer::volume_trigger_ = new Trigger<float>()
protected

Definition at line 147 of file speaker_media_player.h.


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