上一节随笔中,我们已经知道了关于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>
第二步:先用div布局样式,如下图所示
<body> <div style="float:left; width:300px;"> <p>亲,请上传图片并裁剪</p> <div style="width:300px; height:300px;float: left;"> <!--原图--> <img id="uploadPreview"/> <input id="uploadImage" type="file" name="photoimage" class="fimg1" onchange="PreviewImage();" /> <!--//对这个按钮加一个事件--> </div> </div> <div style="float:left; width:300px;"> <p style="font-size:110%; font-weight:bold; padding-left:0.1em;"> 选区预览 </p> <div style="margin:0 1em; width:100px; height:100px;border: 1px solid black;"> <div id="preview" style="width:100px; height:100px; overflow:hidden;"> <!--裁剪后的图片--> <img id="tp" style="width:200px; height:200px;"> </div> </div> <!--做一个表格用来放选取图片的坐标--> <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> </div> </div> </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]);
// 当加载时,图像数据设置为背景的div
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>
<div>
<!--选取的图片-->
<div style="float:left; width:70%;">
<p>
Click and drag on the image to select an area.
</p>
<div style="margin:0 0.3em; width:200px; height:200px;">
<img id="photo" src="./images/1.jpg" style="width:200px; height:200px;"/>
</div>
</div>
<!--截取的图片-->
<div style="float:left; width:30%;">
<p style="font-size:110%; font-weight:bold; padding-left:0.1em;">
Selection Preview
</p>
<div style="margin:0 1em; width:100px; height:100px;">
<div id="preview" style="width:100px; height:100px; overflow:hidden;">
<img src="./images/1.jpg" style="width:200px; height:200px;">
</div>
</div>
<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>
</div>
</div>
</body>
</html>
以上所述是小编给大家介绍的jQuery插件ImgAreaSelect实现头像上传预览和裁剪功能实例讲解一,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# jquery
# imgareaselect
# 头像上传预览
# 裁剪
# struts2+jsp+jquery+Jcrop实现图片裁剪并上传实例
# 利用jQuery插件imgAreaSelect实现图片上传裁剪(同步显示图像位置信息)
# 利用jQuery插件imgAreaSelect实现图片上传裁剪(放大缩小)
# jquery.Jcrop结合JAVA后台实现图片裁剪上传实例
# jQuery实现图片上传和裁剪插件Croppie
# jQuery插件jcrop+Fileapi完美实现图片上传+裁剪+预览的代码分享
# jQuery+PHP实现上传裁剪图片
# 第一个
# 上传
# 就可以
# 第二个
# 看一下
# 就用
# 小编
# 自己的
# 是一个
# 如果你
# 那就
# 在此
# 给大家
# 少了
# 如果没有
# 布尔
# 做一个
# 要知道
# 使其
# 只想
相关文章:
合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍?
如何自定义建站之星网站的导航菜单样式?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
如何快速搭建高效简练网站?
北京企业网站设计制作公司,北京铁路集团官方网站?
宝塔面板如何快速创建新站点?
长沙做网站要多少钱,长沙国安网络怎么样?
建站主机功能解析:服务器选择与快速搭建指南
名字制作网站免费,所有小说网站的名字?
宿州网站制作公司兴策,安徽省低保查询网站?
建站之星后台密码遗忘或太弱?如何重置与强化?
如何在万网自助建站平台快速创建网站?
重庆市网站制作公司,重庆招聘网站哪个好?
可靠的网站设计制作软件,做网站设计需要什么样的电脑配置?
高防服务器租用如何选择配置与防御等级?
如何快速搭建自助建站会员专属系统?
打鱼网站制作软件,波克捕鱼官方号怎么注册?
如何在阿里云虚拟服务器快速搭建网站?
如何在腾讯云服务器上快速搭建个人网站?
网站制作软件免费下载安装,有哪些免费下载的软件网站?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
建站之星后台管理系统如何操作?
建站之星如何快速解决建站难题?
网站制作说明怎么写,简述网页设计的流程并说明原因?
建站主机如何选?性能与价格怎样平衡?
MySQL查询结果复制到新表的方法(更新、插入)
Swift中swift中的switch 语句
建站之星收费标准详解:套餐费用及年费价格表一览
高防服务器:AI智能防御DDoS攻击与数据安全保障
制作网站怎么制作,*游戏网站怎么搭建?
自助网站制作软件,个人如何自助建网站?
制作网站外包平台,自动化接单网站有哪些?
实例解析Array和String方法
建站之星如何防范黑客攻击与数据泄露?
网站建设设计制作营销公司南阳,如何策划设计和建设网站?
如何在建站主机中优化服务器配置?
制作证书网站有哪些,全国城建培训中心证书查询官网?
如何在Golang中实现微服务服务拆分_Golang微服务拆分与接口管理方法
内网网站制作软件,内网的网站如何发布到外网?
移民网站制作流程,怎么看加拿大移民官网?
教学论文网站制作软件有哪些,写论文用什么软件
?
如何选择最佳自助建站系统?快速指南解析优劣
建站之星代理平台如何选择最佳方案?
公司门户网站制作流程,华为官网怎么做?
建站之星如何一键生成手机站?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
建站之星安装失败:服务器环境不兼容?
贸易公司网站制作流程,出口贸易网站设计怎么做?
模具网站制作流程,如何找模具客户?
*请认真填写需求信息,我们会在24小时内与您取得联系。