1
0
mirror of https://github.com/videojs/video.js.git synced 2025-01-21 11:02:08 +02:00
video.js/compare/compare.js

70 lines
2.7 KiB
JavaScript
Raw Normal View History

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,
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
_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") {
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);
};
});