jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一 - 前端之家
jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一
随笔中,我们已经知道了关于jQuery插件ImgAreaSelect基本的知识;那么现在看一下实例:
首先,要知道我们应该实现什么功能?
(1)图片能够实现上传预览功能
(2)拖拽裁剪图片,使其能够显示裁剪后的区域
(3)显示要裁剪区域的坐标
其次,该如何引用该插件呢?
那就具体看一下吧!
第一步:先将样式和文件包引入(根据你自己的位置引入)
第二步:先用div布局样式,如下图所示
css样式:
#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.