From 3ebf4a100950a0cca79b698c462f95aff9507451 Mon Sep 17 00:00:00 2001 From: calzoneman Date: Sun, 2 Jun 2013 19:19:51 -0400 Subject: [PATCH] Leader synchronization for JWPlayer --- channel.js | 2 +- www/assets/js/media.js | 39 ++++++++++++++++++++++++++++++++++----- 2 files changed, 35 insertions(+), 6 deletions(-) diff --git a/channel.js b/channel.js index e0234893..9aad63a6 100644 --- a/channel.js +++ b/channel.js @@ -1312,7 +1312,7 @@ Channel.prototype.tryUpdate = function(user, data) { return; } - if(isLive(this.media.type)) { + if(isLive(this.media.type) && this.media.type != "jw") { return; } diff --git a/www/assets/js/media.js b/www/assets/js/media.js index a4d11228..97df9c04 100644 --- a/www/assets/js/media.js +++ b/www/assets/js/media.js @@ -389,20 +389,49 @@ Media.prototype.initJWPlayer = function() { height: VHEIGHT, autostart: true }); - setTimeout(function() {$("#ytapiplayer_logo").remove();}, 1000); + + jwplayer().onPlay(function() { + this.paused = false; + }.bind(this)); + jwplayer().onPause(function() { + this.paused = true; + }.bind(this)); + jwplayer().onComplete(function() { + socket.emit("playNext"); + }); + + function removeLogo() { + if($("#ytapiplayer_logo").length > 0) { + $("#ytapiplayer_logo").remove(); + } + else { + setTimeout(removeLogo, 100); + } + } this.load = function(data) { this.id = data.id; this.initJWPlayer(); } - this.pause = function() { } + this.pause = function() { + jwplayer().pause(true); + } - this.play = function() { } + this.play = function() { + jwplayer().play(true); + } - this.getTime = function() { } + this.getTime = function(callback) { + // Only return time for non-live media + if(jwplayer().getDuration() != -1) { + callback(jwplayer().getPosition()); + } + } - this.seek = function() { } + this.seek = function(time) { + jwplayer().seek(time); + } } Media.prototype.initUstream = function() {