Web Audio API implementation of the Sound Manager.
Not all browsers can play all audio formats.
There is a good guide to what's supported: Cross-browser audio basics: Audio codec support.
new WebAudioSoundManager(game)
name | type | description |
---|---|---|
game | Phaser.Game |
Reference to the current game instance. |
The AudioContext being used for playback.
Destination node for connecting individual sounds to.
Global detuning of all sounds in cents. The range of the value is -1200 to 1200, but we recommend setting it to 50.
Local reference to game.
Flag used to track if the game has lost focus.
Local reference to the JSON Cache, as used by Audio Sprites.
The Spatial Audio listener position.
Only available with WebAudio.
You can modify the x/y properties of this Vec2 directly to adjust the listener position within the game world.
Mobile devices require sounds to be triggered from an explicit user action, such as a tap, before any sound can be loaded/played on a web page. Set to true if the audio system is currently locked awaiting user interaction.
Gain node responsible for controlling global muting.
Gain node responsible for controlling global volume.
Flag indicating if sounds should be paused when game looses focus, for instance when user switches to another tab/program/app.
Global playback rate at which all the sounds will be played. Value of 1.0 plays the audio at full speed, 0.5 plays the audio at half speed and 2.0 doubles the audio's playback speed.
Adds a new sound into the sound manager.
name | type | arguments | description |
---|---|---|---|
key | string |
Asset key for the sound. |
|
config | Phaser.Types.Sound.SoundConfig | <optional> |
An optional config object containing default sound settings. |
The new sound instance.
Adds a new audio sprite sound into the sound manager. Audio Sprites are a combination of audio files and a JSON configuration. The JSON follows the format of that created by https://github.com/tonistiigi/audiosprite
name | type | arguments | description |
---|---|---|---|
key | string |
Asset key for the sound. |
|
config | Phaser.Types.Sound.SoundConfig | <optional> |
An optional config object containing default sound settings. |
The new audio sprite sound instance.
Add a listener for a given event.
name | type | arguments | Default | description |
---|---|---|---|---|
event | string | symbol |
The event name. |
||
fn | function |
The listener function. |
||
context | * | <optional> | this |
The context to invoke the listener with. |
this
.
Method responsible for instantiating and returning AudioContext instance. If an instance of an AudioContext class was provided through the game config, that instance will be returned instead. This can come in handy if you are reloading a Phaser game on a page that never properly refreshes (such as in an SPA project) and you want to reuse already instantiated AudioContext.
name | type | description |
---|---|---|
game | Phaser.Game |
Reference to the current game instance. |
The AudioContext instance to be used for playback.
Decode audio data into a format ready for playback via Web Audio.
The audio data can be a base64 encoded string, an audio media-type data uri, or an ArrayBuffer instance.
The audioKey
is the key that will be used to save the decoded audio to the audio cache.
Instead of passing a single entry you can instead pass an array of Phaser.Types.Sound.DecodeAudioConfig
objects as the first and only argument.
Decoding is an async process, so be sure to listen for the events to know when decoding has completed.
Once the audio has decoded it can be added to the Sound Manager or played via its key.
name | type | arguments | description |
---|---|---|---|
audioKey | string | Array.<Phaser.Types.Sound.DecodeAudioConfig> | <optional> |
The string-based key to be used to reference the decoded audio in the audio cache, or an array of audio config objects. |
audioData | ArrayBuffer | string | <optional> |
The audio data, either a base64 encoded string, an audio media-type data uri, or an ArrayBuffer instance. |
Calls Phaser.Sound.BaseSoundManager#destroy method and cleans up all Web Audio API related stuff.
Calls each of the listeners registered for a given event.
name | type | arguments | description |
---|---|---|---|
event | string | symbol |
The event name. |
|
args | * | <optional> |
Additional arguments that will be passed to the event handler. |
true
if the event had listeners, else false
.
Return an array listing the events for which the emitter has registered listeners.
Gets the first sound in this Sound Manager that matches the given key.
If none can be found it returns null
.
name | type | description |
---|---|---|
key | string |
Sound asset key. |
Gets all sounds in this Sound Manager.
You can optionally specify a key, in which case only Sound instances that match the given key will be returned.
name | type | arguments | description |
---|---|---|---|
key | string | <optional> |
Optional asset key. If given, only Sound instances with this key will be returned. |
Returns all sounds from this Sound Manager that are currently
playing. That is, Sound instances that have their isPlaying
property set to true
.
When a key is given, returns true if any sound with that key is playing.
When no key is given, returns true if any sound is playing.
name | type | description |
---|---|---|
key | string |
Sound asset key. |
Return the number of listeners listening to a given event.
name | type | description |
---|---|---|
event | string | symbol |
The event name. |
The number of listeners.
Return the listeners registered for a given event.
name | type | description |
---|---|---|
event | string | symbol |
The event name. |
The registered listeners.
Remove the listeners of a given event.
name | type | arguments | description |
---|---|---|---|
event | string | symbol |
The event name. |
|
fn | function | <optional> |
Only remove the listeners that match this function. |
context | * | <optional> |
Only remove the listeners that have this context. |
once | boolean | <optional> |
Only remove one-time listeners. |
this
.
Add a listener for a given event.
name | type | arguments | Default | description |
---|---|---|---|---|
event | string | symbol |
The event name. |
||
fn | function |
The listener function. |
||
context | * | <optional> | this |
The context to invoke the listener with. |
this
.
Method used internally for pausing sound manager if Phaser.Sound.WebAudioSoundManager#pauseOnBlur is set to true.
Method used internally for resuming sound manager if Phaser.Sound.WebAudioSoundManager#pauseOnBlur is set to true.
Add a one-time listener for a given event.
name | type | arguments | Default | description |
---|---|---|---|---|
event | string | symbol |
The event name. |
||
fn | function |
The listener function. |
||
context | * | <optional> | this |
The context to invoke the listener with. |
this
.
Pauses all the sounds in the game.
Adds a new sound to the sound manager and plays it.
The sound will be automatically removed (destroyed) once playback ends.
This lets you play a new sound on the fly without the need to keep a reference to it.
name | type | arguments | description |
---|---|---|---|
key | string |
Asset key for the sound. |
|
extra | Phaser.Types.Sound.SoundConfig | Phaser.Types.Sound.SoundMarker | <optional> |
An optional additional object containing settings to be applied to the sound. It could be either config or marker object. |
Whether the sound started playing successfully.
Adds a new audio sprite sound to the sound manager and plays it. The sprite will be automatically removed (destroyed) once playback ends. This lets you play a new sound on the fly without the need to keep a reference to it.
name | type | arguments | description |
---|---|---|---|
key | string |
Asset key for the sound. |
|
spriteName | string |
The name of the sound sprite to play. |
|
config | Phaser.Types.Sound.SoundConfig | <optional> |
An optional config object containing default sound settings. |
Whether the audio sprite sound started playing successfully.
Removes a sound from the sound manager. The removed sound is destroyed before removal.
name | type | description |
---|---|---|
sound | Phaser.Sound.BaseSound |
The sound object to remove. |
True if the sound was removed successfully, otherwise false.
Removes all sounds from the manager, destroying the sounds.
Remove all listeners, or those of the specified event.
name | type | arguments | description |
---|---|---|---|
event | string | symbol | <optional> |
The event name. |
this
.
Removes all sounds from the sound manager that have an asset key matching the given value. The removed sounds are destroyed before removal.
name | type | description |
---|---|---|
key | string |
The key to match when removing sound objects. |
The number of matching sound objects that were removed.
Remove the listeners of a given event.
name | type | arguments | description |
---|---|---|---|
event | string | symbol |
The event name. |
|
fn | function | <optional> |
Only remove the listeners that match this function. |
context | * | <optional> |
Only remove the listeners that have this context. |
once | boolean | <optional> |
Only remove one-time listeners. |
this
.
Resumes all the sounds in the game.
This method takes a new AudioContext reference and then sets this Sound Manager to use that context for all playback.
As part of this call it also disconnects the master mute and volume nodes and then re-creates them on the new given context.
name | type | description |
---|---|---|
context | AudioContext |
Reference to an already created AudioContext instance. |
The WebAudioSoundManager instance.
Sets the global detuning of all sounds in cents. The range of the value is -1200 to 1200, but we recommend setting it to 50.
name | type | description |
---|---|---|
value | number |
The range of the value is -1200 to 1200, but we recommend setting it to 50. |
This Sound Manager.
Sets the X and Y position of the Spatial Audio listener on this Web Audios context.
If you call this method with no parameters it will default to the center-point of the game canvas. Depending on the type of game you're making, you may need to call this method constantly to reset the listener position as the camera scrolls.
Calling this method does nothing on HTML5Audio.
name | type | arguments | description |
---|---|---|---|
x | number | <optional> |
The x position of the Spatial Audio listener. |
y | number | <optional> |
The y position of the Spatial Audio listener. |
Sets the muted state of all this Sound Manager.
name | type | description |
---|---|---|
value | boolean |
|
This Sound Manager.
Sets the global playback rate at which all the sounds will be played.
For example, a value of 1.0 plays the audio at full speed, 0.5 plays the audio at half speed and 2.0 doubles the audios playback speed.
name | type | description |
---|---|---|
value | number |
Global playback rate at which all the sounds will be played. |
This Sound Manager.
Sets the volume of this Sound Manager.
name | type | description |
---|---|---|
value | number |
The global volume of this Sound Manager. |
This Sound Manager.
Removes all listeners.
Stops all the sounds in the game.
Stops any sounds matching the given key.
name | type | description |
---|---|---|
key | string |
Sound asset key. |
Unlocks Web Audio API on the initial input event.
Read more about how this issue is handled here in this article.
Update method called on every game step.
Removes destroyed sounds and updates every active sound in the game.
name | type | description |
---|---|---|
time | number |
The current timestamp as generated by the Request Animation Frame or SetTimeout. |
delta | number |
The delta time elapsed since the last frame. |