gdoo/public/assets/chat/jquery/jquery-imgview.js

194 lines
6.2 KiB
JavaScript

(function ($) {
function get(id){return document.getElementById(id)};
function funclass(opts, obj){
if(!opts)opts={};
var me = this;
this.ismobile = false;
this.downbool = true;
this.dushu = 0;
this.init=function(){
for(var i in opts)this[i]=opts[i];
if(obj)this.url=obj.attr('src');
this.mheiht = document.body.scrollHeight,sed=$(window).height();
if(this.mheiht<sed)this.mheiht=sed;
this.showview();
};
this.remove=function(){
$('#imgview_main').remove();
};
this.showview=function(){
var s='<div id="imgview_main" style="position:absolute;left:0px;top:0px;width:100%;height:100%;z-index:800">';
s+='<div style="position:absolute;z-index:0;left:0px;top:0px;width:100%;height:'+this.mheiht+'px;background-color:rgba(0,0,0,0.6)" id="imgview_mask"></div>';
s+='<span onclick="$(this).parent().remove()" style="position:fixed;z-index:2;top:2px;right:5px;color:white"><i class="fa fa-remove"></i></span>';
s+='<div id="imgview_span" style="position:fixed;z-index:1;left:47%;top:47%;overflow:hidden;color:white">';
s+=' <div id="imgview_spanmask" style="position:absolute;z-index:1;left:0px;top:0px;background-color:rgba(0,0,0,0);width:100%;height:100%;cursor:move;user-select:none;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none;-khtml-user-select:none;"></div>';
s+=' <img style="position:absolute;z-index:0;left:0px;top:0px" id="imgview_spanimg" width="100%" height="100%" src="/assets/chat/images/mloading.gif" >';
s+='</div>';
s+='<div style="position:fixed;z-index:2;left:0px;bottom:0px;text-align:center;color:white;width:100%;font-size:20px;background-color:rgba(0,0,0,0.2);height:40px;line-height:40px;overflow:hidden"><i style="cursor:pointer" id="imgview_zoom-out" class="fa fa-search-minus" title="缩小"></i> &nbsp; <span id="imgview_nowbili" style="font-size:14px">100%</span> &nbsp; <i style="cursor:pointer" class="fa fa-search-plus" title="放大" id="imgview_zoom-in"></i>';
s+=' &nbsp; <i style="cursor:pointer" class="fa fa-arrows" title="原始大小" id="imgview_zoom-move"></i>';
if(!this.ismobile && this.downbool)s+=' &nbsp; <a target="_blank" download="" style="color:white;font-size:20px" href="'+this.url+'"><i style="cursor:pointer" class="fa fa-download" title="下载"></i></a>';
s+=' &nbsp; <i style="cursor:pointer" class="fa fa-refresh" title="旋转90度" id="imgview_zoom-refresh"></i>';
s+='</div>';
s+='</div>';
$('body').append(s);
$('#imgview_mask').click(function(){
$('#imgview_main').remove();
});
this.showez(32,32,0);
var img = new Image();
img.src = this.url;
img.onload = function(){
me.showez(this.width,this.height, 1);
try{
$('#imgview_span').mousewheel(function(e){
me.bilixxx(e.deltaY*0.1);
});}catch(e){}
me.rotate(me.dushu);
me.initmove();
}
img.onerror=function(e){
$('#imgview_span').html('无图');
}
$('#imgview_zoom-out').click(function(){
me.bilixxx(-0.1);
});
$('#imgview_zoom-in').click(function(){
me.bilixxx(0.1);
});
$('#imgview_zoom-refresh').click(function(){
me.clickrotate();
});
$('#imgview_zoom-move').click(function(){
me.bl=1;
me.rotate(0);
me.bilixxx(0);
});
};
this.showez=function(w, h, lx){
this.width = w;
this.height = h;
var zw = $(window).width(),zh=$(window).height();
var wm = zw-50,wh = zh-50;
var bl= 1,nw=w,nh=h;
if(w>wm){
bl=wm/w;
nh = h*bl;
}
if(nh>wh){
bl= wh/h;
}
this.showbl(bl,lx);
};
this.showbl=function(bl,lx){
this.bl = bl;
$('#imgview_nowbili').html(''+parseInt(bl*100)+'%');
var zw = $(window).width(),zh=$(window).height();
var nw = this.width*this.bl,nh=this.height*this.bl;
var l = (zw-nw)*0.5,t = (zh-nh)*0.5;
var arr = {left:''+l+'px',top:''+t+'px',width:''+nw+'px',height:''+nh+'px'};
var o1 = $('#imgview_span');
if(lx!=2){
if(lx==1)get('imgview_spanimg').src=this.url;
o1.css(arr);
}else{
o1.stop();
o1.animate(arr,300);
}
};
this.bilixxx=function(lx){
var bl = this.bl+lx;
if(bl<0)bl=0.05;
if(bl>3)bl=3;
this.showbl(bl,2);
};
this.initmove=function(){
if(this.ismobile){
this.movehammer();
return;
}
var o = $('#imgview_spanmask');
var x=0,y=0,oldl,oldt;
o.mousedown(function(e){
x=e.clientX;
y=e.clientY;
var o1=get('imgview_span');
oldl = parseInt(o1.style.left);
oldt = parseInt(o1.style.top);
me.movebo=true;
});
o.mousemove(function(e){
if(!me.movebo)return;
var _x = e.clientX-x,_y=e.clientY-y;
$('#imgview_span').css({left:''+(oldl+_x)+'px',top:''+(oldt+_y)+'px'});
});
o.mouseup(function(e){
me.movebo=false;
});
};
this.rotate=function(ds){
var o = get('imgview_span');
var val= "rotate("+ds+"deg)";
o.style.transform=val;
o.style.webkitTransform=val;
o.style.msTransform=val;
o.style.MozTransform=val;
o.style.OTransform=val;
};
this.clickrotate=function(){
this.dushu+=90;
if(this.dushu>=360)this.dushu=0;
this.rotate(this.dushu);
};
this.movehammer=function(){
var o = get('imgview_spanmask');
var x=0,y=0,oldl,oldt;
this.touchci = 0;
o.addEventListener('touchstart',function(e){
me.touchci++;
x=e.touches[0].clientX;
y=e.touches[0].clientY;
var o1=get('imgview_span');
oldl = parseInt(o1.style.left);
oldt = parseInt(o1.style.top);
me.movebo=true;
clearTimeout(me.touctimes);
me.touctimes = setTimeout(function(){me.touchci=0},200);
});
o.addEventListener('touchmove',function(e){
e.preventDefault();
if(!me.movebo)return;
var _x = e.touches[0].clientX-x,_y=e.touches[0].clientY-y;
$('#imgview_span').css({left:''+(oldl+_x)+'px',top:''+(oldt+_y)+'px'});
});
o.addEventListener('touchend',function(e){
me.movebo=false;
if(me.touchci==2){
me.bilixxx(0.1);
me.touchci=0;
}
});
}
}
$.imgview = function(options){
var cls = new funclass(options,false);
cls.init();
return cls;
}
$.fn.imgview = function(options){
var cls = new funclass(options, $(this));
cls.init();
return cls;
}
$.imgviewclose= function(){
var bo = get('imgview_main');
$('#imgview_main').remove();
return bo;
}
})(jQuery);