• 技术文章 >web前端 >js教程

    jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能

    小云云小云云2018-01-10 13:11:10原创1000
    本文主要介绍了jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一,需要的朋友可以参考下,希望能帮助到大家。

    上一节随笔中,我们已经知道了关于jQuery插件ImgAreaSelect基本的知识;那么现在看一下实例:

    首先,要知道我们应该实现什么功能?

    (1)图片能够实现上传预览功能

    (2)拖拽裁剪图片,使其能够显示裁剪后的区域

    (3)显示要裁剪区域的坐标

    其次,该如何引用该插件呢?

    那就具体看一下吧!

    第一步:先将样式和文件包引入(根据你自己的位置引入)

    <!--引入imgareaselect的css样式-->
    <link rel="stylesheet" type="text/css" href="../jquery.imgareaselect-0.9.10/css/imgareaselect-default.css" rel="external nofollow" rel="external nofollow" />
    <!--引入jquery包-->
    <script type="text/javascript" src="../jquery-1.11.2.min.js"></script>
    <!--引入imgareaselect的js文件-->
    <script type="text/javascript" src="../jquery.imgareaselect-0.9.10/scripts/jquery.imgareaselect.pack.js"></script>

    第二步:先用p布局样式,如下图所示

    <body>
     <p style="float:left; width:300px;">
     <p>亲,请上传图片并裁剪</p>
     <p style="width:300px; height:300px;float: left;">
      <!--原图-->  
      <img id="uploadPreview"/>
      <input id="uploadImage" type="file" name="photoimage" class="fimg1" onchange="PreviewImage();" /> <!--//对这个按钮加一个事件-->
     </p>
     </p>  
     <p style="float:left; width:300px;">
     <p style="font-size:110%; font-weight:bold; padding-left:0.1em;">
     选区预览
     </p>
     <p style="margin:0 1em; width:100px; height:100px;border: 1px solid black;">
      <p id="preview" style="width:100px; height:100px; overflow:hidden;">
      <!--裁剪后的图片-->
      <img id="tp" style="width:200px; height:200px;">
      </p>
     </p> 
     <!--做一个表格用来放选取图片的坐标-->
     <table style="margin-top:1em;">
      <thead>
      <tr>
      <th colspan="2" style="font-size:110%; font-weight:bold; text-align:left; padding-left: 0.1em;"> 坐标</th>
      </tr>
      </thead>
      <tbody>
      <tr>
      <td style="width:10%;"><b>X<sub>1</sub>:</b></td>
      <td style="width:30%;"><input type="text" id="x1" value="-" /></td>
      </tr>
      <tr>
      <td><b>Y<sub>1</sub>:</b></td>
      <td><input type="text" id="y1" value="-" /></td>
      </tr>
      <tr>  
      <td><b>X<sub>2</sub>:</b></td>
      <td><input type="text" id="x2" value="-" /></td>
      </tr>
      <tr>
      <td><b>Y<sub>2</sub>:</b></td>
      <td><input type="text" id="y2" value="-" /></td>
      </tr>  
      </tbody>
     </table> 
     </p>
     </p> 
     </body>

    大前端成长进阶课程:进入学习

      css样式:

    <style>
     #uploadPreview
     {
     width: 170px;
     height: 170px;   
     background-position: center center;
     background-size: cover;
     border: 1px solid brown;
     -webkit-box-shadow: 0 0 0px 0px rgba(0, 0, 0, 0);
     display: inline-block;
     }
     </style>

    第三步:实现图片的上传预览效果

    思路:通过input 将图片的 src传给第一个img,然后再将第一个img的src传给第二个img的src

    <script> 
    //通过input将图片路径传给第一个img
    $("#uploadImage").on("change", function(){
     // 得到一个参考文件列表
     var files = !!this.files ? this.files : []; 
     // 如果没有选择任何文件,或者没有文件读到就返回
     if (!files.length || !window.FileReader) return;
     // 只有进行选择的文件是一个形象
     if (/^image/.test( files[0].type)){
     // 创建一个新的FileReader的实例
     var reader = new FileReader(); 
     // 读取本地文件作为一个DataURL
     reader.readAsDataURL(files[0]);
     // 当加载时,图像数据设置为背景的p
     reader.onloadend = function(){
      //给第一个img添加路径 
     $("#uploadPreview").attr("src",this.result);
      //给第二个img添加路径 
      $("#tp").attr("src",this.result);
      //开启裁剪功能  
     $('#uploadPreview ').imgAreaSelect( {handles:true, fadeSpeed:200, onSelectEnd : preview});
     }
     }
    });
    </script>

    这样,就能够实现如下效果:

    点击浏览

    点击选择 :

    第四步:实现区域选择功能

    <script>
     function preview(img, selection)
     {
     if(!selection.width || !selection.height) //判断选取区域不为空
      return; 
      //分别取高宽比率 
     var scaleX = 100 / selection.width; 
     var scaleY = 100 / selection.height;  
     var img = new Image();
     //传路径
     img.src = document.getElementById('uploadPreview').src; 
     //给裁剪的图片定义高和宽
     $('#preview img').css( {
      width : Math.round(scaleX * 170), //170为第一个img的宽,不然截取的图片会有所缺失,可以自己试试 
      height: Math.round(scaleY * 170), //170为第一个img的高
      marginLeft: -Math.round(scaleX * selection.x1),
      marginTop: -Math.round(scaleY * selection.y1)
     }); 
     //显示坐标 
     $('#x1').val(selection.x1);
     $('#y1').val(selection.y1);
     $('#x2').val(selection.x2);
     $('#y2').val(selection.y2); 
     }
     </script>

    这样就可以实现如下效果啦~~~

    到这一步就可以实现头像的上传以及裁剪功能了,当然后期还要将路径添加到数据库就更完美了~~~~

    (------------------------------------------------------------------------此处应有分割线----------------------------------------------------------------------)

    如果你只想实现简单的图片裁剪功能,那么可以看看下面代码,此处不做注释了~~~

    当然,如果上边的代码看不太明白,也可以参照下面的这个进行修改,将图片上传预览功能添加上即可哈~~~~

    效果图:(对比图片就可以知道,下面这个就只是少了浏览功能,其他完全一样)

    <!DOCTYPE html>
    <html>
     <head>
     <meta charset="UTF-8">
     <title></title>
      <!--在HTML头部加入:-->
     <link rel="stylesheet" type="text/css" href="../jquery.imgareaselect-0.9.10/css/imgareaselect-default.css" rel="external nofollow" rel="external nofollow" />
     <script type="text/javascript" src="../jquery-1.11.2.min.js"></script>
     <script type="text/javascript" src="../jquery.imgareaselect-0.9.10/scripts/jquery.imgareaselect.pack.js"></script>
     <script type="text/javascript">
     $(document).ready(function() {
     $('#photo').imgAreaSelect( {handles:true, fadeSpeed:200, onSelectEnd : preview});
     });
    // 如果加上aspectRatio: '1:1',$('#photo').imgAreaSelect( {aspectRatio: '1:1',handles:true, fadeSpeed:200, onSelectEnd : preview});则选取区域固定为正方形。
     function preview(img, selection)
     {
     //等同于var scaleX = 100 / (selection.width || 1) 
     //先对||前面的进行布尔运算,如果结果是true(即width存在且不是0),就使用width,否则使用||后的变量1
     //也就是先检查 selection.width 有没有值,有的话就用 100 / 该值再付给 scaleX,没的话就用 100 / 1 来赋值;
     if(!selection.width || !selection.height)
      return; 
     var scaleX = 100 / selection.width;
     var scaleY = 100 / selection.height; 
     //设置裁剪后图片的宽高 
     $('#preview img').css( {
      width : Math.round(scaleX * 200),
      height: Math.round(scaleY * 200),
      marginLeft: -Math.round(scaleX * selection.x1),
      marginTop: -Math.round(scaleY * selection.y1)
     }); 
     $('#x1').val(selection.x1);
     $('#y1').val(selection.y1);
     $('#x2').val(selection.x2);
     $('#y2').val(selection.y2);
     $('w').val(selection.width);
     $('h').val(selection.height);
     }
     </script>
     </head>
     <body>
     <p>
     <!--选取的图片-->
     <p style="float:left; width:70%;">
     <p>
     Click and drag on the image to select an area.
     </p>
     <p style="margin:0 0.3em; width:200px; height:200px;">
      <img id="photo" src="./images/1.jpg" style="width:200px; height:200px;"/>
     </p>
     </p> 
     <!--截取的图片-->
     <p style="float:left; width:30%;">
     <p style="font-size:110%; font-weight:bold; padding-left:0.1em;">
     Selection Preview
     </p>
     <p style="margin:0 1em; width:100px; height:100px;">
      <p id="preview" style="width:100px; height:100px; overflow:hidden;">
      <img src="./images/1.jpg" style="width:200px; height:200px;">
      </p>  
     </p> 
     <table style="margin-top:1em;">
      <thead>
      <tr>
      <th colspan="2" style="font-size:110%; font-weight:bold; text-align:left; padding-left: 0.1em;"> Coordinates</th>
      </tr>
      </thead>
      <tbody>
      <tr>
      <td style="width:10%;"><b>X<sub>1</sub>:</b></td>
      <td style="width:30%;"><input type="text" id="x1" value="-" /></td>
      </tr>
      <tr>
      <td><b>Y<sub>1</sub>:</b></td>
      <td><input type="text" id="y1" value="-" /></td>
      </tr>
      <tr>
      <td><b>X<sub>2</sub>:</b></td>
      <td><input type="text" id="x2" value="-" /></td>
      </tr>
      <tr>
      <td><b>Y<sub>2</sub>:</b></td>
      <td><input type="text" id="y2" value="-" /></td>
      </tr>  
      </tbody>
     </table> 
     </p>
     </p>
     </body>
    </html>

    相关推荐:

    jQuery插件imgAreaSelect实例讲解

    利用jQuery插件imgAreaSelect实现获得选择域的图像信息

    imgareaselect + php实现图片裁剪

    以上就是jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:ImgAreaSelect jQuery 头像
    上一篇:jQuery插件imgAreaSelect实例讲解 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 一文详解多版本node的安装和管理• Angular学习之聊聊Http ( 错误处理 / 请求拦截 )• 浅析Angular中的Change Detection机制• 一文聊聊node中的path模块• 浅析Angular变更检测中的订阅异步事件
    1/1

    PHP中文网