window.ShearPhoto.MINGGE(function() { var relativeUrl= SHEAR.PATH_RES+"/shearphoto";//by rainfer,相对路径 var avatarUrl= SHEAR.PATH_AVATAR;//by rainfer,头像路径 relativeUrl = relativeUrl.replace(/(^\s*)|(\s*$)/g, "");//去掉相对路径的所有空格 relativeUrl === "" || (relativeUrl += "/");//在相对地址后面加斜框,不需要用户自己加 var publicRelat= document.getElementById("relat"); //"relat"对像 var publicRelatImg=publicRelat.getElementsByTagName("img"); //"relat"下的两张图片对像 var Shear = new ShearPhoto; Shear.config({ relativeUrl:relativeUrl, //取回相对路径 avatarUrl:avatarUrl,//by rainfer,头像路径 traverse:true,//可选 true,false 。 是否在拖动或拉伸时允许历遍全图(是否让大图动呢), translate3d:false, //是否开启3D移动,CPU加速。可选true false。默认关闭的 HTML5:true,//可选 true,false 是否使用HTML5进行切图 HTML5MAX:500, //默认请设0 (最大尺寸做事), HTML上传截图最大宽度, 宽度越大,HTML5截出来的图片容量越大,服务器压力就大,截图就更清淅 HTML5Quality:0.9, //截好的截图 0至1范围可选(可填小数) HTML5切图的质量 为1时 最高 HTML5FilesSize:50, //如果是HTML5切图时,选择的图片不能超过多少,单位M HTML5Effects:true,//是否开启图片特效功能给用户 可选true false, 提示:有HTML5浏览器才会开启的!当然开启HTML5切图,该设置才有效 HTML5ZIP:[900,0.9],//HTML5截图前载入的大图 是否压缩图片(数组成员 是数字) preview:[100],// 开启动态预览图片 (数组成员整数型,禁止含小数点 可选false 和数组) url:relativeUrl+"php/shearphoto.php", //后端处理地址 scopeWidth:300, //可拖动范围宽 也就是"main"对象的初始大小(整数型,禁止含小数点) 宽和高的值最好能一致 scopeHeight:300, //可拖动范围高 也就是"main"对象的初始大小(整数型,禁止含小数点) 宽和高的值最好能一致 proportional:[1/1,100,133], Min:50, //截框拉伸或拖拽不能少于多少PX(整数型,禁止含小数点) Max:300, //一开始启动时,图片的宽和高,有时候图片会很大的,必须要设置一下(整数型,禁止含小数点) backgroundColor:"#000", //遮层色 backgroundOpacity:0.6, //遮层透明度-数字0-1 可选 Border:0, //截框的边框大小 0代表动态边框。大于0表示静态边框,大于0时也代表静态边框的粗细值 BorderStyle:"solid", //只作用于静态边框,截框的边框类型,其实是引入CSS的border属性,和CSS2的border属性是一样的 BorderColor:"#09F", //只作用于静态边框,截框的边框色彩 relat:publicRelat, //请查看 id:"relat"对象 scope:document.getElementById("main"),//main范围对象 ImgDom:publicRelatImg[0], //截图图片对象(小) ImgMain:publicRelatImg[1], //截图图片对象(大) black:document.getElementById("black"),//黑色遮层对象 form:document.getElementById("smallbox"),//截框对象 ZoomDist:document.getElementById("ZoomDist"),//放大工具条,可从HTML查看此对象,不作详细解释了 ZoomBar:document.getElementById("ZoomBar"), //放大工具条,可从HTML查看此对象 to:{ BottomRight:document.getElementById("BottomRight"),//拉伸点中右 TopRight:document.getElementById("TopRight"),//拉伸点上右,下面如此类推,一共8点进行拉伸,下面不再作解释 Bottomleft:document.getElementById("Bottomleft"), Topleft:document.getElementById("Topleft"), Topmiddle:document.getElementById("Topmiddle"), leftmiddle:document.getElementById("leftmiddle"), Rightmiddle:document.getElementById("Rightmiddle"), Bottommiddle:document.getElementById("Bottommiddle") }, Effects:document.getElementById("shearphoto_Effects") || false, DynamicBorder:[document.getElementById("borderTop"),document.getElementById("borderLeft"),document.getElementById("borderRight"),document.getElementById("borderBottom")], SelectBox:document.getElementById("SelectBox"), //选择图片方式的对象 Shearbar:document.getElementById("Shearbar"), //截图工具条对象 UpFun:function() { //鼠标健松开时执行函数 Shear.MoveDiv.DivWHFun(); //把截框现时的宽高告诉JS } }); Shear.complete=function(serverdata) {//截图成功完成时,由shearphoto.php返回数据过来的成功包 //alert(SHEAR.URL);//你可以调试一下这个返回包 var point = this.arg.scope.childNodes[0]; point.className === "point" && this.arg.scope.removeChild(point); var complete = document.createElement("div"); complete.className = "complete"; complete.style.height = this.arg.scopeHeight + "px"; this.arg.scope.insertBefore(complete, this.arg.scope.childNodes[0]); var length = serverdata.length,creatImg; for (var i = 0; i < length; i++) { creatImg = document.createElement("img"); complete.appendChild(creatImg); creatImg.src=this.arg.avatarUrl +"/"+ serverdata[i]["ImgUrl"]; } this.HTML5.EffectsReturn(); this.HTML5.BOLBID && this.HTML5.URL.revokeObjectURL(this.HTML5.BOLBID); var this_ = this; this_.preview.close_(); ////by rainfer,增加ajax开始 $.post(SHEAR.URL, {'imgurl':serverdata[0]['ImgUrl']}, function(data){ if(data.code==1){ layer.alert(data.msg, {icon: 6}, function(index){ layer.close(index); window.location.href=data.url; }); }else{ layer.alert(data.msg, {icon: 5}, function(index){ layer.close(index); }); } }); } var photoalbum = document.getElementById("photoalbum");//相册对象 var ShearPhotoForm = document.getElementById("ShearPhotoForm");//FORM对象 ShearPhotoForm.UpFile.onclick=function(){return false}//一开始时先不让用户点免得事件阻塞 var up = new ShearPhoto.frameUpImg({ url:relativeUrl+"php/upload.php", //HTML5切图时,不会用到该文件,后端处理地址 FORM:ShearPhotoForm, //FORM对象传到设置 UpType:new Array("jpg", "jpeg", "png", "gif"),//图片类限制,上传的一定是图片,你就不要更改了 FilesSize:2, //选择的图片不能超过 单位M(注意:是非HTML5时哦) HTML5:Shear.HTML5, HTML5FilesSize:Shear.arg.HTML5FilesSize, HTML5ZIP:Shear.arg.HTML5ZIP, erro:function(msg) { Shear.pointhandle(3e3, 10, msg, 0, "#f82373", "#fff"); }, fileClick:function(){//先择图片被点击时,触发的事件 Shear.pointhandle(-1);//关闭提示,防止线程阻塞事件冒泡 }, preced:function(fun) { //点击选择图,载入图片时的事件 try{ photoalbum.style.display = "none"; //什么情况下都关了相册 camClose.onclick(); //什么情况下都关了视频 }catch (e){console.log("在加载图片时,发现相册的对象检测不到,错误代码:"+e);} Shear.pointhandle(0, 10, "正在为你加载图片,请你稍等哦......", 2, "#307ff6", "#fff",fun); } }); up.run(function(data,True) {//upload.php成功返回数据后 True || (data = ShearPhoto.JsonString.StringToJson(data)); if (data === false) { Shear.SendUserMsg("错误:请保证后端环境运行正常", 5e3, 0, "#f4102b", "#fff", true,true); return; } if (data["erro"]) { Shear.SendUserMsg("错误:" + data["erro"], 5e3, 0, "#f4102b", "#fff", true,true); return; } Shear.run(data["success"],true); }); try{ var AllType= {".jpg":"image/jpeg", ".jpeg":"image/jpeg", ".gif":"image/jpeg", ".png":"image/png"}; var URLType =function(url){ return AllType[/\.[^.]+$/.exec(url)] || "image/jpeg";//取后缀 } var DE = document.documentElement; var PhotoLoading = document.getElementById("PhotoLoading"); var photoalbumLi = photoalbum.getElementsByTagName("li"); var photoalbumLifun = function() { var serveUrl= this.getElementsByTagName("img")[0].getAttribute("serveUrl"); Shear.HTML5.ImagesType=URLType(serveUrl);//告诉HTML5,图片的类型 Shear.run(serveUrl); //通过API 接口,加载图片 photoalbum.style.display = "none"; }; for (var i = 0; i < photoalbumLi.length; i++) photoalbumLi[i].onclick = photoalbumLifun;//为相册的每张照加入一个点击事件 PhotoLoading.onclick = function() { //从相册选取事件 photoalbum.style.display = "block"; }; document.getElementById("close").onclick = function() { //关闭相册事件 photoalbum.style.display = "none"; }; }catch (e){console.log("相册对象检测有误,错误代码:"+e );} Shear.addEvent(document.getElementById("saveShear"), "click", function() { //按下截图事件,提交到后端的shearphoto.php接收 Shear.SendPHP({shearphoto:"",mingge:""});//我们示例截图并且传参数,后端文件shearphoto.php用 示例:$_POST["shearphoto"] 接收参数,不需要传参数请清空Shear.SendPHP里面的参数示例 Shear.SendPHP(); }); Shear.addEvent(document.getElementById("LeftRotate"), "click", function() {//向左旋转事件 Shear.Rotate("left"); }); Shear.addEvent(document.getElementById("RightRotate"), "click", function() { //向右旋转事件 Shear.Rotate("right"); }); Shear.addEvent(document.getElementById("againIMG"), "click", function() { //重新选择事件 Shear.preview.close_(); Shear.again(); Shear.HTML5.EffectsReturn(); Shear.HTML5.BOLBID && Shear.HTML5.URL.revokeObjectURL(Shear.HTML5.BOLBID); Shear.pointhandle(3e3, 10, "已取消!重新选择", 2, "#fbeb61", "#3a414c"); }); var shearphoto_loading=document.getElementById("shearphoto_loading"); var shearphoto_main=document.getElementById("shearphoto_main"); shearphoto_loading && shearphoto_loading.parentNode.removeChild(shearphoto_loading); shearphoto_main.style.visibility="visible"; });