jQuery实现拖动剪裁图片作为头像


Posted in Javascript onDecember 28, 2016

图片上传是许多网站的一个常用的功能,有时需要对上传的图片做初步的选择裁剪,比如上传头像。下面就是一个使用HTML5+jQuery实现的图片上传裁剪特效,可以对选择要上传的图片做缩小、放大、拖动和裁剪,由何问起调试改进,有需要的朋友可以参考一下。在文后附有源码下载。

效果图:

jQuery实现拖动剪裁图片作为头像

需要引用的css文件为style.css,需要引用的js文件为jquery文件,可以到http://hovertree.com/h/bjaf/ati6k7yk.htm选择合适的版本下载,还需引用cropbox.js文件,这些文件在源码里面都有。

代码如下:

<!DOCTYPE html>
<html lang="zh">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> 
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>jQuery拖动剪裁图片作为头像代码 - 何问起</title>
<link rel="stylesheet" href="css/style.css" type="text/css" />
</head>
<body>
<div class="hovertreecontainer">
 <div class="imageBox">
 <div class="thumbBox"></div>
 <div class="spinner" style="display: none">Loading...</div>
 </div>
 <div class="action"> 
 <div class="new-contentarea tc"> 
 <a href="javascript:void(0)" class="upload-img">
 <label for="upload-file">上传图像</label>
 </a>
 <input type="file" class="" name="upload-file" id="upload-file" />
 </div>
 <input type="button" id="btnCrop" class="Btnsty_peyton" value="裁切">
 <input type="button" id="btnZoomIn" class="Btnsty_peyton" value="+" >
 <input type="button" id="btnZoomOut" class="Btnsty_peyton" value="-" >
 </div>
 <div class="cropped"></div>
</div>
<script src="http://down.hovertree.com/jquery/jquery-1.11.0.min.js" type="text/javascript"></script>
<script type="text/javascript" src="js/cropbox.js"></script>
<script type="text/javascript">
$(window).load(function() {
 var options =
 {
 thumbBox: '.thumbBox',
 spinner: '.spinner',
 imgSrc: 'img/rgevo2ea.jpg'
 }
 var cropper = $('.imageBox').cropbox(options);
 $('#upload-file').on('change', function(){
 var reader = new FileReader();
 reader.onload = function(e) {
 options.imgSrc = e.target.result;
 cropper = $('.imageBox').cropbox(options);
 }
 reader.readAsDataURL(this.files[0]);
 this.files = [];
 })
 $('#btnCrop').on('click', function(){
 var img = cropper.getDataURL();
 $('.cropped').html('');
 $('.cropped').append('<img src="'+img+'" align="absmiddle" style="width:64px;margin-top:4px;border-radius:64px;box-shadow:0px 0px 12px #7E7E7E;" ><p>64px*64px</p>');
 $('.cropped').append('<img src="'+img+'" align="absmiddle" style="width:128px;margin-top:4px;border-radius:128px;box-shadow:0px 0px 12px #7E7E7E;"><p>128px*128px</p>');
 $('.cropped').append('<img src="'+img+'" align="absmiddle" style="width:180px;margin-top:4px;border-radius:180px;box-shadow:0px 0px 12px #7E7E7E;"><p>180px*180px</p>');
 })
 $('#btnZoomIn').on('click', function(){
 cropper.zoomIn();
 })
 $('#btnZoomOut').on('click', function(){
 cropper.zoomOut();
 })
});
</script>
<div style="text-align:center;margin:50px 0; font:normal 14px/24px 'MicroSoft YaHei';">
<p>适用浏览器:360、FireFox、Chrome、Safari、Opera、傲游、搜狗、世界之窗. 不支持IE8及以下浏览器。</p>
<p>来源:<a href="http://hovertree.com/" target="_blank">何问起</a> <a href="http://hovertree.com/h/bjaf/7x8ev3fh.htm" target="_blank">说明</a></p>
</div>
</body>
</html>

源码下载:
http://wd.3water.com:81//201612/yuanma/hovertreejqimg8_3water.rar

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
ExtJS 工具栏 分页事件参数
Mar 05 Javascript
获得Javascript对象属性个数的示例代码
Nov 21 Javascript
收集json解析的四种方法分享
Jan 17 Javascript
jQuery可见性过滤器:hidden和:visibility用法实例
Jun 24 Javascript
js简单判断flash是否加载完成的方法
Jun 21 Javascript
jQuery+Ajax实现用户名重名实时检测
Jun 01 jQuery
Angularjs单选框相关的示例代码
Aug 17 Javascript
利用vue + koa2 + mockjs模拟数据的方法教程
Nov 22 Javascript
extract-text-webpack-plugin用法详解
Feb 14 Javascript
小程序封装路由文件和路由方法(5种全解析)
May 26 Javascript
微信小程序地图绘制线段并且测量(实例代码)
Jan 02 Javascript
一篇文章带你从零快速上手Rollup
Sep 07 Javascript
JS动态遍历json中所有键值对的方法(不知道属性名的情况)
Dec 28 #Javascript
javascript稀疏数组(sparse array)和密集数组用法分析
Dec 28 #Javascript
JS中闭包的经典用法小结(2则示例)
Dec 28 #Javascript
AngularJS实现网站换肤实例
Feb 19 #Javascript
详解js树形控件—zTree使用总结
Dec 28 #Javascript
js 轮播效果实例分享
Dec 28 #Javascript
JS正则RegExp.test()使用注意事项(不具有重复性)
Dec 28 #Javascript
You might like
php使用ICQ网关发送手机短信
2013/10/30 PHP
php获取网卡的MAC地址支持WIN/LINUX系统
2014/04/30 PHP
destoon设置自定义搜索的方法
2014/06/21 PHP
Thinkphp模板标签if和eq的区别和比较实例分析
2015/07/01 PHP
PHP快速排序quicksort实例详解
2016/09/28 PHP
php微信开发之百度天气预报
2016/11/18 PHP
PHP扩展Swoole实现实时异步任务队列示例
2019/04/13 PHP
弹出层之1:JQuery.Boxy (一) 使用介绍
2011/10/06 Javascript
Js日期选择器并自动加入到输入框中示例代码
2013/08/02 Javascript
jquery加载图片时以淡入方式显示的方法
2015/01/14 Javascript
jQuery中iframe的操作(点击按钮新增窗口)
2016/04/20 Javascript
全面解析Bootstrap中transition、affix的使用方法
2016/05/30 Javascript
Bootstrap登陆注册页面开发教程
2016/07/12 Javascript
基于JS如何实现给字符加千分符(65,541,694,158)
2016/08/03 Javascript
window.open不被拦截的简单实现代码(推荐)
2016/08/04 Javascript
Javascript中apply、call、bind的巧妙使用
2016/08/18 Javascript
bootstrapValidator自定验证方法写法
2016/12/01 Javascript
js获取元素下的第一级子元素的方法(推荐)
2017/03/05 Javascript
React进阶学习之组件的解耦之道
2017/08/07 Javascript
javascript 通过键名获取键盘的keyCode方法
2017/12/31 Javascript
JS自定义右键菜单实现代码解析
2020/07/16 Javascript
[18:20]DOTA2 HEROS教学视频教你分分钟做大人-昆卡
2014/06/11 DOTA
把MySQL表结构映射为Python中的对象的教程
2015/04/07 Python
Python进程间通信用法实例
2015/06/04 Python
分享一个简单的python读写文件脚本
2017/11/25 Python
Python中修改字符串的四种方法
2018/11/02 Python
Python中turtle库的使用实例
2019/09/09 Python
利用Pytorch实现简单的线性回归算法
2020/01/15 Python
美国现代家具购物网站:LexMod
2019/01/09 全球购物
Java和Javasciprt的区别
2012/09/02 面试题
介绍一下代理模式(Proxy)
2014/10/17 面试题
党的群众路线教育实践活动通讯稿
2014/09/10 职场文书
民主评议政风行风活动心得体会
2014/10/29 职场文书
新员工试用期工作总结2015
2015/05/28 职场文书
盲山观后感
2015/06/11 职场文书
《秋思》教学反思
2016/02/23 职场文书