Gnash
0.8.10
|
AHI-based sound_handler. More...
#include <sound_handler_ahi.h>
Public Member Functions | |
AOS4_sound_handler (media::MediaHandler *m) | |
~AOS4_sound_handler () | |
virtual int | create_sound (std::auto_ptr< SimpleBuffer > data, std::auto_ptr< media::SoundInfo > sinfo) |
virtual StreamBlockId | addSoundBlock (unsigned char *data, unsigned int data_bytes, unsigned int sample_count, int streamId) |
virtual void | stop_sound (int sound_handle) |
virtual void | delete_sound (int sound_handle) |
Discard the sound data for an embedded event sound. | |
virtual void | reset () |
Discard all sound inputs (slots and aux streamers) and clear scheduling. | |
virtual void | stop_all_sounds () |
Remove all scheduled request for playback of sound buffer slots. | |
virtual int | get_volume (int sound_handle) |
virtual void | set_volume (int sound_handle, int volume) |
Sets the volume for a given event sound. | |
virtual media::SoundInfo * | get_sound_info (int soundHandle) |
virtual void | mute () |
Call this to mute audio. | |
virtual void | unmute () |
Call this to unmute audio. | |
virtual bool | is_muted () const |
Returns whether or not sound is muted. | |
virtual void | pause () |
gnash calls this to pause audio | |
virtual void | unpause () |
gnash calls this to unpause audio | |
virtual unsigned int | get_duration (int sound_handle) |
virtual unsigned int | tell (int sound_handle) |
void | plugInputStream (std::auto_ptr< InputStream > in) |
Plug an InputStream to the mixer. | |
void | fetchSamples (boost::int16_t *to, unsigned int nSamples) |
Fetch mixed samples. | |
int | audioTask () |
AHI-based sound_handler.
gnash::sound::AOS4_sound_handler::AOS4_sound_handler | ( | media::MediaHandler * | m | ) |
gnash::sound::AOS4_sound_handler::~AOS4_sound_handler | ( | ) |
sound_handler::StreamBlockId gnash::sound::AOS4_sound_handler::addSoundBlock | ( | unsigned char * | data, |
unsigned int | data_bytes, | ||
unsigned int | sample_count, | ||
int | streamId | ||
) | [virtual] |
int gnash::sound::AOS4_sound_handler::audioTask | ( | ) |
References AHI_BUF_SIZE, BUFSIZE, _, RESET_TIME, gnash::sound::sound_handler::isPaused(), gnash::key::n, and fetchSamples().
int gnash::sound::AOS4_sound_handler::create_sound | ( | std::auto_ptr< SimpleBuffer > | data, |
std::auto_ptr< media::SoundInfo > | sinfo | ||
) | [virtual] |
void gnash::sound::AOS4_sound_handler::delete_sound | ( | int | sound_handle | ) | [virtual] |
Discard the sound data for an embedded event sound.
Only embedded event sounds are deleted; this happens when the associated sound_sample is deleted.
sound_handle | The id for the event sound to be deleted |
Reimplemented from gnash::sound::sound_handler.
void gnash::sound::AOS4_sound_handler::fetchSamples | ( | boost::int16_t * | to, |
unsigned int | nSamples | ||
) | [virtual] |
Fetch mixed samples.
We run through all the plugged InputStreams fetching decoded audio blocks and mixing them into the given output stream.
to | The buffer to write mixed samples to. Buffer must be big enough to hold nSamples samples. |
nSamples | The amount of samples to fetch. NOTE: this number currently refers to "mono" samples due to some bad design decision. It is so expected that the user fetches 44100 * 2 samples which has to be interpreted as series of left,right channel couples. TODO: use actual number of samples so that it's expected to fetch 44100 per second and let expose a function to give interpretation of what comes back (how many bytes per channel, which format). |
Reimplemented from gnash::sound::sound_handler.
References gnash::sound::sound_handler::hasInputStreams(), and pause().
Referenced by audioTask().
unsigned int gnash::sound::AOS4_sound_handler::get_duration | ( | int | sound_handle | ) | [virtual] |
media::SoundInfo * gnash::sound::AOS4_sound_handler::get_sound_info | ( | int | soundHandle | ) | [virtual] |
int gnash::sound::AOS4_sound_handler::get_volume | ( | int | sound_handle | ) | [virtual] |
bool gnash::sound::AOS4_sound_handler::is_muted | ( | ) | const [virtual] |
Returns whether or not sound is muted.
Reimplemented from gnash::sound::sound_handler.
void gnash::sound::AOS4_sound_handler::mute | ( | ) | [virtual] |
Call this to mute audio.
Reimplemented from gnash::sound::sound_handler.
void gnash::sound::AOS4_sound_handler::pause | ( | ) | [virtual] |
gnash calls this to pause audio
Reimplemented from gnash::sound::sound_handler.
References _.
Referenced by ~AOS4_sound_handler(), and fetchSamples().
void gnash::sound::AOS4_sound_handler::plugInputStream | ( | std::auto_ptr< InputStream > | in | ) | [virtual] |
Plug an InputStream to the mixer.
in | The InputStream to plug, ownership transferred |
Reimplemented from gnash::sound::sound_handler.
References unpause().
void gnash::sound::AOS4_sound_handler::reset | ( | ) | [virtual] |
Discard all sound inputs (slots and aux streamers) and clear scheduling.
Gnash calls this on movie restart.
The function should stop all sounds and get ready for a "parse from scratch" operation.
Reimplemented from gnash::sound::sound_handler.
References gnash::sound::sound_handler::delete_all_sounds(), and stop_all_sounds().
void gnash::sound::AOS4_sound_handler::set_volume | ( | int | sound_handle, |
int | volume | ||
) | [virtual] |
Sets the volume for a given event sound.
Only used by the AS Sound class
sound_handle | The handle of the event sound to set volume for. |
volume | A number from 0 to 100 representing a volume level. 100 is full volume and 0 is no volume. The default setting is 100. |
Reimplemented from gnash::sound::sound_handler.
void gnash::sound::AOS4_sound_handler::stop_all_sounds | ( | ) | [virtual] |
Remove all scheduled request for playback of sound buffer slots.
Mixed functions: This applies both to streaming and event sounds.
Reimplemented from gnash::sound::sound_handler.
Referenced by reset().
void gnash::sound::AOS4_sound_handler::stop_sound | ( | int | sound_handle | ) | [virtual] |
unsigned int gnash::sound::AOS4_sound_handler::tell | ( | int | sound_handle | ) | [virtual] |
void gnash::sound::AOS4_sound_handler::unmute | ( | ) | [virtual] |
Call this to unmute audio.
Reimplemented from gnash::sound::sound_handler.
void gnash::sound::AOS4_sound_handler::unpause | ( | ) | [virtual] |
gnash calls this to unpause audio
Reimplemented from gnash::sound::sound_handler.
References gnash::sound::sound_handler::hasInputStreams(), and _.
Referenced by plugInputStream().