20行JS代码实现网页刮刮乐效果


Posted in Javascript onJune 23, 2017

分享一段用canvas和JS制作刮刮乐的代码,JS部分去掉注释不到20行代码

效果如下

20行JS代码实现网页刮刮乐效果

盖伦.jpg

20行JS代码实现网页刮刮乐效果

刮刮乐.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代码实现网页刮刮乐效果就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
js 幻灯片的实现
Dec 06 Javascript
使用jQuery UI的tooltip函数修饰title属性的气泡悬浮框
Jun 24 Javascript
js中settimeout方法加参数
Feb 28 Javascript
Javascript中的apply()方法浅析
Mar 15 Javascript
jquery获取复选框checkbox的值实现方法
May 30 Javascript
angular-cli修改端口号【angular2】
Apr 19 Javascript
jquery应用实例分享_实现手风琴特效
Feb 01 jQuery
js中的数组对象排序分析
Dec 11 Javascript
JavaScript面向对象核心知识与概念归纳整理
May 09 Javascript
使用React代码动态生成栅格布局的方法
May 24 Javascript
JavaScript实现答题评分功能页面
Jun 24 Javascript
vue 点击其他区域关闭自定义div操作
Jul 17 Javascript
w3c编程挑战_初级脚本算法实战篇
Jun 23 #Javascript
微信小程序 获取二维码实例详解
Jun 23 #Javascript
详谈表单格式化插件jquery.serializeJSON
Jun 23 #jQuery
angularJs的ng-class切换class
Jun 23 #Javascript
关于使用js算总价的问题
Jun 23 #Javascript
angular select 默认值设置方法
Jun 23 #Javascript
获取当前按钮或者html的ID名称实例(推荐)
Jun 23 #Javascript
You might like
PHP投票系统防刷票判断流程分析
2012/02/04 PHP
解析coreseek for sphinx的使用
2013/06/21 PHP
初识Laravel
2014/10/30 PHP
PHP const定义常量及global定义全局常量实例解析
2020/05/28 PHP
Extjs Ext.MessageBox.confirm 确认对话框详解
2010/04/02 Javascript
用JQuery调用Session的实现代码
2010/10/29 Javascript
jQuery 的全选(全非选)即取得被选中的值使用介绍
2013/11/12 Javascript
JS实现根据出生年月计算年龄
2014/01/10 Javascript
js获取日期:昨天今天和明天、后天
2014/06/11 Javascript
判断日期是否能跨月查询的js代码
2014/07/25 Javascript
js实现点击添加一个input节点
2014/12/05 Javascript
JQuery统计input和textarea文字输入数量(代码分享)
2016/12/29 Javascript
js中new一个对象的过程
2017/02/20 Javascript
nodejs入门教程四:URL相关模块用法分析
2017/04/24 NodeJs
JS获取填报扩展单元格控件的值的解决办法
2017/07/14 Javascript
react-native动态切换tab组件的方法
2018/07/07 Javascript
分享一款超好用的JavaScript 打包压缩工具
2020/04/26 Javascript
JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等属性学习笔记
2020/07/15 Javascript
[01:38]DOTA2第二届亚洲邀请赛中国区预选赛出线战队晋级之路
2017/01/17 DOTA
wxPython事件驱动实例详解
2014/09/28 Python
Python的Twisted框架上手前所必须了解的异步编程思想
2016/05/25 Python
python中类变量与成员变量的使用注意点总结
2017/04/29 Python
Python实现Smtplib发送带有各种附件的邮件实例
2017/06/05 Python
python集合比较(交集,并集,差集)方法详解
2018/09/13 Python
python实现猜单词游戏
2020/05/22 Python
python爬取股票最新数据并用excel绘制树状图的示例
2021/03/01 Python
CSS3 text-shadow实现文字阴影效果
2016/02/24 HTML / CSS
全球速卖通:AliExpress(国际版淘宝)
2017/09/20 全球购物
英文翻译的自我评价语句
2013/10/04 职场文书
销售文员岗位职责
2013/11/29 职场文书
党员领导干部承诺书
2014/05/28 职场文书
建筑施工安全责任书
2014/07/24 职场文书
幼儿园亲子活动通知
2015/04/24 职场文书
奖学金主要事迹范文
2015/11/04 职场文书
2016年10月份红领巾广播稿
2015/12/21 职场文书
python实现三阶魔方还原的示例代码
2021/04/28 Python