在解决问题前,我们先来了解一下 canvas 标签
canvas 是 html5 出现的新标签,像所有的 dom 对象一样它有自己本身的属性、方法和事件,其中就有绘图的方法,js 能够调用它来进行绘图。

context是一个封装了很多绘图功能的对象,获取这个对象的方法是 :

var canvas = document.querySelector('canvas');
var ctx = canvas.getContext("2d");
1
2
3
canvas元素绘制图像的时候有两种方法,分别是:

ctx.fill()//填充
ctx.stroke()//绘制边框
1
2
style:在进行图形绘制前,要设置好绘图的样式

ctx.fillStyle()//填充的样式
ctx.strokeStyle()//边框样式
1
2
ctx.fillRect(x, y, width, height)
绘制一个填充的矩形

ctx.clearRect(x, y, width, height)
清除指定矩形区域,让清除部分完全透明。

ctx.beginPath()
新建一条路径,生成之后,图形绘制命令被指向到路径上生成路径。

ctx.closePath()
闭合路径之后图形绘制命令又重新指向到上下文中。

ctx.stroke()
通过线条来绘制图形轮廓。

ctx.fill()
通过填充路径的内容区域生成实心的图形。

ctx.fill();与ctx. stroke()是对应的,一种是填充,一种是描线
ctx.arc()
画圆弧,有五个参数(x, y, 半径, 起始角度,结束角度,是否逆时针)

ctx.arc(75,75,50,0,Math.PI*2,true); // 绘制圆
ctx.arc(75,75,35,0,Math.PI,false); // 口(顺时针)半圆
1
2
更多属性详情请点击这里。

代码实现

实现原理
首先,我们要禁用页面的鼠标选中拖动的事件,就是不运行执行选中操作。

var bodyStyle = document.body.style;
bodyStyle.mozUserSelect = 'none';
bodyStyle.webkitUserSelect = 'none';
接着我们定义图片类,获取canvas元素,并设置背景和位置属性。我们在本例中用到两张随机照片,每次刷新随机一张图片作为背景。
监听图片加载事件,定义gray颜色。
监听鼠标事件并画出图像。

js 代码如下:
<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>演示:使用HTML5实现刮刮卡效果</title>
<style type="text/css">
.demo{width:320px; margin:10px auto 20px auto; min-height:300px;}
.msg{text-align:center; height:32px; line-height:32px; font-weight:bold; margin-top:50px}
</style>
</head>

<body>
<div id="main">
<div class="msg">刮开灰色部分看看,<a href="javascript:void(0)" onClick="window.location.reload()">再来一次</a></div>
<div class="demo">
<canvas></canvas>
</div>
</div>

<script type="text/javascript">
var bodyStyle = document.body.style;
//禁用页面的鼠标选中拖动的事件,就是不运行执行选中操作
bodyStyle.mozUserSelect = 'none';
bodyStyle.webkitUserSelect = 'none';

var img = new Image();
var canvas = document.querySelector('canvas');

canvas.style.position = 'absolute';
var imgs = ['p_0.jpg','p_1.jpg'];
var num = Math.floor(Math.random()*2);
img.src = imgs[num];

img.addEventListener('load', function(e) {
var ctx;
var w = img.width,
h = img.height;
var offsetX = canvas.offsetLeft,
offsetY = canvas.offsetTop;
var mousedown = false;

function eventDown(e){
e.preventDefault();
mousedown=true;
}

function eventUp(e){
e.preventDefault();
mousedown=false;
}

function eventMove(e){
e.preventDefault();
if(mousedown) {
if(e.changedTouches){
e=e.changedTouches[0];
}
var x = (e.clientX + document.body.scrollLeft || e.pageX) - offsetX || 0,
y = (e.clientY + document.body.scrollTop || e.pageY) - offsetY || 0;
with(ctx) {
beginPath()
arc(x, y, 10, 0, Math.PI * 2);
fill();
}
}
}
console.log(w)
canvas.width=w;
canvas.height=h;
canvas.style.backgroundImage='url('+img.src+')';
ctx=canvas.getContext('2d');
ctx.fillStyle = 'gray';
ctx.fillRect(0, 0, w, h);
// 在前面银色图像下面画图
ctx.globalCompositeOperation = 'destination-out';

canvas.addEventListener('touchstart', eventDown);
canvas.addEventListener('touchend', eventUp);
canvas.addEventListener('touchmove', eventMove);
canvas.addEventListener('mousedown', eventDown);
canvas.addEventListener('mouseup', eventUp);
canvas.addEventListener('mousemove', eventMove);
});
</script>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
项目demo请点击这里。

在这里再拓展一个canvas画图的实例——页面时钟
详细的解释在文中已有注释。
js代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title></title>
</head>
<body>
<canvas id="canvas" width="500" height="500" style=""></canvas>
<script>
var canvas = document.getElementById("canvas");
var context = canvas.getContext("2d");
function drawClock(){
context.clearRect(0,0,500,500);
var now = new Date();
var sec = now.getSeconds();
var min = now.getMinutes();
var hours = now.getHours();
//小时必须获取浮点类型 (小时+分钟/60)
hours = hours+min/60;
var hours = hours>12?hours-12:hours;

context.lineWidth = 1;
context.strokeStyle = "blue";
context.beginPath();
context.arc(250,250,200,0,360,false);
context.closePath();
context.stroke();

for(var i=0;i<60;i++){
context.save();
context.beginPath();
context.lineWidth = 3;
context.strokeStyle = "#00aac5";
context.translate(250,250);
context.rotate(i*6*Math.PI/180);
context.moveTo(0,-180);
context.lineTo(0,-190);
context.closePath();
context.stroke();
context.restore();
}

for(var i=0;i<12;i++){
//保存当前环境的状态
context.save();
context.lineWidth = 7;
context.strokeStyle = "#000";
// 转移原点
context.translate(250,250);
// 旋转
context.rotate(i*30*Math.PI/180);
context.beginPath();
context.moveTo(0,-160);
context.lineTo(0,-190);
context.closePath();
context.stroke();
// 返回之前保存过的路径状态和属性
context.restore();
}
// 绘制时针
context.save();
context.lineWidth = 5;
context.strokeStyle = "#000";
context.beginPath();
context.translate(250,250);
context.rotate(hours*30*Math.PI/180);
context.moveTo(0,-130);
context.lineTo(0,10);
context.closePath();
context.stroke();
context.restore();
// 绘制分针
context.save();
context.lineWidth = 3;
context.strokeStyle = "#000";
context.beginPath();
context.translate(250,250);
context.rotate(min*6*Math.PI/180);
context.moveTo(0,-140);
context.lineTo(0,10);
context.closePath();
context.stroke();
context.restore();
// 绘制秒针
context.save();
context.lineWidth = 1;
context.strokeStyle = "#ff0000";
context.beginPath();
context.translate(250,250);
context.rotate(sec*6*Math.PI/180);
context.moveTo(0,-160);
context.lineTo(0,15);
context.closePath();
context.stroke();
context.restore();
}
// 1s 画一次并清除上一次图案
setInterval(drawClock,1000);
</script>
</body>
</html>
---------------------
作者:小皮咖
来源:CSDN
原文:https://blog.csdn.net/weixin_38788347/article/details/78239704
版权声明:本文为博主原创文章,转载请附上博文链接!

转载于:https://www.cnblogs.com/web928943/p/10165463.html

canvas 实现刮刮乐相关推荐

  1. 刮刮乐html5效果擦除,利用HTML5的画布Canvas实现刮刮卡效果

    先给大家展示效果: 你玩过刮刮卡么?一不小心可以中奖的那种.今天我给大家分享一个基于HTML5技术实现的刮刮卡效果,在PC上只需按住鼠标,在手机上你只需按住指头,轻轻刮去图层就可以模拟真实的刮奖效果. ...

  2. H5 Canvas刮刮乐

    玩游戏的人 很多时候都会遇到翻牌子  开宝箱. 总有人傻傻的在哪里还纠结很久到底点哪一个! 纠结  指不定翻哪一个会多一点,你明明看到那个卡片的奖项多 . 那我就告诉你好了  其实很多时候在你点开那个 ...

  3. canvas教程18-刮刮乐

    文章目录 一.刮刮乐 二.效果图 篇章 一.刮刮乐 <!DOCTYPE html> <html lang="en"> <head><met ...

  4. html5 刮刮乐 源码,HTML5 canvas实现刮刮乐功能

    最近比较闲,除了在群里给大家交流交流,就没啥学习重心.看了论坛里的各种帖子,各种问题满天飞,这里我就整理了2个h5 canvas的demo,分享给大家! 使用html5的canvas实现刮刮乐功能 舍 ...

  5. canvas之刮刮乐

    canvas之刮刮乐 canvas合成 说到刮刮乐,先让我们了解一下canvas合成. 透明度合成 globalAlpha globalAlpha 就是全局对象的透明度,全局对象就是canvas 的上 ...

  6. 使用Canvas制作刮刮乐,看看你能刮出什么奖品来?

    点击上方 前端Q,关注公众号 回复加群,加入前端Q技术交流群 前言 今天在一个彩票网站看到了一个刮刮乐的效果,觉得挺有意思的就打算来仿写一个,经过一番简单的思考大概就有了基本都想法.总体效果使用Can ...

  7. canvas实现简单的刮刮乐功能

    canvas实现刮刮乐效果 平时浏览一些购物网站常常有一些抽奖的环节它们就会使用一种刮刮乐的形式给用户发一些优惠券或者其它的一些奖品,对此突然产生了些许兴趣于是就琢磨着该如何实现,最终还是选择了can ...

  8. html5中canvas画布实现手机端和移动端的刮刮乐效果

    用html5中的canvas实现刮刮乐的效果 使用html+css实现背景的样式 使用clearRect()方法实现挂去的作用 手机端使用addEventListener()监听 手机端滑动事件tou ...

  9. 【Android界面实现】使用Canvas对象实现“刮刮乐”效果

    在淘宝.京东等电商举办活动的时候,经常可以看到在移动客户端推出的各种刮奖活动,而这种活动也受到了很多人的喜爱.从客户端的体验来说,这种效果应该是通过网页来实现的,那么,我们使用Android的自带控件 ...

  10. 简单的Canvas刮刮乐带动画效果的实例

    今天做了个刮刮乐领奖品的小活动,感觉挺有用的,整理在这儿记录下 上个效果图先: 加了个简单的 css 动画效果 下面贴上主要代码: index.html <!DOCTYPE html> & ...

最新文章

  1. emca 更改监听端口
  2. 谈谈NITE 2与OpenCV结合的第二个程序(提取人体骨骼坐标)
  3. Java自带的线程池ThreadPoolExecutor详细介绍说明和实例运用
  4. 前端学习(2959):axios介绍
  5. win7下搭建PHP mysql_简单介绍win7下搭建apache+php+mysql开发环境
  6. 10-12-顺序表地址排序-内部排序-第10章-《数据结构》课本源码-严蔚敏吴伟民版...
  7. C++---STL中迭代器失效的总结
  8. 每天进步一点点_抽奖程序
  9. 测试开发自我介绍模板
  10. anaconda报错Collecting package metadata (current_repodata.json): failed
  11. mysql是如何设置候选码_求关系模式中的候选键(软考,数据库)
  12. 天地图API搜索。定位等
  13. Python秒算24点,行还是不行?
  14. (BFM2009只是公开了数据模型,与99年开山基本一样)BM2009文献翻译
  15. DirextX—ddsd.lpitch是什么?
  16. 咸鱼Maya笔记—Maya 热键
  17. 中点分割裁剪算法 c语言,裁剪算法——中点分割算法/Liang-Barsky算法
  18. Qt学习笔记(二)【软件样式及界面外观设置】
  19. java wps 二次开发,Wps二次开发(POI)
  20. 京东商品发布实现店铺商品批量上新,节省大量人力

热门文章

  1. cas client 更新ticket_有人知道 cas单点登录系统是怎么样取得proxyticket的?
  2. fedora nginx php,在fedora16下安裝nginx + php-fpm
  3. mysql自动备份linux_Mysql for linux mysql自动备份脚本
  4. 压缩感知及应用 源代码_信言动态|学院成功举办2019年机器学习与压缩感知理论及其应用研讨会...
  5. public class c中_Spring中@Import的各种用法以及ImportAware接口
  6. python应用程序实例_python中一个非常简单的异步应用程序
  7. java从hbase增量导出到,Hbase实用技巧:全量+增量数据的迁移方法
  8. ubuntu安装redis_在Ubuntu上安装Redis
  9. maven配置testng_TestNG Maven Surefire插件配置
  10. java jvm内存模型_Java(JVM)内存模型– Java中的内存管理