1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > imgareaselect + php 裁剪和上传 jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能

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

时间:2020-06-22 20:45:16

相关推荐

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

本文主要介绍了jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一,需要的朋友可以参考下,希望能帮助到大家。

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

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

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

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

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

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

那就具体看一下吧!

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

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

亲,请上传图片并裁剪

选区预览

坐标

X1:Y1:X2:Y2:

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, 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]);

// 当加载时,图像数据设置为背景的p

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

}

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

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

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

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

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

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

$(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);

}

Click and drag on the image to select an area.

Selection Preview

Coordinates

X1:Y1:X2:Y2:

相关推荐:

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。