zoukankan      html  css  js  c++  java
  • 图片上传裁剪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({
                             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);
        }

    到此为止图片上传裁剪功能全部完成

  • 相关阅读:
    Flash 全局安全性设置面板
    响应式布局的一个例子mark
    移动平台WEB前端开发技巧汇总
    自定义事件机制——观察者模式
    学习之响应式Web设计:Media Queries和Viewports
    常用栅格布局方案
    观察者模式的一个例子
    二进制文件转换为文本工具
    C#面向对象名词比较(二)
    MSN消息提示类
  • 原文地址:https://www.cnblogs.com/GuoJunwen/p/6392623.html
Copyright © 2011-2022 走看看