亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

js+jquery實現圖片裁剪功能

2019-11-20 13:31:30
字體:
來源:轉載
供稿:網友

現在我們在使用各大網站的個人中心時,都有個上傳個人頭像的功能。用戶在上傳了個人照片之后,可能不符合網站的要求,于是要求用戶對照片進行裁剪,最終根據用戶裁剪的尺寸生成頭像。這個功能真是太棒了,原來不懂js的時候,感覺很神奇,太神奇了。心想哪天要是自己也能搞明白這里面的技術,那該多牛呀~大家是不是也有何我一樣的想法呀~哈哈~~

下面我們就來用javascript來實現這個功能吧。

復制代碼 代碼如下:

<!DOCTYPE html>
<html xmlns="<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>clip</title>
<style type="text/css">
*{ padding:0; margin:0;}
ul{ list-style-type:none; overflow:hidden; zoom:1; width:1000px; margin:30px auto; }
li{ float:left; width:500px;}
#container{width:480px; height:480px; margin:0 auto; border:1px solid #999; position:relative;background:url(
http://images.cnblogs.com/cnblogs_com/wtcsy/192373/r_xx.jpg);}
#container .block{height:100px; width:100px; border:1px solid #000000; position:absolute; left:50px; top:50px; background:#fff;filter:alpha(opacity=30);opacity:0.3; cursor:move;}
#container .tips{ position:absolute; padding:5px; border:1px solid #ccc;background:#fff;filter:alpha(opacity=60);opacity:0.6; display:none; font-size:12px; color:#333; ;}
.tips span{ display:inline-block;zoom:1; width:28px;}
.rRightDown,.rLeftDown,.rLeftUp,.rRightUp,.rRight,.rLeft,.rUp,.rDown{
position:absolute;background:#f00;width:6px;height:6px;z-index:5;font-size:0;}
.rLeftDown,.rRightUp{cursor:ne-resize;}
.rRightDown,.rLeftUp{cursor:nw-resize;}
.rRight,.rLeft{cursor:e-resize;}
.rUp,.rDown{cursor:n-resize;}
.rRightDown{ bottom:-3px; right:-3px;}
.rLeftDown{ bottom:-3px; left:-3px;}
.rRightUp{ top:-3px; right:-3px;}
.rLeftUp{ top:-3px; left:-3px;}
.rRight{ right:-3px; top:50%}
.rLeft{ left:-3px; top:50%}
.rUp{ top:-3px; left:50%}
.rDown{ bottom:-3px; left:50%}
#imgC{ border:1px solid #CCC; width:0; height:0; margin:0 auto;background:url(http://images.cnblogs.com/cnblogs_com/wtcsy/192373/r_xx.jpg);}
.code {
    background: none repeat scroll 0 0 #E3F4F9;
    border: 1px solid #BAE2F0;
    font: 12px "Courier New",Courier,monospace;
    margin: 30px auto;
    padding: 10px 10px 40px;
 width:980px;
}
.code p{ height:24px; line-height:24px;}
.code span{ display:inline-block;zoom:1; margin-right:5px; width:85px; font-weight:bold; color:#00F}
</style>
</head>
<body>
<div class="code">
 <div class="how">使用方法</div>
    <p>$("#container").clip({
  imgC : $("#imgC"),
        blockClass : "block",
        tipsClass  : "tips"       
 });</p>
    <p><span>imgC :</span> 表示裁剪圖片的容器,也就是右邊的圖</p>
    <p><span>blockClass :</span> block的樣式名  也就是頁面上的可以拖動的滑塊的樣式 因為怕和別的頁面上的樣式重名  默認是block</p>
    <p><span>tipsClass  :</span> tips的樣式名   也就是頁面上顯示left width height top的那個span的樣式名 默認是tips</p>
</div>
<ul>
 <li>
     <div id="container"></div>
    </li>
    <li>
     <div id="imgC"></div>
    </li>
</ul>
<script type="text/javascript" src=">
<script type="text/javascript">
(function(){
 var dBody = document.body,
  dDoc = document.documentElement,
  ie   = $.browser.msie;
 ie&&($.browser.version=="6.0")
  &&document.execCommand("BackgroundImageCache", false, true); 
 var  clip =  function(options){
  this.init.call(this,options); 
 }
 clip.prototype = {
  options :{
   moveCallBack : function(){},
   blockClass : "block",
   tipsClass  : "tips"
  },
  init : function(options){   
   $.extend(this,this.options,options||{});
   if(!this.container || !this.imgC){
    return;
   }
   this.container = $(this.container);
   var self = this;
   this.block = $('<div class="'+this.blockClass+'">/
     <div action="rightDown" class="rRightDown"></div>/
     <div action="leftDown" class="rLeftDown"></div>/
     <div action="rightUp" class="rRightUp"></div>/
     <div action="leftUp" class="rLeftUp"></div>/
     <div action="right" class="rRight"></div>/
     <div action="left" class="rLeft"></div>/
     <div action="up" class="rUp"></div>/
     <div action="down" class="rDown" ></div>/
       </div>')
   .bind("mousedown.r",function(e){self.start(e)})
   .appendTo(this.container[0]);
   this.tips = $('<span class="'+this.tipsClass+'" />').appendTo(this.container[0]);
   this.setImg();
  },
  setImg : function(){
   var block = this.block;
   var left  = block.css("left"),
    top   = block.css("top"),
    height = block.height(),
    width  = block.width();
   this.imgC.css({
    height: height,
    width : width,
    "background-position" : "-"+left+" -"+top
   });
   this.tips.html("left:<span>"+parseInt(left) + "</span>top:<span>" + +parseInt(top) + "</span>width:<span>"+width+ "</span>height:<span>"+height+"</span>");
  },
  start : function(e){      
   var $elem     = $(e.target),
    block     = this.block,
    self      = this,
    move      = false,
    container = this.container,
    action    = $elem.attr("action");
   //這個 每次都要計算 基本dom結構的改變 瀏覽器的縮放 都會讓里面的值發生改變 
   this.offset = $.extend({height:container.height(),width:container.width()},container.offset());
   this.blockOriginal = {height:block.height(),width:block.width(),left:parseInt(block.css("left")),top:parseInt(block.css("top"))};
   if(action){
    this.fun = this[action];    
   }else{
    this.x = e.clientX - this.offset.left - this.blockOriginal.left ;
    this.y = e.clientY - this.offset.top - this.blockOriginal.top;
    move = true;
   }   
   ie
    &&this.block[0].setCapture();
   this.tips.show();
   $(document)
    .bind("mousemove.r",function(e){self.move(e,move)})
    .bind("mouseup.r",function(){self.end()});   
  },
  end  : function(){
   $(document)
    .unbind("mousemove.r")
    .unbind("mouseup.r");
   ie 
    &&this.block[0].releaseCapture();
   this.tips.hide(); 
  },
  move : function(e,isMove){
   window.getSelection
    ? window.getSelection().removeAllRanges()
    : document.selection.empty();
    
   var block = this.block; 
   if(isMove){
    var left = Math.max(0,e.clientX - this.offset.left - this.x);
    left = Math.min(left,this.offset.width - this.blockOriginal.width);
    var top = Math.max(0,e.clientY - this.offset.top - this.y);
    top = Math.min(top,this.offset.height - this.blockOriginal.height);
    block.css({left:left,top:top});    
   }else{
    var offset = this.fun(e);
    block.css(offset);
   }
   
   this.setImg();
   this.moveCallBack();
  },
  down : function(e){
   var blockOriginal = this.blockOriginal,
    sTop = Math.max(dBody.scrollTop,dDoc.scrollTop), //出現垂直方向滾動條時候 要計算這個 
    offset = this.offset;
    
   if(e.clientY-offset.top>=blockOriginal.top-sTop){
    var height = Math.min(offset.height - blockOriginal.top,e.clientY-offset.top-blockOriginal.top+sTop),
     top = blockOriginal.top;
   }else{
    var height = Math.min(offset.top+blockOriginal.top-e.clientY-sTop,blockOriginal.top),
     top = Math.max(e.clientY - offset.top+sTop,0);
   }
   return {height:height, top:top};
  },
  up : function(e){
   var blockOriginal = this.blockOriginal,
    sTop = Math.max(dBody.scrollTop,dDoc.scrollTop),
    offset = this.offset;
   if(e.clientY-offset.top-blockOriginal.height<=blockOriginal.top-sTop){
    var top = Math.max(e.clientY-offset.top+sTop,0),
     maxHeight = blockOriginal.top + blockOriginal.height,
     height = Math.min(maxHeight,blockOriginal.top + blockOriginal.height -(e.clientY-offset.top)-sTop);     
   }else{
    var height = Math.min(e.clientY-offset.top-blockOriginal.top-blockOriginal.height+sTop,offset.height-blockOriginal.top-blockOriginal.height),
     top = blockOriginal.top+blockOriginal.height;  
   }
   return {height:height, top:top};
  },
  left : function(e){
   var blockOriginal = this.blockOriginal,
    offset = this.offset;
    
   if(e.clientX - offset.left - blockOriginal.width - blockOriginal.left<=0){
    var left  = Math.max(e.clientX - offset.left,0),
     width = Math.min(blockOriginal.left + blockOriginal.width,blockOriginal.left + blockOriginal.width -(e.clientX-offset.left));
   }else{
    var width = Math.min(e.clientX-offset.left-blockOriginal.left-blockOriginal.width,offset.width-blockOriginal.left-blockOriginal.width),
     left  = blockOriginal.left + blockOriginal.width;
   }
   return {left : left,  width : width};
  },
  right : function(e){
   var blockOriginal = this.blockOriginal,
    offset = this.offset;
   if(e.clientX-offset.left>=blockOriginal.left){
    var width = Math.min(offset.width - blockOriginal.left,e.clientX - offset.left - blockOriginal.left),
     left  = blockOriginal.left;
   }else{
    var width = Math.min(offset.left + blockOriginal.left - e.clientX,blockOriginal.left),
     left  = Math.max(e.clientX - offset.left,0);
   }
   return {left : left,  width : width};
  },
  rightDown : function(e){
   return $.extend(this.right(e),this.down(e));  
  },
  leftDown : function(e){
   return $.extend(this.left(e),this.down(e));
  },
  rightUp : function(e){
   return $.extend(this.right(e),this.up(e));
  },
  leftUp : function(e){
   return $.extend(this.left(e),this.up(e));
  },
  getValue : function(){
   var block = this.block;
   return {
    left   : parseInt(block.css("left")),
    top    : parseInt(block.css("top")),
    width  : block.width(),
    height : block.height()
   }
  }
 }
 $.fn.clip = function(options){
  options.container = this;
  return new clip(options);
 }
})();
 xx = $("#container").clip({
  imgC : $("#imgC")
 })
</script>
</body>
</html>

是不是很炫酷啊,小伙伴們,學學本示例的思路吧。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91视频8mav| 亚洲精品日韩丝袜精品| 国产亚洲精品高潮| 欧美精品精品精品精品免费| 欧美最顶级丰满的aⅴ艳星| 这里只有精品丝袜| 国产主播喷水一区二区| 国产精品夜色7777狼人| 亚洲日韩欧美视频一区| 91久久精品国产91久久性色| 久久久国产精品亚洲一区| 国产成人+综合亚洲+天堂| 一区二区成人av| 日韩亚洲一区二区| 国产伦精品免费视频| 亚洲国产91色在线| 久久婷婷国产麻豆91天堂| 亚洲第一偷拍网| 久久久久久12| 欧美日韩美女视频| 色综合久综合久久综合久鬼88| 久久99精品久久久久久噜噜| 亚洲欧美日韩高清| 亚洲天堂免费视频| 亚洲人精品午夜在线观看| 亚洲人成网7777777国产| 国产精品啪视频| 日韩免费视频在线观看| 国产亚洲欧美日韩美女| 草民午夜欧美限制a级福利片| 国产精品久久久久久亚洲调教| 久久人人爽人人爽人人片亚洲| 97免费视频在线播放| 欧美精品18videos性欧| 久久精品国产久精国产一老狼| 久久久久久国产三级电影| 国产欧美va欧美va香蕉在| 国产成人拍精品视频午夜网站| 欧美成人四级hd版| 亚洲成人在线网| 久久亚洲国产成人| 成人欧美一区二区三区在线| 亚洲国产天堂久久综合| 亚洲丝袜av一区| 亚洲精选一区二区| 2020国产精品视频| 欧美中在线观看| 日韩av中文在线| 欧洲成人免费视频| 国产精品99久久久久久白浆小说| 国产精品99久久久久久久久久久久| 精品国产区一区二区三区在线观看| 俺去了亚洲欧美日韩| 91成品人片a无限观看| 精品亚洲精品福利线在观看| 国产精品第一页在线| 欧美裸体视频网站| 97在线观看免费高清| 亚洲人精选亚洲人成在线| 久久影视三级福利片| 日本a级片电影一区二区| 亚洲精品在线看| 成人性教育视频在线观看| 欧美一级大片视频| 欧洲亚洲免费在线| 91啪国产在线| 91网站在线免费观看| 亚洲欧美另类在线观看| 91精品国产高清久久久久久久久| 91系列在线观看| 亚洲欧美一区二区三区四区| 欧美激情aaaa| 国产福利视频一区二区| 成人黄色影片在线| 国产精品美女无圣光视频| 欧美午夜丰满在线18影院| 欧美成人午夜激情| 在线观看精品自拍私拍| 亚洲精品日韩在线| 日韩国产高清污视频在线观看| 日本伊人精品一区二区三区介绍| 欧美日韩免费网站| 久久精品国产69国产精品亚洲| 亚洲性xxxx| 日韩午夜在线视频| 久久国产一区二区三区| 黑人巨大精品欧美一区二区三区| 精品香蕉在线观看视频一| 91久久夜色精品国产网站| 亚洲男人的天堂在线播放| 欧美性xxxx18| 久热精品视频在线观看一区| 国产精品久久久久久超碰| 亚洲人高潮女人毛茸茸| 亚洲精品美女在线| 在线视频日韩精品| 91久久综合亚洲鲁鲁五月天| 欧美一区二粉嫩精品国产一线天| 国产成人精品免费久久久久| 色狠狠久久aa北条麻妃| 亚洲人成在线观| 亚洲男人天堂手机在线| 日韩欧美一区二区三区久久| 91九色视频导航| 成人av在线天堂| 九九热视频这里只有精品| 欧美国产一区二区三区| 成人a级免费视频| 国内揄拍国内精品少妇国语| 国产精品久久久久久久久久久不卡| 欧洲成人午夜免费大片| 欧美大片在线免费观看| 91成人精品网站| 91av免费观看91av精品在线| 精品夜色国产国偷在线| 国产精品久久久久久久久久新婚| 91精品久久久久久久久不口人| 色综合影院在线| 欧美日韩亚洲一区二| 色樱桃影院亚洲精品影院| 国产午夜一区二区| 日韩在线视频免费观看高清中文| 国产精品入口免费视| 91高清视频免费| 国产精品女人网站| 狠狠躁18三区二区一区| 国产91色在线播放| 色婷婷久久av| 日韩av综合网站| xvideos成人免费中文版| 欧美国产在线视频| 亚洲最大的成人网| 久久久精品2019中文字幕神马| 欧美日韩色婷婷| 日本乱人伦a精品| 欧美亚洲另类制服自拍| 自拍偷拍亚洲区| 丝袜亚洲另类欧美重口| 中文字幕日韩精品在线观看| 狠狠躁夜夜躁久久躁别揉| 尤物九九久久国产精品的分类| 亚洲欧洲一区二区三区在线观看| 国产精品午夜视频| 久久av红桃一区二区小说| 国产精品视频播放| 国产精品视频内| 国产亚洲成av人片在线观看桃| 高清一区二区三区四区五区| 国产精品色午夜在线观看| 欧美性高潮在线| 久久久久北条麻妃免费看| www日韩欧美| 亚洲精品999| 国产精品成av人在线视午夜片| 在线观看日韩www视频免费| 麻豆一区二区在线观看| 欧美中文字幕在线| 国产精品7m视频| 国产精品第1页| 欧美成人免费大片| 国内免费久久久久久久久久久| 亚洲精品国产福利| 亚洲免费电影在线观看| 中文字幕在线观看亚洲|