mirror of https://github.com/calzoneman/sync.git
Fix pausing on HTML5 player
This commit is contained in:
parent
4a3645e3ed
commit
f11be6ae81
181
www/js/player.js
181
www/js/player.js
|
@ -103,15 +103,6 @@ var YouTubePlayer = function (data) {
|
||||||
self.player.playVideo();
|
self.player.playVideo();
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
if(self.player && self.player.getPlayerState) {
|
|
||||||
var state = self.player.getPlayerState();
|
|
||||||
callback(state != YT.PlayerState.PLAYING);
|
|
||||||
} else {
|
|
||||||
callback(false);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
if(self.player && self.player.getCurrentTime)
|
if(self.player && self.player.getCurrentTime)
|
||||||
callback(self.player.getCurrentTime());
|
callback(self.player.getCurrentTime());
|
||||||
|
@ -205,10 +196,6 @@ var VimeoPlayer = function (data) {
|
||||||
self.player.api("play");
|
self.player.api("play");
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
callback(self.paused);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
if(self.player && self.player.api) {
|
if(self.player && self.player.api) {
|
||||||
// Vimeo api returns time as a string because fuck logic
|
// Vimeo api returns time as a string because fuck logic
|
||||||
|
@ -315,10 +302,6 @@ var VimeoFlashPlayer = function (data) {
|
||||||
self.player.api_play();
|
self.player.api_play();
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
callback(self.paused);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
if(self.player && self.player.api_getCurrentTime) {
|
if(self.player && self.player.api_getCurrentTime) {
|
||||||
var t = parseFloat(self.player.api_getCurrentTime());
|
var t = parseFloat(self.player.api_getCurrentTime());
|
||||||
|
@ -425,10 +408,6 @@ var DailymotionPlayer = function (data) {
|
||||||
self.player.api("play");
|
self.player.api("play");
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
callback(self.paused);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
if(self.player)
|
if(self.player)
|
||||||
callback(self.player.currentTime);
|
callback(self.player.currentTime);
|
||||||
|
@ -536,13 +515,6 @@ var SoundcloudPlayer = function (data) {
|
||||||
self.player.play();
|
self.player.play();
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
if(self.player && self.player.isPaused)
|
|
||||||
self.player.isPaused(callback);
|
|
||||||
else
|
|
||||||
callback(false);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
if(self.player && self.player.getPosition) {
|
if(self.player && self.player.getPosition) {
|
||||||
self.player.getPosition(function (pos) {
|
self.player.getPosition(function (pos) {
|
||||||
|
@ -595,8 +567,6 @@ var LivestreamPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -645,8 +615,6 @@ var TwitchTVPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -696,8 +664,6 @@ var JustinTVPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -755,8 +721,6 @@ var RTMPPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -850,11 +814,6 @@ var JWPlayer = function (data) {
|
||||||
jwplayer().play(true);
|
jwplayer().play(true);
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
if(jwplayer)
|
|
||||||
callback(jwplayer().getState() !== "PLAYING");
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
// Only return time for non-live media
|
// Only return time for non-live media
|
||||||
if(jwplayer && jwplayer().getDuration() != -1) {
|
if(jwplayer && jwplayer().getDuration() != -1) {
|
||||||
|
@ -904,8 +863,6 @@ var UstreamPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -941,8 +898,6 @@ var ImgurPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -982,8 +937,6 @@ var CustomPlayer = function (data) {
|
||||||
|
|
||||||
self.play = function () { };
|
self.play = function () { };
|
||||||
|
|
||||||
self.isPaused = function () { };
|
|
||||||
|
|
||||||
self.getTime = function () { };
|
self.getTime = function () { };
|
||||||
|
|
||||||
self.seek = function () { };
|
self.seek = function () { };
|
||||||
|
@ -995,88 +948,6 @@ var CustomPlayer = function (data) {
|
||||||
self.init();
|
self.init();
|
||||||
};
|
};
|
||||||
|
|
||||||
var GoogleDocsPlayer = function (data) {
|
|
||||||
var self = this;
|
|
||||||
self.init = function (data) {
|
|
||||||
self.videoId = data.id;
|
|
||||||
self.videoLength = data.seconds;
|
|
||||||
self.paused = false;
|
|
||||||
var wmode = USEROPTS.wmode_transparent ? "transparent" : "opaque";
|
|
||||||
|
|
||||||
var meta = data.meta;
|
|
||||||
if (!meta || !meta.object || !meta.params) {
|
|
||||||
// Reset videoId so that a changeMedia with the appropriate data
|
|
||||||
// will properly reset the player
|
|
||||||
self.videoId = "";
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
self.player = $("<object/>", meta.object)[0];
|
|
||||||
$(self.player).attr("data", meta.object.data);
|
|
||||||
$(self.player).attr("width", VWIDTH)
|
|
||||||
.attr("height", VHEIGHT);
|
|
||||||
meta.params.forEach(function (p) {
|
|
||||||
$("<param/>", p).appendTo(self.player);
|
|
||||||
});
|
|
||||||
removeOld($(self.player));
|
|
||||||
self.setVolume(VOLUME);
|
|
||||||
resizeStuff();
|
|
||||||
};
|
|
||||||
|
|
||||||
self.load = function (data) {
|
|
||||||
self.init(data);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.pause = function () {
|
|
||||||
if(self.player && self.player.pauseVideo)
|
|
||||||
self.player.pauseVideo();
|
|
||||||
};
|
|
||||||
|
|
||||||
self.play = function () {
|
|
||||||
if(self.player && self.player.playVideo)
|
|
||||||
self.player.playVideo();
|
|
||||||
};
|
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
if(self.player && self.player.getPlayerState) {
|
|
||||||
var state = self.player.getPlayerState();
|
|
||||||
callback(state != YT.PlayerState.PLAYING);
|
|
||||||
} else {
|
|
||||||
callback(false);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
|
||||||
if(self.player && self.player.getCurrentTime)
|
|
||||||
callback(self.player.getCurrentTime());
|
|
||||||
};
|
|
||||||
|
|
||||||
self.seek = function (time) {
|
|
||||||
if(self.player && self.player.seekTo)
|
|
||||||
self.player.seekTo(time, true);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getVolume = function (cb) {
|
|
||||||
if (!self.player || !self.player.getVolume || !self.player.isMuted) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// YouTube's API is strange in the sense that getVolume() returns
|
|
||||||
// the regular (unmuted) volume even if it is muted...
|
|
||||||
// YouTube's volume is 0..100, normalize it to 0..1
|
|
||||||
var vol = self.player.isMuted() ? 0 : (self.player.getVolume() / 100);
|
|
||||||
cb(vol);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.setVolume = function (vol) {
|
|
||||||
if (self.player && self.player.setVolume) {
|
|
||||||
self.player.setVolume(vol * 100);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
self.init(data);
|
|
||||||
};
|
|
||||||
|
|
||||||
function FilePlayer(data) {
|
function FilePlayer(data) {
|
||||||
var self = this;
|
var self = this;
|
||||||
|
|
||||||
|
@ -1138,10 +1009,6 @@ function FilePlayer(data) {
|
||||||
self.player.play2();
|
self.player.play2();
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (cb) {
|
|
||||||
cb(self.paused);
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (cb) {
|
self.getTime = function (cb) {
|
||||||
cb(self.currentTime);
|
cb(self.currentTime);
|
||||||
};
|
};
|
||||||
|
@ -1191,6 +1058,30 @@ function FilePlayer(data) {
|
||||||
});
|
});
|
||||||
removeOld(video);
|
removeOld(video);
|
||||||
self.player = video[0];
|
self.player = video[0];
|
||||||
|
if (!Object.hasOwnProperty.call(self, "paused")) {
|
||||||
|
Object.defineProperty(self, "paused", {
|
||||||
|
get: function () {
|
||||||
|
return self.player.paused;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
self.player.onpause = function () {
|
||||||
|
self.paused = true;
|
||||||
|
if (CLIENT.leader) {
|
||||||
|
sendVideoUpdate();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
self.player.onplay = function () {
|
||||||
|
self.paused = false;
|
||||||
|
if (CLIENT.leader) {
|
||||||
|
sendVideoUpdate();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
self.player.onended = function () {
|
||||||
|
if (CLIENT.leader) {
|
||||||
|
socket.emit("playNext");
|
||||||
|
}
|
||||||
|
};
|
||||||
self.setVolume(VOLUME);
|
self.setVolume(VOLUME);
|
||||||
resizeStuff();
|
resizeStuff();
|
||||||
};
|
};
|
||||||
|
@ -1215,12 +1106,6 @@ function FilePlayer(data) {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
self.isPaused = function (callback) {
|
|
||||||
if (self.player) {
|
|
||||||
callback(self.player.paused);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
self.getTime = function (callback) {
|
self.getTime = function (callback) {
|
||||||
if (self.player) {
|
if (self.player) {
|
||||||
callback(self.player.currentTime);
|
callback(self.player.currentTime);
|
||||||
|
@ -1306,17 +1191,14 @@ function handleMediaUpdate(data) {
|
||||||
|
|
||||||
// Handle pause/unpause
|
// Handle pause/unpause
|
||||||
if(data.paused) {
|
if(data.paused) {
|
||||||
PLAYER.isPaused(function (paused) {
|
if (!PLAYER.paused) {
|
||||||
if (!paused) {
|
PLAYER.seek(data.currentTime);
|
||||||
PLAYER.seek(data.currentTime);
|
PLAYER.pause();
|
||||||
PLAYER.pause();
|
}
|
||||||
}
|
|
||||||
});
|
|
||||||
} else {
|
} else {
|
||||||
PLAYER.isPaused(function (paused) {
|
if (PLAYER.paused) {
|
||||||
if(paused)
|
PLAYER.play();
|
||||||
PLAYER.play();
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle time change
|
// Handle time change
|
||||||
|
@ -1359,7 +1241,6 @@ var constructors = {
|
||||||
"jw": JWPlayer,
|
"jw": JWPlayer,
|
||||||
"im": ImgurPlayer,
|
"im": ImgurPlayer,
|
||||||
"cu": CustomPlayer,
|
"cu": CustomPlayer,
|
||||||
"gd": GoogleDocsPlayer,
|
|
||||||
"rt": FilePlayer,
|
"rt": FilePlayer,
|
||||||
"rv": FilePlayer,
|
"rv": FilePlayer,
|
||||||
"fl": FilePlayer,
|
"fl": FilePlayer,
|
||||||
|
|
Loading…
Reference in New Issue