canvas 绘制刮刮卡
思路=》
用div来展示刮奖结果,用canvas绘制刮奖前展示的图片或者文字;将canvas叠在div上方,刮奖是只需要操作canvas配合touch事件即可简单完成。
canvas刮奖可以用globalCompositeOperation属性制作。
globalCompositeOperation:
| 属性值 | 描述 |
|---|---|
| source-over (default) | 新图形会覆盖在原有内容之上 |
| destination-over | 会在原有内容之下绘制新图形 |
| source-in | 新图形会仅仅出现与原有内容重叠的部分。其它区域都变成透明的 |
| destination-in | 原有内容中与新图形重叠的部分会被保留,其它区域都变成透明的 |
| source-out | 结果是只有新图形中与原有内容不重叠的部分会被绘制出来 |
| destination-out | 原有内容中与新图形不重叠的部分会被保留 |
| source-atop | 新图形中与原有内容重叠的部分会被绘制,并覆盖于原有内容之上 |
| destination-atop | 原有内容中与新内容重叠的部分会被保留,并会在原有内容之下绘制新图形 |
| lighter | 两图形中重叠部分作加色处理 |
| darker | 两图形中重叠的部分作减色处理 |
| xor | 重叠的部分会变成透明 |
| copy | 只有新图形会被保留,其它都被清除掉 |
实现代码
class Scratch{
constructor(options){
this.obj = document.querySelector(options.obj); //div容器
this.bgPic = options.bgPic; //刮刮卡前景图
this.radius = options.radius; //圆半径
this.area = options.area || 50; //擦拭部分面积 超过部分隐藏或者清除画布(当前清除画布)
this.succuss = options.succuss; //擦拭成功后执行方法
this.startfn = options.startfn; //开始擦拭时调用刮刮乐结果(可以给div换图或者换样式)
this.isPrize = false; //是否擦拭完毕
}
//初始化
init(){
this.getSize();
this.createCanvas();
this.drawBg();
this.event();
}
//获得容器的宽高(用于设置canvas宽高)
getSize(){
this.width = this.obj.offsetWidth;
this.height = this.obj.offsetHeight;
this.left = this.obj.offsetLeft;
this.top = this.obj.offsetTop;
}
//创建canvas并设置宽高插入容器中
createCanvas(){
let canvas = document.createElement("canvas");
canvas.width = this.width;
canvas.height = this.height;
this.ctx = canvas.getContext("2d");
this.obj.append(canvas)
}//绘制前景图 图片必须预加载
drawBg(){
let oImg = new Image(),
that = this;
oImg.src = that.bgPic;
oImg.onload=()=>{
this.touch = true;
this.ctx.drawImage(oImg,0,0,oImg.width,oImg.height,0,0,this.width,this.height);
this.ctx.globalCompositeOperation = 'destination-out'; //设置原有内容中与新图形不重叠的部分会被保留
}
}
//添加touch事件
event(){
let obj = this.obj,
that = this;
obj.addEventListener("touchstart",event=>{that.touchCanvas(event).bind(this)})
obj.addEventListener("touchmove",event=>{that.touchCanvas(event).bind(this)})
obj.addEventListener("touchend",event=>{})
}
//擦拭canvas
touchCanvas(event){
if(!this.touch){
return false;
}
if(!this.isPrize){
this.isPrize = true;
this.startfn();
}
var e=window.event||event;
e.preventDefault(); //禁止ios和安卓默认事件页面下拉动
this.clearCanvas(e.targetTouches[0].pageX-this.left,e.targetTouches[0].pageY-this.top);
}
//绘制圆形 橡皮擦
clearCanvas(x,y){
this.ctx.save();
this.ctx.beginPath();
this.ctx.arc(x,y,this.radius,0,2*Math.PI);
this.ctx.fill();
this.ctx.closePath();
this.ctx.stroke();
this.ctx.restore();
this.compute();
}
//计算透明区域
compute(){
var pixels = this.ctx.getImageData(0,0,this.width,this.height).data;
let transPixels = [];
for(let i = 0; i < pixels.length; i += 4){
// 严格上来说,判断像素点是否透明需要判断该像素点的a值是否等于0,
// 为了提高计算效率,这儿设置当a值小于128,也就是半透明状态时就可以了
if(pixels[i+3] < 128){
transPixels.push(pixels[i+3]);
}
}
let area= (transPixels.length / (pixels.length / 4) * 100).toFixed(2);
if(area>this.area){
this.touch = false;
this.ctx.clearRect(0,0,this.width,this.height);
this.ctx.globalCompositeOperation = 'source-over';
this.succuss();
}
}
//再来一次(重置)
reset(){
this.isPrize = false;
this.drawBg();
}
}
(第一次写博客,有错请见谅)
canvas 绘制刮刮卡的更多相关文章
- canvas实现刮刮卡效果
canvas实现刮刮卡效果 实现步骤: 设置页面背景图,即刮刮卡底部图片 绘制canvas 刮刮卡顶部图片drawImage 绑定事件 addEventListener touchstart.tou ...
- qt qml 刮刮卡效果
用canvas+mouseArea实现的刮刮卡效果. 表层是一层色彩,用手指划开,可看到下面的文字Lisence: MIT, 请保留本文档说明Author: surfsky.cnblogs.com 2 ...
- 网页闯关游戏(riddle webgame)--H5刮刮卡的原理和实践
前言: 之前编写了一个网页闯关游戏(类似Riddle Game), 除了希望大家能够体验一下我的游戏外. 也愿意分享编写这个网页游戏过程中, 学到的一些知识. 对于刮刮卡, 想必大家都很熟悉, 也很喜 ...
- 使用HTML5实现刮刮卡效果
你玩过刮刮卡么?一不小心可以中奖的那种.今天我给大家分享一个基于HTML5技术实现的刮刮卡效果,在PC上只需按住鼠标,在手机上你只需按住指头,轻轻刮去图层就可以模拟真实的刮奖效果. 我们利用HTML5 ...
- Android 自定义View修炼-【2014年最后的分享啦】Android实现自定义刮刮卡效果View
一.简介: 今天是2014年最后一天啦,首先在这里,我祝福大家在新的2015年都一个个的新健康,新收入,新顺利,新如意!!! 上一偏,我介绍了用Xfermode实现自定义圆角和椭圆图片view的博文& ...
- Android刮刮卡自定义控件
网上的都是自己绘制的或者图片,我的需求是可以随意的自定义底部和顶部的布局.所以自己重写一个,原理就是直接继承 View 来实现一个刮层,让这个刮层和图片以及文字不产生任何依赖,再结合 FrameLay ...
- Android 自定义控件实现刮刮卡效果 真的就只是刮刮卡么
转载请标明出处:http://blog.csdn.net/lmj623565791/article/details/40162163 , 本文出自:[张鸿洋的博客] 很久以前也过一个html5的刮刮卡 ...
- HTML5_图片合成_刮刮卡
刮刮卡(图片合成) 定义: globalCompositeOperation 属性,设置或返回如何将源图像 将 myCanvas 的背景图设置为一张图片,(刮开后显示) // 目标图像(已有的,外面一 ...
- canvas 实现刮刮乐
在解决问题前,我们先来了解一下 canvas 标签canvas 是 html5 出现的新标签,像所有的 dom 对象一样它有自己本身的属性.方法和事件,其中就有绘图的方法,js 能够调用它来进行绘图. ...
随机推荐
- 网络I/O模型--02阻塞模式(多线程)
当服务器收到客户端 X 的请求后(读取到所有请求数据后),将这个请求送入一个独立线程进行处理,然后主线程继续接收客户端 Y 的请求. 客户端一侧也可以使用一个子线程和服务器端进行通信.这样客户端主线程 ...
- R中字符串操作
简介 Stringr中包含3个主要的函数族 字符操作 空格处理 模式匹配 常用函数 在平常的数据分析工作中,经常要用到如下的函数 函数 操作 str_length() 获取字符串长度 str_sub( ...
- Office - Excel 2013
1. 在使用TODAY()时需要注意格式,比如,如果系统区域是中国,那么格式为2015/7/28,如果在单元格中设置了其它格式(比如美国格式 3/24/2015),则可能无法比较: 2. $表示cel ...
- SQL Server的优点与缺点
一般来说索引会加快查询速度,但会影响插入,修改,删除的数据,且占用物理空间;所以我们应该合理的创建索引,而且应该先创建聚合索引,再创建非聚合索引.要在经常进行查询的列上创建索引,而且如果表列较少的话要 ...
- 转载:https://blog.csdn.net/qq_22706515/article/details/52595027
https://blog.csdn.net/qq_22706515/article/details/52595027 包含直播,即时通讯. 大平台都有免费版或基础版,对于需求不大的情况比较适合.
- 【Kettle】2、文件夹与界面介绍
1.文件夹介绍 下载Kettle6.1解压后出现下图相关文件夹以及文件夹介绍说明: Lib:存放Kettle的核心(core)jar包.工作引擎(engine)jar包.数据库(DB) jar包.图形 ...
- Java简单方法批量修改Windows文件夹下的文件名(简单IO使用)
package test.tttt; import java.io.File; import java.util.ArrayList; import java.util.List; public cl ...
- Azure Cosmos DB 使用费用参考
之前在学习Cosmos DB 中SQL API(DocumentDB) 的时候,也就是之前做的一些笔记,看到有使用费用的一些介绍,就有兴趣的去了解了下,做了一下简单的总结. 想了解更多或是购买使用的还 ...
- android 常用adb 及linux 命令
一.ADB相关 adb shell:进入连接的USB调试模式设备shell命令行下 adb tcpip 5555:将USB连接的调试及的连接方式改为网络远程模式进行调试 这里端口为5555(adb 默 ...
- [翻译] RAReorderableLayout
RAReorderableLayout A UICollectionView layout which you can move items with drag and drop. 一种UIColle ...