溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JS如何實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果

發(fā)布時(shí)間:2021-06-29 09:40:23 來(lái)源:億速云 閱讀:323 作者:小新 欄目:web開發(fā)

小編給大家分享一下JS如何實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

效果如下

JS如何實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果

蓋倫.jpg

JS如何實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果

刮刮樂(lè).gif

HTML部分

<body>
  ![](img/gailun.jpg)
  <canvas id="canvas" width="400" height="300"></canvas>
 </body>

沒(méi)什么要特別注意的

為了效果加了些CSS樣式

CSS部分

<style type="text/css">
  *{
   margin: 0;
   padding: 0;
  }
   img{
    width: 400px;
    height: 300px;
    left: 200px;
    position: absolute;
    z-index: -1;
   }
   canvas{
    margin-left:200px;
   }
  </style>

注意

1.為了清除瀏覽器自帶效果加了

*{
   margin: 0;
   padding: 0;
  }

2.img需要在灰布下面,加了z-index;

3.圖片絕對(duì)定位

js部分

分析下邏輯

1.鼠標(biāo)按下移動(dòng)相應(yīng)區(qū)域刮開

2.鼠標(biāo)抬起改變鼠標(biāo)位置不接著刮開

js代碼

<script type="text/javascript">
  var canvas = document.getElementById("canvas");
  var context = canvas.getContext('2d');
   //畫蒙布
  context.beginPath();
  context.fillStyle= 'grey'
  context.fillRect(0,0,400,300);
  //鼠標(biāo)按下開刮
  canvas.onmousedown=function(){
   canvas.onmousemove = function(){
    //獲取鼠標(biāo)坐標(biāo)
    var x = event.clientX;
    var y = event.clientY;
    //destination-out    顯示原來(lái)的不在后來(lái)區(qū)域的部分
    context.globalCompositeOperation = "destination-out";
    context.beginPath();
    context.arc(x-200,y,30,0,Math.PI*2);
    context.fill();  
   }
  }
  //鼠標(biāo)抬起不刮開
  canvas.onmouseup=function(){
   canvas.onmousemove = function(){ 
   }
  } 
  </script>

需要注意的是

1.圖片和畫布左移了200px,所以圓的起點(diǎn)坐標(biāo)相對(duì)于獲取位置減了200px;

2.globalCompositeOperation是畫布的一個(gè)功能作用是設(shè)置或返回如何將一個(gè)源(新的)圖像繪制到目標(biāo)(已有)的圖像上,還有其余10種寫法

以上是“JS如何實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI