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

首頁 > 語言 > JavaScript > 正文

js+jquery實現圖片裁剪功能

2024-05-06 16:13:29
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了js+jquery實現圖片裁剪功能的方法以及全部的示例代碼,思路非常好,這里推薦給有需要的小伙伴。
 
 

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

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

 

復制代碼代碼如下:

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<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="http://common.cnblogs.com/script/jquery.js"></script>
<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
日韩高清欧美高清| 免费99精品国产自在在线| 日本久久久久亚洲中字幕| 日韩电影免费在线观看| 日韩av在线影院| 亚洲精品日韩久久久| 欧美一二三视频| 欧美超级乱淫片喷水| 97精品国产97久久久久久| 蜜月aⅴ免费一区二区三区| 亚洲高清一二三区| 欧美乱大交做爰xxxⅹ性3| 欧美激情视频网址| 欧美日韩免费区域视频在线观看| 国产精品自产拍高潮在线观看| 国产在线高清精品| 亚洲成年网站在线观看| 久久久噜噜噜久久中文字免| 亚洲一区二区免费| 国产亚洲成av人片在线观看桃| 久久大大胆人体| 亚洲深夜福利视频| 91九色在线视频| 91av视频在线播放| 久久久爽爽爽美女图片| 中文字幕一区二区精品| 国产视频综合在线| 国产精品视频最多的网站| 国产精品美女在线| 欧美一级片久久久久久久| 正在播放亚洲1区| 国产自摸综合网| 国产精品xxxxx| 九九综合九九综合| 欧美日韩在线看| 国产亚洲精品久久久久久牛牛| 国产精品视频在线观看| 国产精品久久久久久亚洲调教| 日韩精品极品毛片系列视频| 国产成人亚洲综合91| 免费91麻豆精品国产自产在线观看| 久久精品中文字幕| 亚洲精品国产精品国自产观看浪潮| 中文字幕久热精品视频在线| 青青精品视频播放| 97超级碰碰人国产在线观看| 亚洲а∨天堂久久精品喷水| 不卡毛片在线看| 亚洲第一中文字幕在线观看| 亚洲国产精品热久久| 国产精品成久久久久三级| 国产成人精品优优av| 欧美巨乳美女视频| 中文字幕免费精品一区| 久久精品国产久精国产一老狼| 中文字幕亚洲综合| 国产热re99久久6国产精品| 国产精品吹潮在线观看| 欧美激情精品在线| 伊人久久免费视频| 日本中文字幕久久看| 日韩av免费在线播放| 岛国av一区二区| 欧美激情一区二区三级高清视频| 日本中文字幕不卡免费| 欧美性猛交xxxxx免费看| 欧美午夜性色大片在线观看| 日本乱人伦a精品| 色中色综合影院手机版在线观看| 在线观看国产欧美| 中文字幕不卡av| 97久久精品国产| 国产精品久久久久影院日本| 久久综合久久美利坚合众国| 欧美插天视频在线播放| 日韩在线观看免费网站| 亚洲国产一区自拍| 国产日产欧美精品| 国内精品久久久久久中文字幕| 亚洲免费一在线| 日韩在线观看你懂的| 精品视频—区二区三区免费| 黑人极品videos精品欧美裸| 久久全球大尺度高清视频| 久久中文精品视频| 亚洲国产欧美一区二区三区久久| 91欧美精品成人综合在线观看| 久久精品视频导航| 久久久精品视频在线观看| 国产男女猛烈无遮挡91| 国产综合色香蕉精品| 不卡av日日日| 欧美日韩一区二区三区在线免费观看| 亚洲欧洲一区二区三区在线观看| 97久久精品人人澡人人爽缅北| 精品成人国产在线观看男人呻吟| 国产精品女主播| 自拍偷拍亚洲区| 亚洲一区二区三区在线视频| 国产一区视频在线| 欧美一级淫片丝袜脚交| 日韩在线一区二区三区免费视频| 亚洲最新av在线| 精品福利在线看| 欧美性69xxxx肥| 国产精品免费视频xxxx| 久久久久久久久久av| 国产精品福利网站| 大胆欧美人体视频| 亚洲成人aaa| 最近2019中文字幕mv免费看| 成人黄色片在线| 中文字幕在线亚洲| 在线电影av不卡网址| 一级做a爰片久久毛片美女图片| 欧美性xxxxhd| 亚洲欧美日韩直播| 亚洲夜晚福利在线观看| 欧美成人手机在线| 久久免费少妇高潮久久精品99| 欧美成人国产va精品日本一级| 国产精品视频色| 91极品女神在线| 91av在线不卡| 久久久久久有精品国产| 亚洲成人激情在线| 97视频在线观看免费| 91黑丝高跟在线| 成人黄色av免费在线观看| 91精品一区二区| 久久频这里精品99香蕉| 国产成人精品电影久久久| 中文字幕自拍vr一区二区三区| www.99久久热国产日韩欧美.com| 欧日韩不卡在线视频| 亚洲精品电影在线观看| 亚洲国产中文字幕久久网| 人妖精品videosex性欧美| 国产91精品久久久久久久| 国产精品久久久久影院日本| 久久久最新网址| 黑人精品xxx一区一二区| 国产精品欧美一区二区| 日韩美女激情视频| 日韩精品中文字| 亚洲国产欧美在线成人app| 亚洲精品欧美一区二区三区| 欧美激情在线观看视频| 91av国产在线| 亚洲人成网站色ww在线| 国产精品亚洲自拍| 中文字幕亚洲国产| 国产综合久久久久| 久久久久久网站| 久久福利视频导航| 69影院欧美专区视频| 欧洲亚洲免费在线| 国产精品人成电影| 欧美一区亚洲一区| 青草青草久热精品视频在线网站| 国产欧美精品在线| 午夜精品一区二区三区在线视| 国产自摸综合网| 国产精品成熟老女人|