2016-05-04 09:15:21 +02:00
# Video Tracks
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
> **Note:** While video tracks [are a standard][spec-videotrack], there are no compatible implementations at this time. This is an experimental technology!
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
Video tracks are a feature of HTML5 video for providing alternate video tracks to the user, so they can change the type of video they want to watch. Video.js offers a cross-browser implementation of video tracks.
2016-05-04 09:15:21 +02:00
2016-12-20 16:55:59 -05:00
## Table of Contents
* [Caveats ](#caveats )
* [Working with Video Tracks ](#working-with-video-tracks )
* [Add a Video Track to the Player ](#add-a-video-track-to-the-player )
* [Listen for a Video Track Becoming Enabled ](#listen-for-a-video-track-becoming-enabled )
* [Removing an Video Track from the Player ](#removing-an-video-track-from-the-player )
* [API ](#api )
* [videojs.VideoTrack ](#videojsvideotrack )
* [id ](#id )
* [kind ](#kind )
* [label ](#label )
* [language ](#language )
* [selected ](#selected )
2016-12-02 14:27:59 -05:00
## Caveats
2016-12-20 16:55:59 -05:00
* It is not possible to add video tracks through HTML like you can with text tracks. They must be added programmatically.
* Video.js only stores track representations. Switching video tracks for playback is _not handled by Video.js_ and must be handled elsewhere.
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
## Working with Video Tracks
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
### Add a Video 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.VideoTrack({
id: 'my-alternate-video-track',
kind: 'commentary',
label: 'Director\'s Commentary',
language: 'en'
});
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
// Add the track to the player's video track list.
player.videoTracks().addTrack(track);
```
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
### Listen for a Video Track Becoming Enabled
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
When a track is enabled or disabled on an `VideoTrackList` , a `change` event will be fired. You can listen for that event and do something with it.
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
> NOTE: The initial `VideoTrack` selection (usually the main track that is selected) should not fire a `change` event.
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
```js
// Get the current player's VideoTrackList object.
var videoTrackList = player.videoTracks();
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
// Listen to the "change" event.
videoTrackList.addEventListener('change', function() {
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
// Log the currently enabled VideoTrack label.
for (var i = 0; i < videoTrackList.length ; i + + ) {
var track = videoTrackList[i];
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
if (track.enabled) {
videojs.log(track.label);
return;
}
}
});
```
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
### Removing an Video Track from the Player
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
Assuming a player already exists and has an video track that you want to remove, you might do something like the following:
2016-05-04 09:15:21 +02:00
```js
2016-12-02 14:27:59 -05:00
// Get the track we created in an earlier example.
var track = player.videoTracks().getTrackById('my-alternate-video-track');
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
// Remove it from the video track list.
player.videoTracks().removeTrack(track);
2016-05-04 09:15:21 +02:00
```
## API
2016-12-20 16:55:59 -05:00
2018-08-10 15:13:32 -04:00
For more complete information, refer to the [Video.js API docs ](https://docs.videojs.com/ ), specifically:
2016-12-02 14:27:59 -05:00
2016-12-20 16:55:59 -05:00
* `Player#videoTracks`
* `VideoTrackList`
* `VideoTrack`
2016-12-02 14:27:59 -05:00
### `videojs.VideoTrack`
2016-12-20 16:55:59 -05:00
2016-12-02 14:27:59 -05:00
This class is based on [the `VideoTrack` standard][spec-videotrack] and can be used to create new video track objects.
Each property below is available as an option to the `VideoTrack` 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-videotrack-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-videotrack-kind)
Video.js supports standard `kind` values for `VideoTracks` :
2016-12-20 16:55:59 -05:00
* `"alternative"` : A possible alternative to the main track.
* `"captions"` : The main video track with burned in captions
* `"main"` : The main video track.
* `"sign"` : The main video track with added sign language overlay.
* `"subtitles"` : The main video track with burned in subtitles.
* `"commentary"` : The main video track with burned in 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-videotrack-label)
The label for the track that will be shown to the user. For example, in a menu that lists the different captions available as alternate video tracks.
#### `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-videotrack-language)
The valid [BCP 47 ](https://tools.ietf.org/html/bcp47 ) code for the language of the video track, e.g. `"en"` for English or `"es"` for Spanish.
2021-01-19 17:41:39 -05:00
For supported language translations, please see the [languages folder (/lang) ](https://github.com/videojs/video.js/tree/main/lang ) folder located in the Video.js root and refer to the [languages guide ](/docs/guides/languages.md ) for more information on languages in Video.js.
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
#### `selected`
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-videotrack-selected)
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
Whether or not this track should be playing. Only one video track may be selected at a time.
2016-05-04 09:15:21 +02:00
2016-12-02 14:27:59 -05:00
[spec-videotrack]: https://html.spec.whatwg.org/multipage/embedded-content.html#videotrack