图片上传裁剪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 ...
随机推荐
- mysql优化----第一篇:综述
一 系统层面 查看CPU和IO状态,确定瓶颈.增 更换设备 二 数据库层面 1 参数优化. 参考文章<mysql性能优化----调整参数>增大数据库内存缓存等设置. 参考 http: ...
- 使用USBASP给Arduino烧写bootloader教程
源:使用UsbAsp给UNO烧写bootloader ATMEGA16U2.ATMEGA328P固件烧写教程 arduino板由于操作不发导致固件损坏,或者想更新固件怎么办?今天给大家介绍一下如何使用 ...
- keil mdk中如何确保某一段程序不被优化掉(转)
源:keil mdk中如何确保某一段程序不被优化掉 使用mdk编程,假如有一个有用的函数你定义了但是没有显式的调用,mdk在默认方式下,将会把这个函数从整个程序总删除掉,以节省ROM. 比如,你在RO ...
- php 模式
设计模式1.单例模式类的计划生育1.让该类在外界无法造对象2.让外界可以造一个对象,做一个静态方法返回对象3.在类里面通过静态变量控 class Dog { static $dx; public $t ...
- js设置文本框只能输入数字
JS判断只能是数字和小数点 1.文本框只能输入数字代码(小数点也不能输入) <input onkeyup="this.value=this.value.replace(/\D/g,'' ...
- 自己实现一个IOC(控制翻转,DI依赖注入)容器
1.新建一个控制台应用程序 TestIOC 2.新增一个 IocFactory类 using System; using System.Collections.Generic; using Syste ...
- ubuntu 16.04 php 安装curl方法
先查看自己的php是否已经安装了curl.方法如下:1.在web服务器目录( Ubuntu下的通常为 /var/www )新建test.php文件2.编辑文件,键入下面一行代码:<?php ph ...
- Ubuntu各个版本支持时间
早期版本:
- 环信 之 iOS 客户端集成三:基础功能
SDK中,大部分与网络有关的操作,都有三种方法: 同步方法 通过delegate回调的异步方法.要想能收到回调,必须要注册为:[[EaseMob sharedInstance].chatManager ...
- 基于arm开发板四个按键控制四个灯亮
基于s5pv2410,cortex a8的四个按键每一个按键点了对应的灯 对于用汇编来编程的话不难,重点在于数据手册,电路图,管脚的看懂 直接上代码 .globl _start_start: ldr ...