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 相关文章推荐
js GridView 实现自动计算操作代码
Mar 25 Javascript
js判断IE6/IE7/FF的代码[XMLHttpRequest]
Feb 16 Javascript
基于jquery的仿百度搜索框效果代码
Apr 11 Javascript
Extjs优化(二)Form表单提交通用实现
Apr 15 Javascript
Node.js的MongoDB驱动Mongoose基本使用教程
Mar 01 Javascript
关于微信上网页图片点击全屏放大效果
Dec 19 Javascript
Node.js  REPL (交互式解释器)实例详解
Aug 06 Javascript
React.Js添加与删除onScroll事件的方法详解
Nov 03 Javascript
js+canvas实现滑动拼图验证码功能
Mar 26 Javascript
用Node编写RESTful API接口的示例代码
Jul 04 Javascript
vue-cli3添加模式配置多环境变量的方法
Jun 05 Javascript
js实现html滑动图片拼图验证
Jun 24 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中配置文件操作 如config.php文件的读取修改等操作
2012/07/07 PHP
关于UEditor编辑器远程图片上传失败的解决办法
2012/08/31 PHP
PHP中对于浮点型的数据需要用不同的方法解决
2014/03/11 PHP
PHP中4个加速、缓存扩展的区别和选用建议
2014/03/12 PHP
在Linux系统下一键重新安装WordPress的脚本示例
2015/06/30 PHP
详解PHP swoole process的使用方法
2017/08/26 PHP
javascript 获取页面的高度及滚动条的位置的代码
2010/05/06 Javascript
关于jquery动态增减控件的一些想法和小插件
2010/08/01 Javascript
JSONP跨域的原理解析及其实现介绍
2014/03/22 Javascript
jQuery实现Twitter的自动文字补齐特效
2014/11/28 Javascript
Shell脚本实现Linux系统和进程资源监控
2015/03/05 Javascript
在AngularJS中使用AJAX的方法
2015/06/17 Javascript
jQuery实现TAB选项卡切换特效简单演示
2016/03/04 Javascript
AngularJS基础 ng-include 指令简单示例
2016/08/01 Javascript
对js中回调函数的一些看法
2016/08/29 Javascript
ion content 滚动到底部会遮住一部分视图的快速解决方法
2016/09/06 Javascript
js实现横向拖拽导航条功能
2017/02/17 Javascript
Vue.js结合bootstrap实现分页控件
2017/03/10 Javascript
详解Immutable及 React 中实践
2018/03/01 Javascript
JS 实现缓存算法的示例(FIFO/LRU)
2018/03/20 Javascript
Vue使用v-viewer实现图片预览
2020/10/21 Javascript
python的paramiko模块实现远程控制和传输示例
2017/10/13 Python
Python工厂函数用法实例分析
2018/05/14 Python
使用python存储网页上的图片实例
2018/05/22 Python
python tkinter界面居中显示的方法
2018/10/11 Python
pytorch实现onehot编码转为普通label标签
2020/01/02 Python
jupyter notebook中新建cell的方法与快捷键操作
2020/04/22 Python
python实现从ftp上下载文件的实例方法
2020/07/19 Python
如何用css3实现switch组件开关的方法
2018/02/09 HTML / CSS
如何用Python输出一个Fibonacci数列
2016/08/28 面试题
土木工程专业大学毕业生求职信
2013/10/13 职场文书
小学生成长感言
2014/01/30 职场文书
应届毕业生如何写求职信
2014/02/16 职场文书
司法助理专业自荐书
2014/06/13 职场文书
典型事迹材料范文
2014/12/29 职场文书
运动会跳远广播稿
2015/08/19 职场文书