buzz
Version:
Buzz, a Javascript HTML5 Audio library
133 lines (99 loc) • 3.81 kB
Markdown
Documentation: Events
{:.intro} Various events are sent by the
[HTML5 audio element](https://developer.mozilla.org/en/docs/Web/HTML/Element/audio).
This section lists the events and provides helpful information about using them.
# Methods
The sound and group classes provide methods bind, bindOnce, unbind and trigger to manage events.
```
mySound.bind("loadstart", function () {
document.getElementById("loading").style.display = "block";
}).bind("loadeddata error", function () {
document.getElementById("loading").style.display = "none";
});
```
# Events
### abort
Sent when playback is aborted; for example, if the media is playing and is
restarted from the beginning, this event is sent.
### canplay
Sent when enough data is available that the media can be played, at least for a
couple of frames. This corresponds to the **CAN_PLAY** readyState.
### canplaythrough
Sent when the ready state changes to **CAN_PLAY_THROUGH**, indicating that the
entire media can be played without interruption, assuming the download rate
remains at least at the current level.
### dataunavailable
Sent when the ready state changes to **DATA_UNAVAILABLE**.
### durationchange
The meta data has loaded or changed, indicating a change in duration of the media.
This is sent, for example, when the media has loaded enough data that the
duration is known.
### emptied
The media has become empty; for example, this event is sent if the media has
already been loaded (or partially loaded), and the load() method is called
to reload it.
### empty
Sent when an error occurs and the media is empty.
### ended
Sent when playback completes.
### error
Sent when an error occurs. The element's error attribute contains more information.
### sourceerror
Sent when an error occurs with the source.
### loadeddata
The first frame of the media has finished loading.
```
mySound.bind("loadeddata", function () {
document.getElementById("loading").style.display = "none";
});
```
### loadedmetadata
The media's meta data has finished loading; all attributes now contain as much
useful information as they're going to.
### loadstart
Sent when loading of the media begins.
```
mySound.bind("loadstart", function () {
document.getElementById("loading").style.display = "block";
});
```
### pause
Sent when playback is paused.
### play
Sent when playback of the media starts after having been paused; that is, when
playback is resumed after a prior pause event.
### playing
Sent when the media begins to play (either for the first time, after having been
paused, or after ending and then restarting).
### progress
Sent periodically to inform interested parties of progress downloading the media.
Information about the current amount of the media that has been downloaded is
available in the media element's buffered attribute.
### ratechange
Sent when the playback speed changes.
### seeked
Sent when a seek operation completes.
### seeking
Sent when a seek operation begins.
### suspend
Sent when loading of the media is suspended; this may happen either because the
download has completed or because it has been paused for any other reason.
### timeupdate
The time indicated by the element's currentTime attribute has changed.
```
mySound.bind("timeupdate", function () {
var timer = buzz.toTimer(this.getTime());
document.getElementById("timer") .innerHTML = timer;
});
```
### volumechange
Sent when the audio volume changes (both when the volume is set and when the
muted attribute is changed).
```
mySound.bind("volumechange", function () {
document.getElementById("timer").innerHTML = this.getVolume();
});
```
### waiting
Sent when the requested operation (such as playback) is delayed pending the
completion of another operation (such as a seek).