Getting Started with Brightcove Web & Smart TV SDK
Installing the SDK
You can install the Brightcove Web & Smart TV SDK using npm or directly from the Brightcove CDN.
Using npm:
Open your command line interface and run the following command to install the SDK:
npm install @brightcove/web-sdk
After installation, you can import the SDK using your preferred module system:
CommonJS
const { Player } = require('@brightcove/web-sdk');
ES Module
import { Player } from '@brightcove/web-sdk';
Using CDN
Alternatively, if you prefer to use the SDK from the CDN, include one of the following script tags in your HTML files:
CommonJS
<script src="https://players.brightcove.net/sdk/v1/web-sdk/playback/index.cjs.js"></script>
ES Module
<script type="module" src="https://players.brightcove.net/sdk/v1/web-sdk/playback/index.es.js"></script>
IIFE (Immediately Invoked Function Expression)
<script src="https://players.brightcove.net/sdk/v1/web-sdk/playback/index.iife.min.js"></script>
Specifying a Version
To specify a version in the CDN URL:
- Use
v{major}
to include the latest patch within a major version. - Use
v{major}
.{minor}
to include the latest patch within a minor version. - Use
v{major}
.{minor}
.{patch}
to include a specific version.
For example
<script src="https://players.brightcove.net/sdk/v1/web-sdk/playback/index.iife.min.js"></script>
<script src="https://players.brightcove.net/sdk/v1.1/web-sdk/playback/index.iife.min.js"></script>
<script src="https://players.brightcove.net/sdk/v1.1.1/web-sdk/playback/index.iife.min.js"></script>
Import the Player
Playback-Only
For applications that only require playback functionality, and no additional UI features:
import { Player } from '@brightcove/web-sdk/playback';
Playback with UI
For applications that need playback functionality along with a UI, use the following player entry point:
import { Player } from '@brightcove/web-sdk/ui';
import '@brightcove/web-sdk/ui/styles';
Initializing the Player
Once the SDK is installed, you can create a media player to embed in your application. By following these steps, you will have a basic video player set up using the Brightcove Web & Smart TV SDK.
-
Initialize the Player: Set up the player with your Brightcove account details:
const player = new Player({ // Account ID parameter is required to initialize a player accountId: '<ACCOUNT_ID>', });
-
Attach the player to a mount root (DOM element in the page):
const root = document.querySelector('#player-mount-root'); player.attach(root);
-
Dynamically update params in the player configuration:
player.updateConfiguration({ brightcove: { policyKey: '<POLICY_KEY>' }, ui: { language: 'en', playsinline: false } });
Loading Media
Video Cloud VOD
Load media into your project by following these steps:
Initialize the Player: Create a new instance of the Player.
const player = new Player({accountId: '<ACCOUNT_ID>'}); player.updateConfiguration({ brightcove: { policyKey: '<POLICY_KEY>' }, });
Create a Function to Load Video: Define an asynchronous function to load video metadata using the video ID.
async function loadVideo(videoId) { // you can abort a request by calling abort() const { abort, promise } = player.getVideoByIdFromPlaybackApi({ videoId: '<VIDEO_ID>' }); try { let brightcoveVideoModel = await promise; player.loadBrightcoveVideoModel(brightcoveVideoModel); } catch (error) { console.error('Error loading video:', error); } }
Call the loadVideo function with your specific video ID to load the video into the player.
loadVideo('<VIDEO_ID>');
Video Cloud Playlist
Integrate playlists into your project by following these steps:
Initialize the Player: Create a new instance of the Player.
const player = new Player({accountId: '<ACCOUNT_ID>'}); player.updateConfiguration({ brightcove: { policyKey: '<POLICY_KEY>' }, });
Create a Function to Load Playlist: Define an asynchronous function to load a playlist using the playlist ID.
async function loadPlaylist(playlistId) { // you can abort request by calling abort() const { abort, promise } = player.getPlaylistByIdFromPlaybackApi({ playlistId }); try { const playlistModel = await promise; const playlistManager = player.getPlaylistManager(); // Create playlist object const playlist = playlistManager.createPlaylistFromBrightcoveVideoModels(playlistModel.videos); // Pass the playlist object to the PlaylistManager playlistManager.setPlaylist(playlist); // Load the first playlist item player.loadBrightcoveVideoModel(playlist.getCurrentItem()); } catch (error) { console.error('Error loading playlist:', error); } }
Call the loadPlaylist function with your specific playlist ID to load the playlist into the player.
loadPlaylist('<PLAYLIST_ID>');
Create a function to advance to the next item.
function advanceToNextItem() { const playlistManager = player.getPlaylistManager(); const playlist = playlistManager.getPlaylist(); // Advance to the next item playlist.moveToNext(); player.loadBrightcoveVideoModel(playlist.getCurrentItem()); } advanceToNextItem();
Remote Source
Integrate a remote source into your project by following these steps:
Initialize the Player: Create a new instance of the Player.
const player = new Player({ // accountId is still required even when loading remote media accountId: '<ACCOUNT_ID>', });
Define the Remote Video Source: Define the remote video source URL.
const source = { url: 'https:' };
Load the Remote Video: Load the remote video source.
player.loadRemoteVideo(source);
IntegrationsManager
The IntegrationsManager
class is designed to manage various integrations within the SDK, such as pinning, thumbnails, IMA ads, and more. It allows you to register, deregister, and access different integration factories, providing a flexible way to enhance your video player with additional features. See Interface IntegrationsManager for more information.
Example Usage
Below is an example of how to use the IntegrationsManager
to register integrations and use them within your Player instance.
Import Necessary Modules: Import the required modules from the SDK.
import { Player, IntegrationsManager } from '@brightcove/web-sdk'; import { PinningIntegrationFactory } from '@brightcove/web-sdk/integrations/pinning'; import { ThumbnailsIntegrationFactory } from '@brightcove/web-sdk/integrations/thumbnails'; import '@brightcove/web-sdk/ui/styles'; import '@brightcove/web-sdk/integrations/pinning/styles'; import '@brightcove/web-sdk/integrations/thumbnails/styles';
Register Integrations: Register the integrations before creating the player instance.
IntegrationsManager.registerPinningIntegrationFactory(PinningIntegrationFactory); IntegrationsManager.registerThumbnailsIntegrationFactory(ThumbnailsIntegrationFactory);
Initialize the Player with Integrations: Create a new instance of the Player and include the integrations with their configuration options.
const player = new Player({accountId: '<ACCOUNT_ID>'}); player.updateConfiguration({ // Integrations can have their own configuration options integrations: { pinning: { posX: 'left', posY: 'top', closeable: true } } });
Attach the Player to the DOM: Specify the DOM element where the player should be attached.
const root = document.querySelector('#player-mount-root'); player.attach(root);
Access Individual Integrations: Use the
IntegrationsManager
to access and control specific integrations.const { pinningIntegration } = player.getIntegrationsManager();
Perform Integration-Specific Operations provided by the integration.
pinningIntegration.togglePinning();
NetworkingManager
The NetworkingManager
is used to hook into the SDK's request/response cycle and allows you to intercept and manipulate network requests and responses the player makes, enabling a wide range of custom behaviors and optimizations.
The NetworkingManager
provides two main functionalities:
Request Interceptors: These allow you to intercept and modify outgoing requests before they are sent to the server.
Response Interceptors: These allow you to intercept and modify incoming responses before they are processed by the player.
To use the NetworkingManager follow these steps:
Initialize the
NetworkingManager
const networkingManager = player.getNetworkingManager();
Add a Request Interceptor: Add a request interceptor to modify or log the outgoing requests.
networkingManager.addRequestInterceptor(Player.RequestType.HlsPlaylist, (request) => { console.log('HLS Playlist request interceptor', request); return request; });
Add a Response Interceptor: Add a response interceptor to modify or log the incoming responses.
networkingManager.addResponseInterceptor(Player.RequestType.HlsPlaylist, (response) => { console.log('HLS Playlist response interceptor', response); return response; });
UiManager
The UiManager
creates and manages UI Components. All SDK UI Components extend the UiComponent
class, which has an extensive API.
See the UiComponentDependencies interface for the basic list of options that can be passed to components.
Overriding Default Components
Modify existing components to better suit your application's needs.
Import Required Modules
import { UiManager, BigPlayButtonUiComponent, UiComponentType } from '@brightcove/web-sdk/ui';
Create a Custom UI Component
class CustomPlayButton extends BigPlayButtonUiComponent { // ... custom play button code }
Override the Default Component: override the default
BigPlayButton
with theCustomPlayButton
UiManager.overrideDefaultComponent(UiComponentType.BigPlayButton, CustomPlayButton);
Custom Components
By using the BaseUiComponent class, you can add unique features and tailor the player interface to better fit your application requirements.
To apply Custom Components following these steps:
Import
BaseUiComponent
:import { BaseUiComponent } from '@brightcove/web-sdk/ui';
Initialize UI Manager and Player Component:
const uiManager = player.getUiManager(); const playerComponent = uiManager.getPlayerContainerUiComponent();
Create a DOM element:
const customElement = document.createElement('div');
Create a new custom UI component:
const customComponent = new BaseUiComponent({ // Add a unique name name: 'CustomUiComponent', componentOptions: { // Pass the custom DOM element as an option el: customElement, }, });
Add the Custom Component to the Player:
playerComponent.addChild(customComponent);
(Optional) Add the Custom Component to Another Component : (for example the ControlBar)
const controlBarComponent = playerComponent.getChild('controlBar'); controlBarComponent.addChild(customComponent);
PlaylistManager
The PlaylistManager
provides methods for creating playlists, managing the current playing item, and navigating through the playlist items.
To use the PlaylistManager follow these steps:
Initialize PlaylistManager:
const playlistManager = player.getPlaylistManager();
Create a Playlist from a Playback API Response:
const videoCloudPlaylist = playlistManager.createPlaylistFromBrightcoveVideoModels( /* Array<BrightcoveVideoModel> */ );
Create a Playlist from Remote Sources: Alternatively, create a playlist using remote media sources.
const remotePlaylist = playlistManager.createPlaylistFromRemoteSources( /* Array<Source> */ );
Set the Playlist in the PlaylistManager:
playlistManager.setPlaylist(/* videoCloudPlaylist | remotePlaylist */);
Load the First Playlist Item:
player.loadBrightcoveVideoModel(playlist.getCurrentItem());
Navigate Through the Playlist: Use the next methods to navigate through the playlist items.
Move to the next item:
playlist.moveToNext();
Move to the previous item:
playlist.moveToPrevious();
Move to a specific item:
playlist.moveTo(/* index number */);
Shuffle the playlist:
playlist.shuffle();
Load the new current item: Load the newly selected item in the playlist.
player.loadBrightcoveVideoModel(playlist.getCurrentItem());
Events
To handle events, add or remove event listeners follow these steps:
Handle the First Emission of an Event: If you want to handle only the first occurrence of an event, use the
once
method.player.once(Player.Event.PlayerPlaying, (event) => { console.log('PlayerPlaying event: ', event); });
Handle Every Emission of an Event: To handle every emission of an event, use the
addEventListener
method. Below is an example of handling thePlayerQualityLevelsChanged
event:// Define the event handler function const handlePlayerQualityLevelsChanged = (event) => { console.log('PlayerQualityLevelsChanged event: ', event); }; // Handle every emission of the PlayerQualityLevelsChanged event player.addEventListener(Player.Event.PlayerQualityLevelsChanged, handlePlayerQualityLevelsChanged);
Remove Specific Event Listeners: To remove a specific event listener, use the
removeEventListener
method.player.removeEventListener(Player.Event.PlayerQualityLevelsChanged, handlePlayerQualityLevelsChanged);
Remove All Listeners for a Specific Event: To remove all listeners for a specific event, use the
removeAllEventListenersForType
method.player.removeAllEventListenersForType(Player.Event.PlayerQualityLevelsChanged);
Remove All Event Listeners: To remove all event listeners for all events, use the
removeAllEventListeners
method:player.removeAllEventListeners();
Errors
To listen for error events and check the player's current error state, follow these steps:
Listening for Error Events:
this.player.addEventListener(Player.Event.PlayerError, (event) => { const error = event.error; console.log('An error occurred:', error); });
Styling
To apply CSS for UI features follow these steps:
Import the Player Class:
import Player from '@brightcove/web-sdk/ui';
Import the CSS for the Player Class:
import '@brightcove/web-sdk/ui/styles';
Importing Integration-Specific Styles: you must import the styles specific to that integration from
@brightcove/web-sdk/integrations/<integration-name>/styles
If you are integrating with a specific feature likepinning
, follow this pattern:import '@brightcove/web-sdk/integrations/pinning/styles';
CSS Variables
The CSS from @brightcove/web-sdk/ui/styles
comes with a set of preset CSS variables to control certain aspects of the player's styling. These CSS variables can be overridden by resetting the value.
.bc-sdk {
/* Override the default control bar color */
--bc-sdk-control-bar-color: red;
}
The following are the available CSS variables, along with their default values:
Variable | Default Value | Description |
---|---|---|
--bc-sdk-control-color |
#fff | The color of buttons and text. |
--bc-sdk-progress-color |
#80888c | The color of the progress bar. |
--bc-sdk-control-bar-transparency |
0.45 | The transparency of the background color of the control bar and the big play button. |
--bc-sdk-control-bar-color |
rgba(0, 0, 0, var(--bc-sdk-control-bar-transparency)) | The background color of the control bar and the big play button. |
--bc-sdk-big-play-button--border |
none | The border of the big play button. |
--bc-sdk-big-play-button--width |
2em | The width of the big play button. |
--bc-sdk-big-play-button--height |
2em | The height of the big play button. |
Spatial Navigation
spatialNavigation
enhances user experience and accessibility on Smart TV devices by enabling navigation through interactive elements within the player using remote control arrow keys.
Enable Spatial Navigation
Import the required Player class and associated styles.
import { Player } from '@brightcove/web-sdk/ui'; import '@brightcove/web-sdk/styles';
Initialize a UI-enabled player for Spatial Navigation.
const player = new Player({ accountId: '<ACCOUNT_ID>' }); player.updateConfiguration({ ui: { spatialNavigation: { // Enable Spatial Navigation enabled: true, // Enable horizontal navigation seek functionality, using right and left RCU arrow keys. horizontalSeek: true, } } });
Retrieve the Spatial Navigation Manager.
const spatialNavigationManager = player.getSpatialNavigationManager();
Manage Spatial Navigation Events. The SpatialNavigationManager allows you to start, pause, resume, and stop listening for keydown events.
// Start listening for keydown events spatialNavigationManager.start(); // Pause listening for keydown events without removing listeners spatialNavigationManager.pause(); // Resume listening for keydown events after pausing spatialNavigationManager.resume(); // Disable Spatial Navigation by removing all keydown listeners spatialNavigationManager.stop();
Spatial Navigation Events
The Web & Smart TV SDK provides two key events for spatial navigation:
Player.Event.SpatialNavigation.EndOfFocusableComponents
: Fired when there are no more focusable components available in the specified direction within the player interface.Player.Event.SpatialNavigation.FocusableComponentsChanged
: Fired when the list of focusable components changes.
Localizations
Localization is a crucial aspect of developing a user-friendly video player that meets the needs of a diverse, global audience.
Support for multiple languages and localizations can be included as follows:
Import general player localizations:
import mainJapanese from '@brightcove/web-sdk/ui/languagePacks/ja';
Import integration-specific localizations:
import ssaiJapanese from '@brightcove/web-sdk/integrations/ssai/languagePacks/ja';
Initialize the UI Manager:
const uiManager = player.getUiManager();
Add the Language Pack to the UI Manager: Use the
addLanguagePack
method of the UI manager to add the imported language pack:uiManager.addLanguagePack('ja', mainJapanese); uiManager.addLanguagePack('ja', ssaiJapanese);
Sample Implementations
To help you quickly get up to speed with the Brightcove Web & Smart TV SDK, we offer several sample implementations. These examples demonstrate various features and use cases, providing a hands-on way to learn how to use the SDK effectively.
Explore a variety of sample implementations by visiting the following links:
Preset Video Cloud Media: