亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

20行JS代碼實現(xiàn)網(wǎng)頁刮刮樂效果

 更新時間:2017年06月23日 08:59:32   投稿:jingxian  
下面小編就為大家?guī)硪黄?0行JS代碼實現(xiàn)網(wǎng)頁刮刮樂效果。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

分享一段用canvas和JS制作刮刮樂的代碼,JS部分去掉注釋不到20行代碼

效果如下

蓋倫.jpg

刮刮樂.gif

HTML部分

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

沒什么要特別注意的

為了效果加了些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.圖片絕對定位

js部分

分析下邏輯

1.鼠標(biāo)按下移動相應(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    顯示原來的不在后來區(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,所以圓的起點坐標(biāo)相對于獲取位置減了200px;

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

以上這篇20行JS代碼實現(xiàn)網(wǎng)頁刮刮樂效果就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論