图片上传裁剪zyupload
图片上传控件用的是zyupload控件,使用过程中遇到了一些问题,特别记录下来

上图是目前的使用效果,这个控件我是用js代码动态添加出来的
HTML代码:
<div class="widget-body">
<div class="widget-main padding-12" id="uploadarea">
<ul class="ace-thumbnails clearfix" id="gallery">
</ul>
</div>
</div>
js代码:
function initZyupload(){
var uploadarea=document.getElementById("uploadarea");
var zyupload=document.createElement("div");
zyupload.setAttribute("id","zyupload");
zyupload.setAttribute("class","zyupload");
uploadarea.appendChild(zyupload);
$("#zyupload").zyUpload({
width : "700px", // 宽度
height : "400px", // 高度
itemWidth : "140px", // 文件项的宽度
itemHeight : "140px", // 文件项的高度
url : $("#zyupload").url= basePath+"/smart/activity/saveImages.do?id="+$("#form_Id").val(), // 上传文件的路径
fileType : ["jpg","jpeg","bmp","png"],// 上传文件的类型
fileSize : 51200000, // 上传文件的大小
multiple : true, // 是否可以多个文件上传
dragDrop : true, // 是否可以拖动上传文件
tailor : true, // 是否可以裁剪图片
del : true, // 是否可以删除文件
finishDel : false, // 是否在上传文件完成后删除预览
/* 外部获得的回调接口 */
onSelect: function(selectFiles, allFiles){ // 选择文件的回调方法 selectFile:当前选中的文件 allFiles:还没上传的全部文件
console.info("当前选择了以下文件:");
console.info(selectFiles);
},
onDelete: function(file, files){ // 删除一个文件的回调方法 file:当前删除的文件 files:删除之后的文件
console.info("当前删除了此文件:");
console.info(file.name);
},
onSuccess: function(file, response){ // 文件上传成功的回调方法
console.info("此文件上传成功:");
console.info(file.name);
console.info("此文件上传到服务器地址:");
console.info(response);
var obj=eval("("+response+")");
$("#uploadInf").append("<p>上传成功,文件地址是:" + obj.result+ "</p>");
var imgs=$("#form_url").val();//获取原url组
//在url后添加新图片的url
if(imgs){
imgs+=","+obj.msg;
}else{
imgs+=obj.msg;
}
$("#form_url").val(imgs);//设置新url组
saveActivityInfo();
clearImg();//清除所有图片
initImg(imgs);//加载图片
},
onFailure: function(file, response){ // 文件上传失败的回调方法
console.info("此文件上传失败:");
console.info(file.name);
bootbox.alert("上传失败");
},
onComplete: function(response){ // 上传完成的回调方法
console.info("文件上传完成");
console.info(response);
}
});
}
这个控件自带裁剪功能,但是当图片大小过大的时候就会显示不全,因为它并没有调整图片大小,原本多大就是多大

这个是我修改过后的效果

现在可以根据显示区域的大小来对图片进行缩放
源码代码修改部分,我现在技术不够,代码写的比较烂
首先定义2个全局变量
var ScaleWidth=0;//裁剪后图片宽度
var Scale=1;//图片缩放倍数
首先找到定义图片宽度高度处,进行修改
zoomContent.html(image).delay(500).addClass("loading");
image.load(render).attr("src", para.src);
var editWidth = $("#zoom").width();
var editHeight = $("#zoom").height();
var xScale = 1;
var yScale = 1;
if(editWidth < image.width()){
xScale = editWidth/image.width();
}
if(editHeight < image.height()){
yScale = editHeight/image.height();
}
if(xScale > yScale){
xScale = yScale;
Scale=xScale;
}
其他地方也要相应修改
zoomContent.animate({
width: image.width()*xScale,
height: image.height()*xScale,
marginTop: -(image.height()*xScale / 2) - borderWidth,
marginLeft: -(image.width()*xScale / 2) - borderWidth
},
200,
function() {
show(image)
});
function show(image) {
image.show();
zoomContent.removeClass("loading");
self.createTailorPlug()
}
}
};
this.createTailorPlug = function() {
var width = $("#tailorImg").width();
var height = $("#tailorImg").height();
var editWidth = $("#zoom").width();
var editHeight = $("#zoom").height();
var xScale = 1;
var yScale = 1;
if(editWidth < width){
xScale = editWidth/width;
}
if(editHeight < height){
yScale = editHeight/height;
}
if(xScale > yScale){
xScale = yScale;
Scale=xScale;
}
ScaleWidth=width*xScale;
$("#tailorImg").css("width",width*xScale);
$("#tailorImg").css("height",height*xScale);
$("#tailorImg").css("position","relative");
var x1 = (width*Scale/2)-(width*Scale/5);
var y1 = (height*Scale/2)-(height*Scale/5);
var x2 = (width*Scale/2)+(width*Scale/5);
var y2 = (height*Scale/2)+(height*Scale/5);
好了,到此为止前端的工作完成,接下来是后端实现,项目用的是spingmvc+sping+hibernate的架构
java代码Controller部分:
@RequestMapping(value = "/saveImages")
@ResponseBody
public MessageBox saveImages(MultipartFile file,String id) throws Exception{
this.logAllRequestParams(); String rootPath = this.getSession().getServletContext().getRealPath("/");
Double width = Double.parseDouble(this.getReqParam("tailorWidth")); //图片缩放所需宽度
String tailor = this.getReqParam("tailor");
ImageCut cut = null;
if(!tailor.equals("false")){
cut = JSON.parseObject(tailor, ImageCut.class);
} //重命名
String fileName = file.getOriginalFilename();
String fileSuffix=fileName.substring(fileName.lastIndexOf(".")+1);
fileName=String.valueOf(System.currentTimeMillis())+"."+fileSuffix; String fileParant=rootPath + "/mirror/activity/"+id+"/";
File folder = new File(fileParant);
if (!folder.exists()){
folder.mkdirs();
}
File f = new File(folder,fileName);
file.transferTo(f);
//图片裁剪
if(CommonUtil.isNotBlank(cut)){
ImageCutUtil.covertImage(f, width, cut);
}else{
ImageCutUtil.commpressPic(f.getPath(), f.getPath());
}
return returnSuccessInfo(fileName,fileParant+fileName);
}
到此为止图片上传裁剪功能全部完成
图片上传裁剪zyupload的更多相关文章
- Uploadify & jQuery.imgAreaSelect 插件实现图片上传裁剪
在网站中需要一个图片上传裁剪的功能,借鉴这篇文章 Ajax+PHP+jQuery图片截图上传 的指点,找到了jquery.imgAreaSelect这个不错插件,能对图片进行自定义区域选择并给出坐标, ...
- 基于Jcrop的图片上传裁剪加预览
最近自己没事的时候研究了下图片上传,发现之前写的是有bug的,这里自己重新写了一个! 1.页面结构 <!DOCTYPE html> <html lang="en" ...
- 图片上传裁剪(asp.net)
图片在线裁剪功能 前台展现用jquery.Jcrop实现,后台使用 System.Drawing.Image类来进行裁剪 完整dome下载 http://download.csdn.net/detai ...
- JavaScript实现本地图片上传前进行裁剪预览
本项目支持IE8+,测试环境IE8,IE9,IE10,IE11,Chrome,FireFox测试通过 另:本项目并不支持Vue,React等,也不建议,引入JQuery和Vue.React本身提倡的开 ...
- PHP结合zyupload多功能图片上传实例
PHP结合zyupload多功能图片上传实例,支持拖拽和裁剪.可以自定义高度和宽度,类型,远程上传地址等. zyupload上传基本配置 $("#zyupload").zyUplo ...
- Jquery插件-Html5图片上传并裁剪
/** * 图片裁剪 * @author yanglizhe * 2015/11/16 */ (function($){ /** * Drag */ var Drag={obj:null,init:f ...
- 利用cropper插件裁剪本地图片,然后将裁剪过后的base64图片上传至七牛云空间
现在做的项目需要做一些图片处理,由于时间赶急,之前我便没有处理图片,直接将图片放在input[type=file]里面,以文件的形式提交给后台,这样做简直就是最低级的做法,之后各种问题便出来了,人物头 ...
- java多图片上传--前端实现预览--图片压缩 、图片缩放,区域裁剪,水印,旋转,保持比例。
java多图片上传--前端实现预览 前端代码: https://pan.baidu.com/s/1cqKbmjBSXOhFX4HR1XGkyQ 解压后: java后台: <!--文件上传--&g ...
- Django使用cropbox包来上传裁剪图片
1.使用cropbox包来上传裁剪图片,可见介绍:https://www.jianshu.com/p/6c269f0b48c0I ImgCrop包包括:css--style.css,js--cropb ...
随机推荐
- Protocol Buffers
今天来介绍一下"Protocol Buffers"(以下简称protobuf)这个玩意儿.本来俺在构思"生产者/消费者模式"系列的下一个帖子:关于生产者和消费者 ...
- ZOJ 3927 Programming Ability Test
水题,判断一下加起来是否大于等于80 #include<cstdio> #include<cstring> #include<cmath> #include< ...
- CodeForces 625D Finals in arithmetic
神奇的构造题,我的思路比较奇葩.搞了好久,看到WA on 91我绝望了,然后自己造数据,找到了错误,总算是AC了,现在是凌晨0:24分,看到AC之后,感动China! 我写的代码无比的长.....应该 ...
- python_json常用的方法
1. 什么是JSON? JSON 可以将 JavaScript 对象中表示的一组数据转换为字符串,然后就可以在函数之间轻松地传递这个字符串,或者在异步应用程序中将字符串从 Web 客户机传递给服务器端 ...
- js div截取字符串的长度
<div style="width:100%;" id="changdu">这个是字符串的长度</div> $("#chang ...
- IOS9中联系人对象的使用及增删改查操作的函数封装
之前克服重重困难把IOS9中新的类联系人搞明白了,现在把增删改查封装成了函数,如下: // // ViewController.m // IOS9中联系人CNContact的使用 // // Crea ...
- Use Wireshark to capture loopback traffic without a loopback adapter (转)
Use Wireshark to capture loopback traffic without a loopback adapter If you’ve ever used Wireshark f ...
- UVa 10911 - Forming Quiz Teams
题目大意:给出2*n个点,将这些点配成n对,使得所有点对中两点的距离之和尽量小. 用一个整数的二进制形式表示一个集合的子集,以每个集合为状态进行状态转移.具体参见<算法竞赛入门经典>9.5 ...
- 忘记Django登陆账号和密码的处理方法
Reference: http://nolinux.blog.51cto.com/4824967/1743392 公司部署了一套分布式网络监控系统,使用celery来做的分布式任务队列,针对celer ...
- Win10還原成最乾淨的狀態 不必重灌
系統不穩定時我們想到的第一個選擇就是重灌,如果你的作業系統是win10將會有另外一個新選擇,就是透過程式進行還原,讓你的電腦回到剛安裝時的清爽. 工具資訊 [軟體名稱]微軟 Refresh Windo ...