﻿/*
///说明：在图片加载前显示一个加载标志，当图片下载完毕后显示图片出来
可对图片进行是否自动缩放功能
此插件使用时可让页面先加载，而图片后加载的方式，

///参数设置：
scaling     是否等比例自动缩放
vertical    是否垂直居中
width       图片最大高
height      图片最大宽
loadpic     加载中的图片路径
pdiv        是否调整图片父div的宽度和高度，配合放大镜使用
*/
jQuery.fn.LoadImage=function(scaling,vertical,width,height,loadpic,pdiv){

    if(loadpic==null)loadpic="default.gif";
	return this.each(function(){
		var t=$(this);
		var p=$(this).parent();
		
		var src=$(this).attr("src")
		var img=new Image();
		//alert("Loading...")
		img.src=src;
		//自动缩放图片
		var autoScaling=function(){
			if(scaling){
				if(img.width>0 && img.height>0){
				    if(width>0 && height>0){
				        if(img.width/img.height>=width/height){ 
    			            if(img.width>width){ 
    			                t.width(width); 
    			                t.height((img.height*width)/img.width); 
    			            }else{ 
    			                t.width(img.width); 
    			                t.height(img.height); 
    			            } 
    			        } 
    			        else{ 
    			            if(img.height>height){ 
    			                t.height(height); 
    			                t.width((img.width*height)/img.height); 
    			            }else{ 
    			                t.width(img.width); 
    			                t.height(img.height); 
    			            } 
    			        } 
				    }
                    else{
                        if(width==0){ 
                            if(img.height>height){
                                t.height(height);
                                t.width((img.width*height)/img.height); 
                            }
                        }
                        if(height==0){ 
                            if(img.width>width){
                                t.width(width); 
    			                t.height((img.height*width)/img.width); 
                            }
                        }
                    }
			    }
			}	
		}
		//处理ff下会自动读取缓存图片
		if(img.complete){
		    //alert("getToCache!");
			autoScaling();
            if(pdiv){
                t.parent().width(t.width());
                t.parent().height(t.height());
            }
            
            if(vertical && height!=0){
                var topmargin = parseInt((height-t.height())/2);
                if(pdiv){
                    t.parent().css("margin-top",topmargin);
                }
                else{
                    t.css("margin-top",topmargin);
                }
            }
		    return;
		}
		$(this).attr("src","");
		var loading=$("<img alt=\"Loading...\" title=\"Loading...\" src=\""+loadpic+"\" />");
		
		t.hide();
		t.after(loading);
		$(img).load(function(){
			autoScaling();
			if(pdiv){
                t.parent().width(t.width());
                t.parent().height(t.height());
            }
            
            if(vertical && height!=0){
                var topmargin = parseInt((height-t.height())/2);
                if(pdiv){
                    t.parent().css("margin-top",topmargin);
                }
                else{
                    t.css("margin-top",topmargin);
                }
            }
			loading.remove();
			t.attr("src",this.src);
			t.show();
			//alert("finally!")
		});
	});
}
