Revision 47 | Blame | Vergleich mit vorheriger | Letzte Änderung | Log anzeigen | RSS feed
/*!* Thumbnail helper for fancyBox* version: 1.0.7 (Mon, 01 Oct 2012)* @requires fancyBox v2.0 or later** Usage:* $(".fancybox").fancybox({* helpers : {* thumbs: {* width : 50,* height : 50* }* }* });**/(function ($) {//Shortcut for fancyBox objectvar F = $.fancybox;//Add helper objectF.helpers.thumbs = {defaults : {width : 50, // thumbnail widthheight : 50, // thumbnail heightposition : 'bottom', // 'top' or 'bottom'source : function ( item ) { // function to obtain the URL of the thumbnail imagevar href;if (item.element) {href = $(item.element).find('img').attr('src');}if (!href && item.type === 'image' && item.href) {href = item.href;}return href;}},wrap : null,list : null,width : 0,init: function (opts, obj) {var that = this,list,thumbWidth = opts.width,thumbHeight = opts.height,thumbSource = opts.source;//Build list structurelist = '';for (var n = 0; n < obj.group.length; n++) {list += '<li><a style="width:' + thumbWidth + 'px;height:' + thumbHeight + 'px;" href="javascript:jQuery.fancybox.jumpto(' + n + ');"></a></li>';}this.wrap = $('<div id="fancybox-thumbs"></div>').addClass(opts.position).appendTo('body');this.list = $('<ul>' + list + '</ul>').appendTo(this.wrap);//Load each thumbnail$.each(obj.group, function (i) {var href = thumbSource( obj.group[ i ] );if (!href) {return;}$("<img />").load(function () {var width = this.width,height = this.height,widthRatio, heightRatio, parent;if (!that.list || !width || !height) {return;}//Calculate thumbnail width/height and center itwidthRatio = width / thumbWidth;heightRatio = height / thumbHeight;parent = that.list.children().eq(i).find('a');if (widthRatio >= 1 && heightRatio >= 1) {if (widthRatio > heightRatio) {width = Math.floor(width / heightRatio);height = thumbHeight;} else {width = thumbWidth;height = Math.floor(height / widthRatio);}}$(this).css({width : width,height : height,top : Math.floor(thumbHeight / 2 - height / 2),left : Math.floor(thumbWidth / 2 - width / 2)});parent.width(thumbWidth).height(thumbHeight);$(this).hide().appendTo(parent).fadeIn(300);}).attr('src', href);});//Set initial widththis.width = this.list.children().eq(0).outerWidth(true);this.list.width(this.width * (obj.group.length + 1)).css('left', Math.floor($(window).width() * 0.5 - (obj.index * this.width + this.width * 0.5)));},beforeLoad: function (opts, obj) {//Remove self if gallery do not have at least two itemsif (obj.group.length < 2) {obj.helpers.thumbs = false;return;}//Increase bottom margin to give space for thumbsobj.margin[ opts.position === 'top' ? 0 : 2 ] += ((opts.height) + 15);},afterShow: function (opts, obj) {//Check if exists and create or update listif (this.list) {this.onUpdate(opts, obj);} else {this.init(opts, obj);}//Set active elementthis.list.children().removeClass('active').eq(obj.index).addClass('active');},//Center listonUpdate: function (opts, obj) {if (this.list) {this.list.stop(true).animate({'left': Math.floor($(window).width() * 0.5 - (obj.index * this.width + this.width * 0.5))}, 150);}},beforeClose: function () {if (this.wrap) {this.wrap.remove();}this.wrap = null;this.list = null;this.width = 0;}}}(jQuery));