canvas实现刮刮卡效果
程序员文章站
2022-07-20 19:56:50
目前在html5和css3的热潮下,html页面的效果也是层出不穷,下面我们来介绍使用canvas来模仿刮奖刮开效果。
原理
在需要刮出的图片或者文字上方盖上一层灰色或...
目前在html5和css3的热潮下,html页面的效果也是层出不穷,下面我们来介绍使用canvas来模仿刮奖刮开效果。
原理
在需要刮出的图片或者文字上方盖上一层灰色或者其他背景的canvas画布,当手指或者鼠标点击画布并移动时,将画布上移动过的轨迹变成透明即可。
分析
demo中在class为content的div上盖上一层灰色的画布,然后通过获取鼠标和手指的坐标计算出在画布位置上的坐标,通过在坐标原点位置画一个半径10px的透明圆形来透过画布,显示出画布下的内容。本demo是用时需要改变的内容为_width,_height,touchtop,touchleft这几个参数,根据自身画布的位置自行计算即可。由于是长按事件,记得在移动端阻止浏览器默认功能。
效果图:
图(1)初始图
图(2)刮开效果
代码如下:
<!doctype html> <html> <head> <meta charset="utf-8"> <title>无标题文档</title> <meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no" /> <style> .content,.cover{width:400px; height:400px; position:absolute; left:50%; top:50%; margin:-200px 0 0 -200px;} .content{ font-size:48px; line-height:400px; text-align:center;} h3{ text-align:center; line-height:200px;} </style> </head> <body> <h3>快来刮开!!!</h3> <div class="content" >中奖啦~!</div> <canvas id="cover" class="cover" width="400" height="400"></canvas> </body> <script> var isdown = false, cover = document.getelementbyid("cover"), covercanvas = cover.getcontext("2d"); // covercanvas.fillstyle="transparent"; covercanvas.fillrect(0,0,400,400); function fillter( canvas ){ canvas.fillstyle="#ccc"; canvas.fillrect(0,0,400,400); } function isdown(e){ e.preventdefault(); isdown=true; } function isup(e){ isdown=false; } function draw( e ){ e.preventdefault(); if(isdown){ if(e.changedtouches){ e=e.changedtouches[e.changedtouches.length-1]; } var _height= parseint((window.innerheight-400)/2), _width= parseint((window.innerwidth-400)/2), touchtop=e.clienty - _height, touchleft=e.clientx - _width; with(covercanvas){ beginpath(); arc(touchleft, touchtop, 10, 0, math.pi * 2); fill(); } } //alert(touchtop); } fillter(covercanvas); covercanvas.globalcompositeoperation = 'destination-out'; cover.addeventlistener('touchstart',isdown); cover.addeventlistener('touchmove',draw); cover.addeventlistener('touchend',isup); cover.addeventlistener('mousemove',draw); cover.addeventlistener('mousedown',isdown); cover.addeventlistener('mouseup',isup); </script> </html>
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持!