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

前端之家收集整理的这篇文章主要介绍了jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

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

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

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

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

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

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

那就具体看一下吧!

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

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

亲,请上传图片并裁剪

X1:Y1:X2:Y2:

  css样式:

404_76@ #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); display: inline-block; }

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

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

//通过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]); // 当加载时,图像数据设置为背景的div reader.onloadend = function(){ //给第一个img添加路径 $("#uploadPreview").attr("src",this.result); //给第二个img添加路径 $("#tp").attr("src",this.result); //开启裁剪功能 $('#uploadPreview ').imgAreaSelect( {handles:true,fadeSpeed:200,onSelectEnd : preview}); } } });

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

点击浏览

点击选择 :

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

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); }

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

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

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

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

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

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

<Meta charset="UTF-8">
Click and drag on the image to select an area.

X1:Y1:X2:Y2:

以上所述是小编给大家介绍的jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持

猜你在找的jQuery相关文章