Add wmode=transparent option

This commit is contained in:
calzoneman 2013-08-06 11:42:20 -04:00
parent b53ac91a61
commit 07249f3589
3 changed files with 86 additions and 70 deletions

View File

@ -103,6 +103,7 @@ var USEROPTS = {
modhat : getOrDefault("modhat", false), modhat : getOrDefault("modhat", false),
blink_title : getOrDefault("blink_title", false), blink_title : getOrDefault("blink_title", false),
sync_accuracy : getOrDefault("sync_accuracy", 2), sync_accuracy : getOrDefault("sync_accuracy", 2),
wmode_transparent : getOrDefault("wmode_transparent", true),
chatbtn : getOrDefault("chatbtn", false), chatbtn : getOrDefault("chatbtn", false),
altsocket : getOrDefault("altsocket", false), altsocket : getOrDefault("altsocket", false),
joinmessage : getOrDefault("joinmessage", true), joinmessage : getOrDefault("joinmessage", true),

View File

@ -22,9 +22,11 @@ function removeOld(replace) {
var YouTubePlayer = function (data) { var YouTubePlayer = function (data) {
var self = this; var self = this;
waitUntilDefined(window, "YT", function () { waitUntilDefined(window, "YT", function () {
waitUntilDefined(YT, "Player", function () {
removeOld(); removeOld();
self.paused = false; self.paused = false;
self.videoId = data.id; self.videoId = data.id;
var wmode = USEROPTS.wmode_transparent ? "transparent" : "opaque";
self.player = new YT.Player("ytapiplayer", { self.player = new YT.Player("ytapiplayer", {
height: VHEIGHT, height: VHEIGHT,
width: VWIDTH, width: VWIDTH,
@ -35,7 +37,8 @@ var YouTubePlayer = function (data) {
controls: 1, // Show controls controls: 1, // Show controls
iv_load_policy: 3, // No annotations iv_load_policy: 3, // No annotations
modestbranding: 1, // No logo modestbranding: 1, // No logo
rel: 0 // No related videos rel: 0, // No related videos
wmode: wmode
}, },
events: { events: {
onReady: function () { onReady: function () {
@ -57,9 +60,11 @@ var YouTubePlayer = function (data) {
} }
}); });
$("#ytapiplayer").css("border", "none"); $("#ytapiplayer").css("border", "none");
});
});
self.load = function (data) { self.load = function (data) {
if(self.player.loadVideoById) { if(self.player && self.player.loadVideoById) {
self.player.loadVideoById(data.id, data.currentTime); self.player.loadVideoById(data.id, data.currentTime);
if(VIDEOQUALITY) if(VIDEOQUALITY)
self.player.setPlaybackQuality(VIDEOQUALITY); self.player.setPlaybackQuality(VIDEOQUALITY);
@ -67,18 +72,18 @@ var YouTubePlayer = function (data) {
} }
}; };
self.pause = function() { self.pause = function () {
if(self.player.pauseVideo) if(self.player && self.player.pauseVideo)
self.player.pauseVideo(); self.player.pauseVideo();
}; };
self.play = function() { self.play = function () {
if(self.player.playVideo) if(self.player && self.player.playVideo)
self.player.playVideo(); self.player.playVideo();
}; };
self.isPaused = function(callback) { self.isPaused = function (callback) {
if(self.player.getPlayerState) { if(self.player && self.player.getPlayerState) {
var state = self.player.getPlayerState(); var state = self.player.getPlayerState();
callback(state != YT.PlayerState.PLAYING); callback(state != YT.PlayerState.PLAYING);
} else { } else {
@ -86,16 +91,15 @@ var YouTubePlayer = function (data) {
} }
}; };
self.getTime = function(callback) { self.getTime = function (callback) {
if(self.player.getCurrentTime) if(self.player && self.player.getCurrentTime)
callback(self.player.getCurrentTime()); callback(self.player.getCurrentTime());
}; };
self.seek = function(time) { self.seek = function (time) {
if(self.player.seekTo) if(self.player && self.player.seekTo)
self.player.seekTo(time, true); self.player.seekTo(time, true);
}; };
});
}; };
var VimeoPlayer = function (data) { var VimeoPlayer = function (data) {
@ -111,6 +115,8 @@ var VimeoPlayer = function (data) {
iframe.attr("webkitAllowFullScreen", ""); iframe.attr("webkitAllowFullScreen", "");
iframe.attr("mozallowfullscreen", ""); iframe.attr("mozallowfullscreen", "");
iframe.attr("allowFullScreen", ""); iframe.attr("allowFullScreen", "");
if(USEROPTS.wmode_transparent)
iframe.attr("wmode", "transparent");
iframe.css("border", "none"); iframe.css("border", "none");
$f(iframe[0]).addEvent("ready", function () { $f(iframe[0]).addEvent("ready", function () {
@ -195,7 +201,8 @@ var VimeoFlashPlayer = function (data) {
}; };
var params = { var params = {
allowfullscreen: true, allowfullscreen: true,
allowScriptAccess: "always" allowScriptAccess: "always",
wmode: USEROPTS.wmode_transparent ? "transparent" : undefined
}; };
swfobject.embedSWF(url, swfobject.embedSWF(url,
"ytapiplayer", "ytapiplayer",

View File

@ -451,6 +451,13 @@ function showOptionsMenu() {
syncacc.val(USEROPTS.sync_accuracy); syncacc.val(USEROPTS.sync_accuracy);
addOption("Synch Accuracy", syncacc); addOption("Synch Accuracy", syncacc);
var wmcontainer = $("<label/>").addClass("checkbox")
.text("Allow transparency over video");
var wmodetrans = $("<input/>").attr("type", "checkbox")
.appendTo(wmcontainer);
wmodetrans.prop("checked", USEROPTS.wmode_transparent);
addOption("Transparent wmode", wmcontainer);
var vidcontainer = $("<label/>").addClass("checkbox") var vidcontainer = $("<label/>").addClass("checkbox")
.text("Hide Video"); .text("Hide Video");
var hidevid = $("<input/>").attr("type", "checkbox").appendTo(vidcontainer); var hidevid = $("<input/>").attr("type", "checkbox").appendTo(vidcontainer);
@ -509,6 +516,7 @@ function showOptionsMenu() {
USEROPTS.layout = layoutselect.val(); USEROPTS.layout = layoutselect.val();
USEROPTS.synch = synch.prop("checked"); USEROPTS.synch = synch.prop("checked");
USEROPTS.sync_accuracy = parseFloat(syncacc.val()) || 2; USEROPTS.sync_accuracy = parseFloat(syncacc.val()) || 2;
USEROPTS.wmode_transparent = wmodetrans.prop("checked");
USEROPTS.hidevid = hidevid.prop("checked"); USEROPTS.hidevid = hidevid.prop("checked");
USEROPTS.show_timestamps = showts.prop("checked"); USEROPTS.show_timestamps = showts.prop("checked");
USEROPTS.blink_title = blink.prop("checked"); USEROPTS.blink_title = blink.prop("checked");