欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于JavaScript實現(xiàn)圖片剪切效果

 更新時間:2017年03月07日 16:13:19   作者:Vampire-blog  
這篇文章主要介紹了用JavaScript實現(xiàn)圖片剪切效果,本文給大家介紹的非常詳細,具有參考借鑒價值,需要的朋友可以參考下

學會如何獲取鼠標的坐標位置以及監(jiān)聽鼠標的按下、拖動、松開等動作事件,從而實現(xiàn)拖動鼠標來改變圖片大小。

還可以學習css中的clip屬性。

一、CSS實現(xiàn)圖片不透明及裁剪效果。

圖片剪切三層結(jié)構(gòu)

1、第一層opacity,給圖層設(shè)置透明度

2、第二層clip,clip屬性:對圖片進行裁剪,實現(xiàn)圖像的一部分顯示,其他部分進行隱藏

3、第三層選取框absolute(與第二層重疊的),包括八個觸點的效果

html代碼:

<div id="box">
 <img src="img/1.jpg" id="img1" />
 <img src="img/1.jpg" id="img2" />
 <div id="main">
  <div class="Divmin up-left"></div>
  <div class="Divmin up"></div>
  <div class="Divmin up-right"></div>
  <div class="Divmin right"></div>
  <div class="Divmin right-down"></div>
  <div class="Divmin down"></div>
  <div class="Divmin left-down"></div>
  <div class="Divmin left"></div>
 </div>
</div>

css代碼:

body{
  background: #333;
 }
 #box{
  width: 500px;
  height: 380px;
  position: absolute;
  top: 100px;
  left: 200px;
 }
 #img1,#img2{
  position: absolute;
  top: 0;
  left: 0;
 }
 #img1{
  opacity: 0.3;
 }
 #img2{
  clip: rect(0,200px,200px,0);
 }
 #main{
  position: absolute;/*第三層需用絕對定位浮在上面*/
  width: 200px;
  height: 200px;
  border: 1px solid #fff;
 }
 .Divmin{
  position: absolute;
  width: 8px;
  height: 8px;
  background: #fff;
 }
 .up-left{margin-top: -4px;margin-left: -4px;cursor: nw-resize;}
 .up{
  left: 50%;/*父元素盒子main寬度的一半,注意要有絕對定位*/
  margin-left:-4px;
  top: -4px;
  cursor: n-resize;
 }
 .up-right{top: -4px;right: -4px;cursor: ne-resize;}
 .right{top: 50%;margin-top: -4px;right: -4px;cursor: e-resize;}
 .right-down{right: -4px;bottom: -4px;cursor: se-resize;}
 .down{bottom: -4px;left: 50%;margin-left: -4px;cursor: s-resize;}
 .left-down{left: -4px;bottom: -4px;cursor: sw-resize;}
 .left{left: -4px;top: 50%;margin-top: -4px;cursor: w-resize;}

二、javascript獲取選擇框偏移量

選擇框鼠標拖動位置詳解:

offsetLeft:元素相對于其父元素左邊界的距離;

clientX:鼠標位置的橫坐標;

clientWidth:元素的寬度;

offsetXY:是該事件發(fā)生的盒子模型里的坐標,與滾動條無關(guān)。

clientXY:是整個瀏覽器可用部分里的坐標,與滾動條無關(guān),即需要拖動滾動條才能看到的區(qū)域不考慮。

pageXY:是整個網(wǎng)頁里的坐標,與滾動條有關(guān)。

構(gòu)造一個getPosition()函數(shù),用于獲取元素相對于屏幕左邊及上邊的距離

js代碼如下:

//獲取元素相對于屏幕左邊及上邊的距離,利用offsetLeft
 function getPosition(el){
  var left = el.offsetLeft;
  var top = el.offsetTop;
  var parent = el.offsetParent;
  while(parent != null){
   left += parent.offsetLeft;
   top += parent.offsetTop;
   parent = parent.offsetParent;
  }
  return {"left":left,"top":top};
 }

三、javascript實現(xiàn)控制觸點

監(jiān)聽鼠標的按下、拖動、松開的事件控制選取框的大小。

注意區(qū)別:

Element.clientWidth 屬性表示元素的內(nèi)部寬度,以像素計。該屬性包括內(nèi)邊距,但不包括垂直滾動條(如果有的話)、邊框和外邊距。

即clientWidth不包括邊框,offsetWidth包括邊框

1)點擊右面的觸點

js代碼:

var mainDiv = $('main');
 var rightDiv = $('right');
 var isDraging = false;
 var contact = "";//表示被按下的觸點
 //鼠標按下時
 rightDiv.onmousedown = function(){
  isDraging = true;
  contact = "right";
 }
 //鼠標松開時
 window.onmouseup = function(){
  isDraging = false;
 }
 //鼠標移動時
 window.onmousemove = function(e){
  if(isDraging == true){
   if(contact == "right"){
    var e = e||window.event;
    var x = e.clientX;//鼠標位置的橫坐標
    var widthBefore = mainDiv.offsetWidth - 2;//選取框變化前的寬度
    //var widthBefore = mainDiv.clientWidth;
    var addWidth = x - getPosition(mainDiv).left - widthBefore;//鼠標移動后選取框增加的寬度
    mainDiv.style.width = widthBefore + addWidth + 'px';//選取框變化后的寬度
   }
  }
 }
//獲取id的函數(shù)
function $(id){
 return document.getElementById(id);
}

2)點擊上面觸點

點擊上面中間的觸點移動時,選取框的高度和左上角的位置都需要變化。

增加的高度=選取框相對于屏幕上面的距離 - 鼠標位置的縱坐標

選取框左上角的top值要減去增加的高度,因為鼠標向上移動時高度增加,top值減小,下移時高度減小,top增大。

變化示意圖:

js代碼:

else if(contact == "up"){
    var y = e.clientY;//鼠標位置的縱坐標
    var heightBefore = mainDiv.offsetHeight - 2;//選取框變化前的高度
    var addHeight = getPosition(mainDiv).top - y;//增加的高度
    mainDiv.style.height = heightBefore + addHeight + 'px';//選取框變化后的寬度
    mainDiv.style.top = mainDiv.offsetTop - addHeight + 'px';//相當于變化后左上角的縱坐標,鼠標向上移縱坐標減小,下移增大
   }

 3)點擊左邊觸點

原理同點擊上面觸點,寬度和左邊的位置都會變化

變化示意圖:

js代碼:

 else if(contact == "left"){
     var widthBefore = mainDiv.offsetWidth - 2;
      var addWidth = getPosition(mainDiv).left - e.clientX;//增加的寬度等于距離屏幕左邊的距離減去鼠標位置橫坐標
      mainDiv.style.width = widthBefore + addWidth + 'px';
     mainDiv.style.left = mainDiv.offsetLeft - addWidth + 'px';//左邊的距離(相當于左邊位置橫坐標)等于選取框距父級元素的距離減去增加的寬度
   }

 4)點擊下面觸點

增加的寬度 = 鼠標位置縱坐標 - 距屏幕上邊的距離 - 原先的寬度

左上角的位置不需改變

js代碼:

else if(contact = "down"){
     var heightBefore = mainDiv.offsetHeight - 2;
     var addHeight = e.clientY - getPosition(mainDiv).top - mainDiv.offsetHeight;
     mainDiv.style.height = heightBefore + addHeight + 'px';
    }

 5)點四個角時的變化是高度和寬度變化的疊加,所以最好將上面四個變化的過程封裝成函數(shù),便于維護和代碼復用。

      如果用if else 需要判斷8次,所以改為switch語句來簡化代碼

      修改后的js代碼如下:

window.onmousemove = function(e){
  var e = e||window.event;
  if(isDraging == true){
   switch (contact){
    case "up" : upMove(e);break;
    case "right" : rightMove(e);break;
    case "down" : downMove(e);break;
    case "left" : leftMove(e);break;
    case "up-right" : upMove(e);rightMove(e);break;
    case "down-right" : downMove(e);rightMove(e);break;
    case "down-left" : downMove(e);leftMove(e);break;
    case "up-left" : upMove(e);leftMove(e);break;
   }
  }
 }
//獲取id的函數(shù)
function $(id){
 return document.getElementById(id);
}
//獲取元素相對于屏幕左邊及上邊的距離,利用offsetLeft
 function getPosition(el){
  var left = el.offsetLeft;
  var top = el.offsetTop;
  var parent = el.offsetParent;
  while(parent != null){
   left += parent.offsetLeft;
   top += parent.offsetTop;
   parent = parent.offsetParent;
  }
  return {"left":left,"top":top};
 }
 //up移動
 function upMove(e){
  var y = e.clientY;//鼠標位置的縱坐標
  var heightBefore = mainDiv.offsetHeight - 2;//選取框變化前的高度
  var addHeight = getPosition(mainDiv).top - y;//增加的高度
  mainDiv.style.height = heightBefore + addHeight + 'px';//選取框變化后的寬度
  mainDiv.style.top = mainDiv.offsetTop - addHeight + 'px';//相當于變化后左上角的縱坐標,鼠標向上移縱坐標減小,下移增大
 }
 //right移動
 function rightMove(e){
  var x = e.clientX;//鼠標位置的橫坐標
  var widthBefore = mainDiv.offsetWidth - 2;//選取框變化前的寬度
  //var widthBefore = mainDiv.clientWidth;
  var addWidth = x - getPosition(mainDiv).left - widthBefore;//鼠標移動后選取框增加的寬度
  mainDiv.style.width = widthBefore + addWidth + 'px';//選取框變化后的寬度
 }
 //down移動
 function downMove(e){
  var heightBefore = mainDiv.offsetHeight - 2;
  var addHeight = e.clientY - getPosition(mainDiv).top - mainDiv.offsetHeight;
  mainDiv.style.height = heightBefore + addHeight + 'px';
 }
 //left移動
 function leftMove(e){
  var widthBefore = mainDiv.offsetWidth - 2;
  var addWidth = getPosition(mainDiv).left - e.clientX;//增加的寬度等于距離屏幕左邊的距離減去鼠標位置橫坐標
  mainDiv.style.width = widthBefore + addWidth + 'px';
  mainDiv.style.left = mainDiv.offsetLeft - addWidth + 'px';//左邊的距離(相當于左邊位置橫坐標)等于選取框距父級元素的距離減去增加的寬度
 }

四、實現(xiàn)選取框區(qū)域明亮顯示

1)選取框內(nèi)的第二層圖片需重新設(shè)置其clip屬性

四個方面圖示:

js代碼:

//設(shè)置選取框圖片區(qū)域明亮顯示
 function setChoice(){
  var top = mainDiv.offsetTop;
  var right = mainDiv.offsetLeft + mainDiv.offsetWidth;
  var bottom = mainDiv.offsetTop + mainDiv.offsetHeight;
  var left = mainDiv.offsetLeft;
  img2.style.clip = "rect("+top+"px,"+right+"px,"+bottom+"px,"+left+"px)";
 }

2)鼠標移動時會導致圖片被選中,可在js代碼中添加一行代碼使其禁止圖片被選中

//禁止圖片被選中
 document.onselectstart = new Function('event.returnValue = false;');

也可以在css樣式里添加 *{user-select:none}

意思是文本不可選中,對圖片跟div有一樣的效果。

五、實現(xiàn)選取框位置可拖動

首先要阻止事件冒泡

js代碼如下: 

//鼠標按下觸點時
 rightDiv.onmousedown = function(e){
  e.stopPropagation();
  isDraging = true;
  contact = "right";
 }

鼠標拖拽效果的實現(xiàn)可見另一篇隨筆http://www.cnblogs.com/vampire170204/p/6422914.html

六、實現(xiàn)圖片剪切區(qū)域預覽

新增一個圖片預覽區(qū)域的div

html代碼:

<div id="preview">
 <img src="img/1.jpg" id="img3" />
</div>

css代碼:

#preview{
  position: absolute;
  width: 500px;
  height: 380px;
  top: 100px;
  left:710px ;
 }
 #preview #img3{position: absolute;}

注意:要讓clip:rect(top,right,bottom,left) 起作用,必須讓作用元素為相對/絕對定位。

js部分同樣是利用clip屬性,和setChoice()函數(shù)同時被調(diào)用

同時為了讓右邊預覽區(qū)的左上角位置固定,需要設(shè)置其top和left的值

//右邊圖片預覽函數(shù)
 function setPreview(){
  var top = mainDiv.offsetTop;
  var right = mainDiv.offsetLeft + mainDiv.offsetWidth;
  var bottom = mainDiv.offsetTop + mainDiv.offsetHeight;
  var left = mainDiv.offsetLeft;
  var img3 = $('img3');
  img3.style.top = -top + 'px';
  img3.style.left = -left + 'px';
  img3.style.clip = "rect("+top+"px,"+right+"px,"+bottom+"px,"+left+"px)";
 }

以上所述是小編給大家介紹的基于JavaScript實現(xiàn)圖片剪切效果,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • package.json管理依賴包版本詳解

    package.json管理依賴包版本詳解

    本文講述前端項目的實戰(zhàn)中,是如何使用package.json對依賴包進行版本管理的,以及不同規(guī)則對依賴的管理會產(chǎn)生什么影響
    2022-07-07
  • 淺談在js傳遞參數(shù)中含加號(+)的處理方式

    淺談在js傳遞參數(shù)中含加號(+)的處理方式

    下面小編就為大家?guī)硪黄獪\談在js傳遞參數(shù)中含加號(+)的處理方式。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • javascript閉包的理解和實例

    javascript閉包的理解和實例

    所謂閉包,值得是詞法表示包括不必要計算的變量的函數(shù),也就是說,該函數(shù)可以使用函數(shù)外定義的變量。
    2010-08-08
  • 微信小程序?qū)崿F(xiàn)商品分類列表

    微信小程序?qū)崿F(xiàn)商品分類列表

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)商品分類列表,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • childNodes 用法兩例

    childNodes 用法兩例

    childNodes實現(xiàn)代碼
    2009-04-04
  • 微信小程序模板消息推送的兩種實現(xiàn)方式

    微信小程序模板消息推送的兩種實現(xiàn)方式

    這篇文章主要介紹了微信小程序模板消息推送的兩種實現(xiàn)方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-08-08
  • 微信小程序?qū)崿F(xiàn)底部彈窗

    微信小程序?qū)崿F(xiàn)底部彈窗

    這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)底部彈窗,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • js實現(xiàn)頁面轉(zhuǎn)發(fā)功能示例代碼

    js實現(xiàn)頁面轉(zhuǎn)發(fā)功能示例代碼

    本文為大家介紹的是使用js實現(xiàn)頁面轉(zhuǎn)發(fā),具體實現(xiàn)如下,感興趣的朋友可以參考下,希望對大家有所幫助
    2013-08-08
  • 用cssText批量修改樣式

    用cssText批量修改樣式

    一般情況下我們用js設(shè)置元素對象的樣式會使用這樣的形式
    2009-08-08
  • 微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導航欄標題功能示例

    微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導航欄標題功能示例

    這篇文章主要介紹了微信小程序?qū)崿F(xiàn)的動態(tài)設(shè)置導航欄標題功能,結(jié)合實例形式分析了微信小程序使用wx.setNavigationBarTitle接口動態(tài)設(shè)置導航欄標題的相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01

最新評論