先看一下整体效果

页面html

                <div class="row">
<div class="tabs-container">
<ul class="nav nav-tabs">
<li>
<a style="color: #676a6c;padding: 10px 30px 10px 40px;"> 上传头像<span style="color:red;">*</span></a>
</li>
<li class="active">
<a data-toggle="tab" href="#tab-1" aria-expanded="true"> 本地上传</a>
</li>
<li class="">
<a data-toggle="tab" href="#tab-2" aria-expanded="false">相册选取</a>
</li>
</ul>
<div class="tab-content">
<div id="tab-1" class="tab-pane active">
<div class="panel-body" style="height:475px">
<div class="container">
<div class="imageBox">
<div class="thumbBox"></div>
<div class="spinner" style="display: none">Loading...</div>
</div>
<div class="cropped"></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>
</div>
</div>
<div id="tab-2" class="tab-pane">
<div class="panel-body" id="Album" style="height:475px;overflow: scroll;overflow-x: hidden;">
<a class="fancybox" title="选取该照片">
<img src="/assets/img/Inteall/HeadPortrait/user_Doctor_01.jpg" alt="图片" />
</a>
<a class="fancybox" title="选取该照片">
<img src="/assets/img/Inteall/HeadPortrait/user_Doctor_02.jpg" alt="图片" />
</a>
<a class="fancybox" title="选取该照片">
<img src="/assets/img/Inteall/HeadPortrait/user_Doctor_03.jpg" alt="图片" />
</a>
<a class="fancybox" title="选取该照片">
<img src="/assets/img/Inteall/HeadPortrait/user_Doctor_04.jpg" alt="图片" />
</a>
<a class="fancybox" title="选取该照片">
<img src="/assets/img/Inteall/HeadPortrait/user_Doctor_05.jpg" alt="图片" />
</a>
<a class="fancybox" title="选取该照片">
<img src="/assets/img/Inteall/HeadPortrait/user_Doctor_06.jpg" alt="图片" />
</a>
</div>
</div>
</div>
</div>
</div>

页面js引用

<script src="/assets/js/jquery.js"></script>
<script src="~/assets/js/cropbox/cropbox.js"></script>
<script type="text/javascript">
var HeaderImg = null, EditHeaderImg = null, cropper = null, options =
{
thumbBox: '.thumbBox',
spinner: '.spinner',
imgSrc: "/assets/img/Inteall/HeadPortrait/user_Doctor_01.jpg",
loadAfter: function () { $('#btnCrop').click(); }
};
$(window).load(function () {
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[]);
this.files = null;
});
$('#btnCrop').on('click', function () {
HeaderImg = 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="' + HeaderImg + '" 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();
});
$(".imageBox").autoScroll();
$("#Album").autoScroll(); $('.fancybox img').each(function () {
$(this).click(function () {
options.imgSrc = $(this).attr('src');
cropper = $('.imageBox').cropbox(options);
$('.nav-tabs li:nth(1) a').click();
$('#btnCrop').click();
});
});
});
</script>

cropbox.js

/**
* Created by ezgoing on 14/9/2014.
*/ "use strict";
(function (factory) {
if (typeof define === 'function' && define.amd) {
define(['jquery'], factory);
} else {
factory(jQuery);
}
}(function ($) {
var cropbox = function (options, el) {
var el = el || $(options.imageBox),
obj =
{
state: {},
ratio: ,
options: options,
imageBox: el,
thumbBox: el.find(options.thumbBox),
spinner: el.find(options.spinner),
image: new Image(),
getDataURL: function () {
var width = this.thumbBox.width(),
height = this.thumbBox.height(),
canvas = document.createElement("canvas"),
dim = el.css('background-position').split(' '),
size = el.css('background-size').split(' '),
dx = parseInt(dim[]) - el.width() / + width / ,
dy = parseInt(dim[]) - el.height() / + height / ,
dw = parseInt(size[]),
dh = parseInt(size[]),
sh = parseInt(this.image.height),
sw = parseInt(this.image.width); canvas.width = width;
canvas.height = height;
var context = canvas.getContext("2d");
context.drawImage(this.image, , , sw, sh, dx, dy, dw, dh);
var imageData = canvas.toDataURL('image/png');
return imageData;
},
getBlob: function () {
var imageData = this.getDataURL();
var b64 = imageData.replace('data:image/png;base64,', '');
var binary = atob(b64);
var array = [];
for (var i = ; i < binary.length; i++) {
array.push(binary.charCodeAt(i));
}
return new Blob([new Uint8Array(array)], { type: 'image/png' });
},
zoomIn: function () {
this.ratio *= 1.1;
setBackground();
},
zoomOut: function () {
this.ratio *= 0.9;
setBackground();
},
loadAfter: options.loadAfter || function () { }
},
setBackground = function (IsOnload) {
var w = parseInt(obj.image.width) * obj.ratio;
var h = parseInt(obj.image.height) * obj.ratio; var pw = (el.width() - w) / ;
var ph = (el.height() - h) / ; el.css({
'background-image': 'url(' + obj.image.src + ')',
'background-size': w + 'px ' + h + 'px',
'background-position': pw + 'px ' + ph + 'px',
'background-repeat': 'no-repeat'
});
},
imgMouseDown = function (e) {
e.stopImmediatePropagation(); obj.state.dragable = true;
obj.state.mouseX = e.clientX;
obj.state.mouseY = e.clientY;
},
imgMouseMove = function (e) {
e.stopImmediatePropagation(); if (obj.state.dragable) {
var x = e.clientX - obj.state.mouseX;
var y = e.clientY - obj.state.mouseY; var bg = el.css('background-position').split(' '); var bgX = x + parseInt(bg[]);
var bgY = y + parseInt(bg[]); el.css('background-position', bgX + 'px ' + bgY + 'px'); obj.state.mouseX = e.clientX;
obj.state.mouseY = e.clientY;
}
},
imgMouseUp = function (e) {
e.stopImmediatePropagation();
obj.state.dragable = false;
},
zoomImage = function (e) {
e.originalEvent.wheelDelta > || e.originalEvent.detail < ? obj.ratio *= 1.1 : obj.ratio *= 0.9;
setBackground();
} obj.spinner.show();
obj.image.onload = function () {
obj.spinner.hide();
setBackground('onload'); el.bind('mousedown', imgMouseDown);
el.bind('mousemove', imgMouseMove);
$(window).bind('mouseup', imgMouseUp);
el.bind('mousewheel DOMMouseScroll', zoomImage);
obj.loadAfter();
};
obj.image.src = options.imgSrc;
el.on('remove', function () { $(window).unbind('mouseup', imgMouseUp) }); return obj;
}; jQuery.fn.cropbox = function (options) {
return new cropbox(options, this);
};
})); $.fn.extend({
"preventScroll": function () {
$(this).each(function () {
var _this = this;
if (navigator.userAgent.indexOf('Firefox') >= ) { //firefox
_this.addEventListener('DOMMouseScroll', function (e) { e.preventDefault(); }, false);
} else {
_this.onmousewheel = function (e) {
return false;
};
}
})
},
"autoScroll": function () {
$(this).each(function () {
var _this = this;
if (navigator.userAgent.indexOf('Firefox') >= ) { //firefox
_this.addEventListener('DOMMouseScroll', function (e) {
_this.scrollTop += e.detail > ? : -;
e.preventDefault();
}, false);
} else {
_this.onmousewheel = function (e) {
e = e || window.event;
_this.scrollTop += e.wheelDelta > ? - : ;
return false;
};
}
})
}
});

cropbox.css

@charset "utf-8";

.container {
width: 400px;
position: relative;
font-family: 微软雅黑;
font-size: 12px;
margin-left: 0px;
} .container p {
line-height: 12px;
line-height: 0px;
height: 0px;
margin: 10px;
color: #bbb;
} .action {
width: 400px;
height: 30px;
margin: 10px ;
} .cropped {
position: absolute;
right: -230px;
top: ;
width: 200px;
/*border: 1px #ddd solid;*/
height: 300px;
padding: 4px;
/* box-shadow: 0px 0px 12px #ddd;*/
text-align: center;
} .imageBox {
position: relative;
height: 400px;
width: 400px;
border: 1px solid #aaa;
background: #fff;
overflow: hidden;
background-repeat: no-repeat;
cursor: move;
box-shadow: 4px 4px 12px #B0B0B0;
} .imageBox .thumbBox {
position: absolute;
top: %;
left: %;
width: 200px;
height: 200px;
margin-top: -100px;
margin-left: -100px;
box-sizing: border-box;
border: 1px solid rgb(, , );
box-shadow: 1000px rgba(, , , 0.5);
background: none repeat scroll % % transparent;
} .imageBox .spinner {
position: absolute;
top: ;
left: ;
bottom: ;
right: ;
text-align: center;
line-height: 400px;
background: rgba(,,,0.7);
} .Btnsty_peyton {
float: right;
width: 66px;
display: inline-block;
margin-bottom: 10px;
height: 30px;
line-height: 30px;
font-size: 14px;
color: #FFFFFF;
margin: 0px 2px;
background-color: #4dbec4;
border-radius: 3px;
text-decoration: none;
cursor: pointer;
box-shadow: 0px 0px 5px #B0B0B0;
border: 0px #fff solid;
}
/*选择文件上传*/
.new-contentarea {
width: 100px;
overflow: hidden;
margin: auto;
position: relative;
float: left;
} .new-contentarea label {
width: %;
height: %;
display: block;
} .new-contentarea input[type=file] {
width: 100px;
height: 30px;
background: #;
margin: auto;
position: absolute;
margin-right: -94px;
top: ;
right /*\**/: 0px\;
margin-right /*\**/: 0px\;
width /*\**/: 10px\;
opacity: ;
filter: alpha(opacity=);
z-index: ;
} a.upload-img {
width: 100px;
display: inline-block;
margin-bottom: 10px;
height: 30px;
line-height: 30px;
font-size: 14px;
color: #FFFFFF;
background-color: #4dbec4;
border-radius: 3px;
text-decoration: none;
border: 0px #fff solid;
box-shadow: 0px 0px 5px #B0B0B0;
} a.upload-img:hover {
background-color: #ec7e70;
} .tc {
text-align: center;
}

头像截取 图片上传 js插件的更多相关文章

  1. 图片上传JS插件梳理与学习

    项目的oper端和seller端,用了两个不同插件,简单了解一下: 一.seller端:AjaxUpload.js seller端使用的是 AjaxUpload.js ,封装好的一个库.调用时传入参数 ...

  2. 图片上传jQuery插件(兼容IE8)

      图片上传jQuery插件(兼容IE8) 代码来源 :https://github.com/zilan93/uploadImg   html <!DOCTYPE html> <ht ...

  3. 百度编辑器前后端二开图片上传Js Thinkphp tp5 ueditor

    百度编辑器图片上传Jsueditor.all.min.js 下载链接 链接:https://pan.baidu.com/s/1VNgw9ELgRRHKeCQheFkQTw 提取码:fnfi 使用方法: ...

  4. springMVC3 ckeditor3.6 图片上传 JS回调

    一.引入js文件 <script type="text/javascript" src="<%=base %>/resources/ckeditor/c ...

  5. 适用于各浏览器支持图片预览,无刷新异步上传js插件

    文件上传无疑是web应用中一个非常常用的功能,不管是PHP.jsp还是aspx.mvc等都会需要文件上传,但是众所周知当使用自带的文件上传功能时总会出现页面刷新的情况.当然现在有了html5这个好东西 ...

  6. 阿里云OSS图片上传plupload.js结合jq-weui 图片上传的插件

    项目中用到了oss上传,用的plupload,奈何样式上不敢恭维,特别是放在移动端上使用.于是自己把它移植到了jq weui的上传图片组件上. 更改:选择照片后确认即及时上传至oss服务器,不限制上传 ...

  7. 图片上传js

    var imgURL; function getImgURL(node) { try{ var file = null; if(node.files && node.files[0] ...

  8. js截取图片上传(仅原理)----闲的无聊了代码就不共享了!写的难看,不好意思给你们看了(囧)

    就算世界再坑爹,总有一些属性能带你走出绝望(伟大的absolute) 今天吐槽一下!......在我的世界里没有正统UI,所以效果图永远都是那么坑爹! 这里我要感谢有个position:absolut ...

  9. ASP.Net MVC3 图片上传详解(form.js,bootstrap)

    图片上传的插件很多,但很多时候还是不能切合我们的需求,我这里给大家分享个我用一个form,file实现上传四张图片的小demo.完全是用jquery前后交互,没有用插件. 最终效果图如下: 玩过花田人 ...

随机推荐

  1. 【Docker 命令】- run命令

    docker run :创建一个新的容器并运行一个命令 语法: docker run [OPTIONS] IMAGE [COMMAND] [ARG...] OPTIONS说明: -a stdin: 指 ...

  2. oracle怎样查询索引的使用情况

    查询用户的索引select index_name,table_name,tablespace_name, index_type,uniqueness , status from dba_indexes ...

  3. Angular-Cli中引用第三方库

    最近在学习angular(AngularJS 2),根据教程使用angular-cli新建项目, 然而在添加JQuery和Bootstrap第三方库时遇到了问题... 初试 我最初的想法是直接将相对路 ...

  4. perf record -c

    如果perf record -c -c后面接的是sample_period,也就是说你让这个事件没 我的loop进程一直在执行,我的CPU的频率是2.6G hz,也就是说每一秒会有2,600,000, ...

  5. Android基础------Intent组件

    1.什么是intent 同Activity一样,也是Android应用组件在Android中承担着一种指令输出的作用Intent负责对应用中一次操作的动作及动作相关的数据进行描述.Android则根据 ...

  6. 第72天:jQuery实现下拉菜单

    jQuery实现下拉菜单 一.居中 1.块元素居中:给块元素本身设置:margin:0 auto;,块元素必须设置宽度 2.行内块元素居中:给元素父级设置text-algin:center; < ...

  7. 【codevs1380】没有上司的舞会 树形dp

    题目描述 Ural大学有N个职员,编号为1~N.他们有从属关系,也就是说他们的关系就像一棵以校长为根的树,父结点就是子结点的直接上司.每个职员有一个快乐指数.现在有个周年庆宴会,要求与会职员的快乐指数 ...

  8. iphone手机与PC蓝牙出现感叹号且无法修复解决方案

    解决方案如下: 1.需要下载Windows Mobile 6.5 的驱动 drvupdate-amd64.exe ,下载需要正版验证,手动安装驱动,具体步骤Google 2. 如果在BlueTooth ...

  9. [洛谷P2495][SDOI2011]消耗战

    题目大意:有一棵$n(n\leqslant2.5\times10^5)$个节点的带边权的树,$m$个询问,每次询问给出$k(\sum\limits_{i=1}^mk_i\leqslant5\times ...

  10. Balanced Sequence(毒瘤啊)排序贪心 HDU多校

    Problem Description Chiaki has n strings s1,s2,…,sn consisting of '(' and ')'. A string of this type ...