2011-12-07 21:41:28 -08:00
|
|
|
_V_.options.flash.swf = "../flash/video-js.swf";
|
2012-01-05 23:25:09 -08:00
|
|
|
_V_.options.flash.swf = "http://andylemay.com/dev/videojs/VideoJS.swf";
|
2011-12-07 16:44:21 -08:00
|
|
|
|
|
|
|
$(function(){
|
|
|
|
var tech, i, tname, player,
|
2011-12-07 21:03:12 -08:00
|
|
|
techList = ["html5","flash"],
|
2011-11-21 17:19:31 -08:00
|
|
|
props = "error,currentSrc,networkState,buffered,readyState,seeking,initialTime,duration,startOffsetTime,paused,played,seekable,ended,videoWidth,videoHeight,textTracks,preload,currentTime,defaultPlaybackRate,playbackRate,autoplay,loop,controls,volume,muted,defaultMuted,poster".split(","),
|
2011-09-30 17:28:43 -07:00
|
|
|
methods = "play,pause,src,load,canPlayType,addTextTrack",
|
|
|
|
notUsed = "mediaGroup,controller,videoTracks,audioTracks,defaultPlaybackRate";
|
|
|
|
|
|
|
|
for (i=0; i < techList.length; i++) {
|
|
|
|
tech = techList[i];
|
2011-12-07 16:44:21 -08:00
|
|
|
tname = tech.toLowerCase();
|
2011-09-30 17:28:43 -07:00
|
|
|
|
2011-12-07 16:44:21 -08:00
|
|
|
player = _V_("vid"+(i+1), { "techOrder":[tech] });
|
2011-09-30 17:28:43 -07:00
|
|
|
|
2011-12-07 21:03:12 -08:00
|
|
|
_V_.each(_V_.html5.events, function(evt){
|
2011-12-07 16:44:21 -08:00
|
|
|
|
|
|
|
player.addEvent(evt, _V_.proxy(tname, function(evt){
|
2011-09-30 17:28:43 -07:00
|
|
|
var eventsId = "#"+this+"_events",
|
|
|
|
type = evt.type,
|
|
|
|
prev = $(eventsId+" div").first();
|
|
|
|
|
|
|
|
if (prev && prev.html() && prev.html().indexOf(type + " ") === 0) {
|
|
|
|
var countSpan = prev.children(".count");
|
|
|
|
countSpan.html(parseInt(countSpan.html() || 1) + 1);
|
|
|
|
} else {
|
|
|
|
$("#"+this+"_events").prepend("<div>" + evt.type + " <span class='count'></span></div>");
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
});
|
|
|
|
|
2011-12-07 16:44:21 -08:00
|
|
|
var propTable = $("#"+tname+"_props");
|
2011-09-30 17:28:43 -07:00
|
|
|
_V_.each(props, function(prop){
|
2011-12-07 16:44:21 -08:00
|
|
|
propTable.append("<tr><th>"+prop+"</th><td id='"+tname+prop+"' class='data'></td></tr>")
|
2011-09-30 17:28:43 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
setInterval(_V_.proxy(player, function(){
|
|
|
|
_V_.each(props, _V_.proxy(this, function(prop){
|
|
|
|
var result = ""
|
|
|
|
try {
|
|
|
|
result = this[prop]();
|
|
|
|
if (result === false) result = "false";
|
|
|
|
if (result === true) result = "true";
|
|
|
|
if (result === "") result = "''";
|
|
|
|
if (result === null) result = "<span class='undefined'>null</span>";
|
|
|
|
if (result === undefined) result = "<span class='undefined'>undefined</span>";
|
|
|
|
if (typeof result.start == "function") {
|
2011-12-08 17:33:44 -08:00
|
|
|
var newResult = "", i;
|
|
|
|
if (result.length > 0) {
|
|
|
|
|
|
|
|
for (i=0;i<result.length;i++) {
|
|
|
|
newResult += "l:"+result.length+" s:"+result.start(i)+" e:"+result.end(i);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
newResult = "-";
|
|
|
|
}
|
|
|
|
result = newResult;
|
|
|
|
// result = result.toString();
|
|
|
|
// result = (result.length > 0) ? "s:"+result.start(0)+" e:"+result.end(0) : "-";
|
2011-09-30 17:28:43 -07:00
|
|
|
}
|
|
|
|
} catch(e) {
|
|
|
|
result = "<span class='na'>N/A</span>";
|
|
|
|
}
|
2011-12-07 16:44:21 -08:00
|
|
|
$("#"+this.techName+prop).html(result);
|
2011-09-30 17:28:43 -07:00
|
|
|
}));
|
|
|
|
}), 500);
|
|
|
|
|
|
|
|
};
|
|
|
|
});
|