分享一段用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.鼠标按下移动相应区域刮开
2.鼠标抬起改变鼠标位置不接着刮开
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); //鼠标按下开刮 canvas.onmousedown=function(){ canvas.onmousemove = function(){ //获取鼠标坐标 var x = event.clientX; var y = event.clientY; //destination-out 显示原来的不在后来区域的部分 context.globalCompositeOperation = "destination-out"; context.beginPath(); context.arc(x-200,y,30,0,Math.PI*2); context.fill(); } } //鼠标抬起不刮开 canvas.onmouseup=function(){ canvas.onmousemove = function(){ } } </script>
需要注意的是
1.图片和画布左移了200px,所以圆的起点坐标相对于获取位置减了200px;
2.globalCompositeOperation是画布的一个功能作用是设置或返回如何将一个源(新的)图像绘制到目标(已有)的图像上,还有其余10种写法
以上这篇20行JS代码实现网页刮刮乐效果就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
本文向大家介绍js HTML5手机刮刮乐代码,包括了js HTML5手机刮刮乐代码的使用技巧和注意事项,需要的朋友参考一下 手机刮刮乐HTML5代码, 使用原型prototype扩展了一个clearArc 清除圆内像素的功能, 此功能未完成扇形清除功能, 此外,在清除圆内的像素时,还有点瑕疵,右边和下边还不够圆滑,有明显的齿状。如果你找到修复方法请一定要告诉我哟。不过此清除方法用于刮刮乐已经完全满
本文向大家介绍Android刮刮卡效果实现代码,包括了Android刮刮卡效果实现代码的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android刮刮卡效果,供大家参考,具体内容如下 android实现底层一张图片,上层一个遮罩层,触摸滑动按手指滑动路径实现去除遮罩效果,类似于抽奖的刮刮卡一样,不多说先上张效果图: 直接上代码: XfermodeView.java Xfermod
本文向大家介绍移动端刮刮乐的实现方式(js+HTML5),包括了移动端刮刮乐的实现方式(js+HTML5)的使用技巧和注意事项,需要的朋友参考一下 程序员有一种惯性思维,就是看见一些会动的东西(带点科技含量的,猫啊,狗啊就算了),总要先想一遍,这玩意用代码是怎么控制的。比如电梯,路边的霓虹灯,遥控器,小孩子的玩具等,都统统被程序员“意淫”过。 有时候还会感觉程序员看世界会看的透彻一点.......
本文向大家介绍2种jQuery 实现刮刮卡效果,包括了2种jQuery 实现刮刮卡效果的使用技巧和注意事项,需要的朋友参考一下 其中拖拽刮涂层效果使用jquery UI的draggable方法 以下是源代码: 这里给大家分享的是十分常用的刮奖的特效代码,希望小伙伴们能够喜欢。
本文向大家介绍简单实现Android刮刮卡效果,包括了简单实现Android刮刮卡效果的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了Android仿刮刮卡效果展示的具体代码,供大家参考,具体内容如下 一、Xfermode 通过使用Xfermode将绘制的图形的像素和Canvas上对应位置的像素按照一定的规则进行混合,形成新的像素,再更新到Canvas中形成最终的图形,使用的时候都是
本文向大家介绍Android刮刮卡功能具体实现代码,包括了Android刮刮卡功能具体实现代码的使用技巧和注意事项,需要的朋友参考一下 今天整理之前的代码,忽然看到之前自己写的一个刮刮卡,整理下以便以后使用,同时分享给需要的朋友,如有错误,还请多多指正。 实现的步骤,其实就是徒手画三个图层叠加在一起,最上层是绘制需要的问题,就是以上所述的“骚年,刮我吧”,第二层就是覆盖宽高的灰层,第三层是结果层,