Created
August 5, 2013 15:39
-
-
Save mboles/6156908 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
<!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