您好,登錄后才能下訂單哦!
小編給大家分享一下JS如何實(shí)現(xiàn)網(wǎng)頁(yè)刮刮樂(lè)效果,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
效果如下
蓋倫.jpg
刮刮樂(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è)資訊頻道!
免責(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)容。