Files
shaka-player/demo/configuration_section.js
T
Joey Parrish 1f9818a093 Demo controls v2
This is a reimplementation of v1's demo controls for v2.

Improvements over v1:
 - more organized JavaScript
 - no more asset images for buttons
 - uses material design icons via woff font
 - allows play/pause by clicking video
 - includes CC button
 - better styling on IE & Edge
 - Google-esque buffering spinner
 - hides pointer when mouse stops moving in fullscreen

Not yet implemented:
 - Chromecast support

Closes #322, #328

Change-Id: Ic97254d2251582a3f456ab8e1e2bf406a3ab25e3
2016-04-12 23:34:21 +00:00

73 lines
2.0 KiB
JavaScript

/**
* @license
* Copyright 2016 Google Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/** @suppress {duplicate} */
var shakaDemo = shakaDemo || {};
/** @private */
shakaDemo.setupConfiguration_ = function() {
document.getElementById('preferredAudioLanguage').addEventListener(
'keyup', shakaDemo.onConfigKeyUp_);
document.getElementById('preferredTextLanguage').addEventListener(
'keyup', shakaDemo.onConfigKeyUp_);
document.getElementById('showTrickPlay').addEventListener(
'change', shakaDemo.onTrickPlayChange_);
document.getElementById('enableAdaptation').addEventListener(
'change', shakaDemo.onAdaptationChange_);
};
/**
* @param {!Event} event
* @private
*/
shakaDemo.onConfigKeyUp_ = function(event) {
// Update the configuration if the user presses enter.
if (event.keyCode != 13) return;
shakaDemo.player_.configure(/** @type {shakaExtern.PlayerConfiguration} */({
preferredAudioLanguage:
document.getElementById('preferredAudioLanguage').value,
preferredTextLanguage:
document.getElementById('preferredTextLanguage').value
}));
};
/**
* @param {!Event} event
* @private
*/
shakaDemo.onAdaptationChange_ = function(event) {
// Update adaptation config.
shakaDemo.player_.configure(/** @type {shakaExtern.PlayerConfiguration} */({
abr: { enabled: event.target.checked }
}));
};
/**
* @param {!Event} event
* @private
*/
shakaDemo.onTrickPlayChange_ = function(event) {
// Show/hide trick play controls.
shakaDemo.controls_.showTrickPlay(event.target.checked);
};