2016-05-04 09:15:21 +02:00
|
|
|
# Audio Tracks
|
2016-12-20 16:55:59 -05:00
|
|
|
|
|
|
|
Audio tracks are a feature of HTML5 video for providing alternate audio track selections
|
|
|
|
to the user, so that a track other than the main track can be played. Video.js offers a
|
|
|
|
cross-browser implementation of audio tracks.
|
|
|
|
|
|
|
|
## Table of Contents
|
|
|
|
|
|
|
|
* [Caveats](#caveats)
|
|
|
|
* [Working with Audio Tracks](#working-with-audio-tracks)
|
|
|
|
* [Add an Audio Track to the Player](#add-an-audio-track-to-the-player)
|
2019-06-20 14:31:21 -04:00
|
|
|
* [Listen for an Audio Track Becoming Enabled](#listen-for-an-audio-track-becoming-enabled)
|
2016-12-20 16:55:59 -05:00
|
|
|
* [Removing an Audio Track from the Player](#removing-an-audio-track-from-the-player)
|
|
|
|
* [API](#api)
|
|
|
|
* [videojs.AudioTrack](#videojsaudiotrack)
|
|
|
|
* [id](#id)
|
|
|
|
* [kind](#kind)
|
|
|
|
* [label](#label)
|
|
|
|
* [language](#language)
|
|
|
|
* [enabled](#enabled)
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
## Caveats
|
2016-12-20 16:55:59 -05:00
|
|
|
|
|
|
|
* It is not possible to add audio tracks through HTML like you can with text tracks.
|
|
|
|
They must be added programmatically.
|
|
|
|
* Video.js only stores track representations. Switching audio tracks for playback is
|
|
|
|
_not handled by Video.js_ and must be handled elsewhere - for example,
|
2017-03-21 17:13:06 -04:00
|
|
|
[videojs-contrib-hls][hls] handles switching
|
2016-12-20 16:55:59 -05:00
|
|
|
audio tracks to support track selection through the UI.
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
## Working with Audio Tracks
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
### Add an Audio Track to the Player
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
```js
|
|
|
|
// Create a player.
|
|
|
|
var player = videojs('my-player');
|
|
|
|
|
|
|
|
// Create a track object.
|
|
|
|
var track = new videojs.AudioTrack({
|
|
|
|
id: 'my-spanish-audio-track',
|
|
|
|
kind: 'translation',
|
|
|
|
label: 'Spanish',
|
|
|
|
language: 'es'
|
|
|
|
});
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
// Add the track to the player's audio track list.
|
|
|
|
player.audioTracks().addTrack(track);
|
|
|
|
```
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2019-02-22 13:46:53 -05:00
|
|
|
### Listen for an Audio Track Becoming Enabled
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
When a track is enabled or disabled on an `AudioTrackList`, a `change` event will be
|
|
|
|
fired. You can listen for that event and do something with it.
|
|
|
|
|
|
|
|
> NOTE: The initial `AudioTrack` selection (usually the main track that is selected)
|
|
|
|
> should not fire a `change` event.
|
2016-05-04 09:15:21 +02:00
|
|
|
|
|
|
|
```js
|
2016-12-02 14:27:59 -05:00
|
|
|
// Get the current player's AudioTrackList object.
|
|
|
|
var audioTrackList = player.audioTracks();
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
// Listen to the "change" event.
|
|
|
|
audioTrackList.addEventListener('change', function() {
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
// Log the currently enabled AudioTrack label.
|
|
|
|
for (var i = 0; i < audioTrackList.length; i++) {
|
|
|
|
var track = audioTrackList[i];
|
2016-05-04 09:15:21 +02:00
|
|
|
|
|
|
|
if (track.enabled) {
|
2016-12-02 14:27:59 -05:00
|
|
|
videojs.log(track.label);
|
2016-05-04 09:15:21 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
```
|
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
### Removing an Audio Track from the Player
|
2016-12-20 16:55:59 -05:00
|
|
|
|
|
|
|
Assuming a player already exists and has an audio track that you want to remove, you
|
|
|
|
might do something like the following:
|
2016-12-02 14:27:59 -05:00
|
|
|
|
|
|
|
```js
|
|
|
|
// Get the track we created in an earlier example.
|
|
|
|
var track = player.audioTracks().getTrackById('my-spanish-audio-track');
|
|
|
|
|
|
|
|
// Remove it from the audio track list.
|
|
|
|
player.audioTracks().removeTrack(track);
|
|
|
|
```
|
|
|
|
|
2016-05-04 09:15:21 +02:00
|
|
|
## API
|
2016-12-02 14:27:59 -05:00
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
For more complete information, refer to the
|
2018-08-10 15:13:32 -04:00
|
|
|
[Video.js API docs](https://docs.videojs.com/), specifically:
|
2016-12-20 16:55:59 -05:00
|
|
|
|
|
|
|
* `Player#audioTracks`
|
|
|
|
* `AudioTrackList`
|
|
|
|
* `AudioTrack`
|
2016-12-02 14:27:59 -05:00
|
|
|
|
|
|
|
### `videojs.AudioTrack`
|
2016-12-20 16:55:59 -05:00
|
|
|
|
|
|
|
This class is based on [the `AudioTrack` standard][spec-audiotrack] and can be used to
|
|
|
|
create new audio track objects.
|
2016-12-02 14:27:59 -05:00
|
|
|
|
|
|
|
Each property below is available as an option to the `AudioTrack` constructor.
|
|
|
|
|
|
|
|
#### `id`
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
> [standard definition](https://html.spec.whatwg.org/multipage/embedded-content.html#dom-audiotrack-id)
|
|
|
|
|
|
|
|
A unique identifier for this track. Video.js will generate one if not given.
|
|
|
|
|
|
|
|
#### `kind`
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
> [standard definition](https://html.spec.whatwg.org/multipage/embedded-content.html#dom-audiotrack-kind)
|
|
|
|
|
|
|
|
Video.js supports standard `kind` values for `AudioTracks`:
|
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
* `"alternative"`: A possible alternative to the main track.
|
|
|
|
* `"descriptions"`: An audio description of a video track.
|
|
|
|
* `"main"`: The primary audio track for this video.
|
|
|
|
* `"main-desc"`: The primary audio track, mixed with audio descriptions.
|
|
|
|
* `"translation"`: A translated version of the main audio track.
|
|
|
|
* `"commentary"`: Commentary on the primary audio track, e.g. a director's commentary.
|
|
|
|
* `""` (default): No explicit kind, or the kind given by the track's metadata is not
|
|
|
|
recognized by the user agent.
|
2016-12-02 14:27:59 -05:00
|
|
|
|
|
|
|
#### `label`
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
> [standard definition](https://html.spec.whatwg.org/multipage/embedded-content.html#dom-audiotrack-label)
|
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
The label for the track that will be shown to the user. For example, in a menu that lists
|
|
|
|
the different languages available as alternate audio tracks.
|
2016-12-02 14:27:59 -05:00
|
|
|
|
|
|
|
#### `language`
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
> [standard definition](https://html.spec.whatwg.org/multipage/embedded-content.html#dom-audiotrack-language)
|
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
The valid [BCP 47](https://tools.ietf.org/html/bcp47) code for the language of the audio
|
|
|
|
track, e.g. `"en"` for English or `"es"` for Spanish.
|
2016-12-02 14:27:59 -05:00
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
For supported language translations, please see the [languages folder (/lang)](https://github.com/videojs/video.js/tree/master/lang)
|
2017-03-21 17:13:06 -04:00
|
|
|
located in the Video.js root and refer to the [languages guide][languages-guide] for more
|
2016-12-20 16:55:59 -05:00
|
|
|
information on languages in Video.js.
|
2016-12-02 14:27:59 -05:00
|
|
|
|
|
|
|
#### `enabled`
|
2016-12-20 16:55:59 -05:00
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
> [standard definition](https://html.spec.whatwg.org/multipage/embedded-content.html#dom-audiotrack-enabled)
|
|
|
|
|
|
|
|
Whether or not this track should be playing.
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2016-12-20 16:55:59 -05:00
|
|
|
In Video.js, we only allow one track to be enabled at a time; so, if you enable more
|
|
|
|
than one, the last one to be enabled will end up being the only one. While the spec
|
|
|
|
allows for more than one track to be enabled, Safari and most implementations only allow
|
|
|
|
one audio track to be enabled at a time.
|
2016-05-04 09:15:21 +02:00
|
|
|
|
2017-03-21 17:13:06 -04:00
|
|
|
[languages-guide]: /docs/guides/languages.md
|
|
|
|
|
2016-12-02 14:27:59 -05:00
|
|
|
[spec-audiotrack]: https://html.spec.whatwg.org/multipage/embedded-content.html#audiotrack
|
2017-03-21 17:13:06 -04:00
|
|
|
|
2018-08-10 15:13:32 -04:00
|
|
|
[hls]: https://github.com/videojs/videojs-contrib-hls
|