Skip to content

Instantly share code, notes, and snippets.

@mboles
Created August 5, 2013 15:39
Show Gist options
  • Save mboles/6156908 to your computer and use it in GitHub Desktop.
Save mboles/6156908 to your computer and use it in GitHub Desktop.
<!DOCTYPE html>
<html>
<head>
<style type="text/css">
#placeholder {
width:480px;
height:270px;
}
#overlay {
position:absolute;
z-index: 10;
width:480px;
height:270px;
background-color: #000;
text-align: center;
}
.BrightcoveExperience {
position: absolute;
}
#message {
color: #FFF;
padding: 20px;
text-transform: uppercase;
font-size: 2em;
}
</style>
</head>
<body>
<div id="placeholder">
<div id="overlay"> <!-- MESSAGE SHOWN BEFORE STREAM -->
<p id="message">Video is not yet live</p>
<img id="progress" src="" />
</div>
<!-- PLAYER WILL BE INSERTED HERE -->
</div>
<script type="text/javascript" src="http://admin.brightcove.com/js/BrightcoveExperiences.js"></script>
<script type="text/javascript">
if (typeof console == "undefined") {window.console = {log: function () {}};}
/* A proof of concept of having a banner displayed over the player until a live event starts.
Not tested for all possible situations nor supported by Brightcove
*/
var player,experienceModule,videoPlayer,
errorTime=0,
placeholderElem = document.getElementById("placeholder"),
overlayElem = document.getElementById("overlay"),
progressElem = document.getElementById("progress"),
messageElem = document.getElementById("message"),
retryTime = 10000;
// All "param" elements that will go into the player object
var playerConfig = {
"width": "480",
"height": "270",
"playerID": "1234567890",
"playerKey": "ABCDEFGHIJKLMNOPQRSTUVWXYZ",
"isVid": "true",
"isUI": "true",
"autoStart": "true",
"wmode": "transparent",
"@videoPlayer": "987654321",
"templateErrorHandler": "onTemplateError",
"includeAPI": "true",
"templateLoadHandler": "onTemplateLoaded",
"templateReadyHandler": "onTemplateReady"
};
function onTemplateLoaded(id) {
console.log("LOADED");
// Show the loading bar to give viewer feedback that we are checking if the stream is available
progressElem.style.visibility = "visible";
player = brightcove.api.getExperience(id);
videoPlayer = player.getModule(brightcove.api.modules.APIModules.VIDEO_PLAYER);
// Event listener so we know if the stream is successful
videoPlayer.addEventListener(brightcove.api.events.MediaEvent.BEGIN, onBegin);
}
function onTemplateReady(event) {
console.log("READY");
// We're not doing anything on ready, but we could be
}
function onTemplateError(event) {
// An error has occurred. This is either the stream not yet ready or a transient error.
console.log("ERROR");
console.log("Old: " + errorTime);
console.log("New: " + Date.now());
// If an error is fired very soon afterwards, ignore it
if (Date.now() - errorTime > 500) {
// In ten seconds, try again
console.log("ADD TIMEOUT FOR READDING PLAYER");
//window.setTimeout(addPlayer, 2000, playerConfig, placeholderElem); // Grrr IE doesn't send the parameters
window.setTimeout(function() {addPlayer(playerConfig, placeholderElem)}, retryTime);
// Remove the player.
console.log("REQUEST REMOVE");
window.setTimeout(removePlayer, 2); // Delay is for IE
// Remove the progress bar
console.log("HIDE SPINNER");
progressElem.style.visibility = "hidden";
} else {
console.log ("DOUBLE EVENT IGNORED");
}
errorTime = Date.now();
}
function onBegin(e) {
console.log("BEGIN");
// Playback has begun, remove the overlay
overlayElem.style.display = "none";
// If we get an error once playback starts (like an CDN server problem), we'd want to try reconnecting more quickly
retryTime = 1000;
// And the message shown will be different
messageElem.innerHTML = "Please wait";
// Set event handler for complete - when the stream is finished
videoPlayer.addEventListener(brightcove.api.events.MediaEvent.COMPLETE, onComplete);
}
function onComplete(e) {
console.log("COMPLETE");
// Playback has finished, show the overlay with a new message
progressElem.style.visibility = "hidden";
overlayElem.style.display = "block";
messageElem.innerHTML = "Thank you for watching";
}
function addPlayer(config,elem) {
console.log("ADD");
// Create an object element with the above player parameters
var playerObj = document.createElement("object");
playerObj.id = "myExperience";
playerObj.className = "BrightcoveExperience";
console.log(playerObj);
for (var param in config) {
var playerParam = document.createElement("param");
playerParam.setAttribute("name",param);
playerParam.setAttribute("value",config[param]);
console.log("ADD-APPEND PARAM TO OBJECT");
playerObj.appendChild(playerParam);
}
//console.log(JSON.stringify(playerObj));
// Create a new player appended to the "elem" element
console.log("ADD-CREATE EXPERIENCE");
brightcove.createExperience(playerObj,elem,true)
}
function removePlayer() {
// Remove the player
brightcove.removeExperience("myExperience");
}
// Add the player for the first time
addPlayer(playerConfig,placeholderElem);
</script>
</body>
</html>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment