diff -r 62612c69699f -r ed4ac18baf07 src/js/widgets/playerWidget.js --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/src/js/widgets/playerWidget.js Wed Oct 19 15:00:34 2011 +0200 @@ -0,0 +1,135 @@ +IriSP.PlayerWidget.prototype = new IriSP.Widget; + +IriSP.PlayerWidget.prototype.draw = function() { + var _this = this; + var width = this._config.gui.width; + var height = this._config.gui.height; + var heightS = this._config.gui.height-20; + + if( this._config.gui.mode=="radio" ){ + + //IriSP.jQuery( "#"+this._config.gui.container ).before(IriSP.search_template); + var radioPlayer = Mustache.to_html(IriSP.radio_template, {"share_template" : IriSP.share_template}); + IriSP.jQuery(radioPlayer).appendTo("#"+this._config.gui.container); + + // special tricks for IE 7 + if (IriSP.jQuery.browser.msie==true && IriSP.jQuery.browser.version=="7.0"){ + //LdtSearchContainer + //__IriSP.jQuery("#LdtPlayer").attr("margin-top","50px"); + IriSP.jQuery("#Ldt-Root").css("padding-top","25px"); + } + } else if(this._config.gui.mode=="video") { + + var videoPlayer = Mustache.to_html(IriSP.video_template, {"share_template" : IriSP.share_template, "heightS" : heightS}); + IriSP.jQuery(videoPlayer).appendTo("#"+this._config.gui.container); + } + + IriSP.jQuery("#Ldt-Annotations").width(width-(75*2)); + IriSP.jQuery("#Ldt-Show-Arrow-container").width(width-(75*2)); + IriSP.jQuery("#Ldt-ShowAnnotation-audio").width(width-10); + IriSP.jQuery("#Ldt-ShowAnnotation-video").width(width-10); + IriSP.jQuery("#Ldt-SaKeyword").width(width-10); + IriSP.jQuery("#Ldt-controler").width(width-10); + IriSP.jQuery("#Ldt-Control").attr("z-index","100"); + IriSP.jQuery("#Ldt-controler").hide(); + + IriSP.jQuery(IriSP.annotation_loading_template).appendTo("#Ldt-ShowAnnotation-audio"); + + if(this._config.gui.mode=='radio'){ + IriSP.jQuery("#Ldt-load-container").attr("width",this._config.gui.width); + } + + IriSP.jQuery( "#Ldt-controler" ).show(); + //__IriSP.jQuery("#Ldt-Root").css('display','visible'); + IriSP.jQuery( "#Ldt-ShowAnnotation").click( function () { + //__IriSP.jQuery(this).slideUp(); + } ); + + var LdtpPlayerY = IriSP.jQuery("#Ldt-PlaceHolder").attr("top"); + var LdtpPlayerX = IriSP.jQuery("#Ldt-PlaceHolder").attr("left"); + + IriSP.jQuery( "#slider-range-min" ).slider( { //range: "min", + value: 0, + min: 1, + max: this._serializer.currentMedia().meta["dc:duration"]/1000,//1:54:52.66 = 3600+3240+ + step: 0.1, + slide: function(event, ui) { + _this._Popcorn.currentTime(ui.value); + }, + /* change event is similar to slide, but it happens when the slider position is + modified programatically. We use it for unit tests */ + /* + change: function(event, ui) { + _this._Popcorn.currentTime(ui.value); + } + */ + } ); + + IriSP.jQuery("#amount").val(IriSP.jQuery("#slider-range-min").slider("value")+" s"); + IriSP.jQuery(".Ldt-Control1 button:first").button({ + icons: { + primary: 'ui-icon-play' + }, + text: false + }).click(function() { _this.playHandler.call(_this); }) + .next().button({ + icons: { + primary: 'ui-icon-seek-next' + }, + text: false + }); + IriSP.jQuery(".Ldt-Control2 button:first").button({ + icons: { + primary: 'ui-icon-search'//, + //secondary: 'ui-icon-volume-off' + }, + text: false + }).next().button({ + icons: { + primary: 'ui-icon-volume-on' + }, + text: false + }).click(function() { _this.muteHandler.call(_this); } ); + + // /!\ PB A MODIFIER + //__IriSP.MyTags.draw(); + IriSP.jQuery( "#ldt-CtrlPlay" ).attr( "style", "background-color:#CD21C24;" ); + + IriSP.jQuery( "#Ldt-load-container" ).hide(); + + if( this._config.gui.mode=="radio" & IriSP.jQuery.browser.msie != true ) { + IriSP.jQuery( "#Ldtplayer1" ).attr( "height", "0" ); + } + + this._Popcorn.listen("timeupdate", IriSP.wrap(this, this.sliderUpdater)); +}; + +IriSP.PlayerWidget.prototype.playHandler = function() { + var status = this._Popcorn.media.paused; + + if ( status == true ){ + this._Popcorn.play(); + IriSP.jQuery( ".ui-icon-play" ).css( "background-position", "-16px -160px" ); + IriSP.jQuery( "#ldt-CtrlPlay" ).attr("title", "Play"); + } else { + this._Popcorn.pause(); + IriSP.jQuery( ".ui-icon-play" ).css( "background-position","0px -160px" ); + IriSP.jQuery( "#ldt-CtrlPlay" ).attr("title", "Pause"); + } +}; + +IriSP.PlayerWidget.prototype.muteHandler = function() { + if (!this._Popcorn.muted()) { + this._Popcorn.mute(true); + IriSP.jQuery(" .ui-icon-volume-on ").css("background-position", "-130px -160px"); + } else { + this._Popcorn.mute(false); + IriSP.jQuery( ".ui-icon-volume-on" ).css("background-position", "-144px -160px" ); + } +}; + +IriSP.PlayerWidget.prototype.sliderUpdater = function() { + var currentPosition = this._Popcorn.currentTime(); + IriSP.jQuery( "#slider-range-min" ).slider( "value", currentPosition); +}; +