<template>

<!--游玩区域-->
<div class="panel">
<canvas
id="canvas" @touchstart.prevent="touchStart($event)" @touchmove.prevent="eventMove($event)"
:style='{"background-image":"url("+backgroundImage+")"}'
width="550" height="380"></canvas>
<div id="canvasMask" v-if="start">
<div class="start" @touchstart="StartTouch()">
<div class="startContain">
<span>刮开试试手气</span>
<span >开始刮开</span>
</div>
<img src="../assets/scratch/u611.png" alt="">
</div> </div>
<div class="reStart" v-if="restart">
<span @touchstart="ContinueScratch()">继续刮奖</span>
</div> </div> </template>
<script>
let canvas;
let ctx; export default {
// inject:["reload"],
data(){
return{
start:true,
restart:false,
clientWidth:null,
canvasWidth:null,
canvasHeight:null,
backgroundImage: require('../assets/scratch/prize2.png'),
num:2
}
},
mounted(){
this.initCanvas()
},
methods:{
initCanvas() {
console.log("初始化canvas")
canvas = document.getElementById('canvas');
ctx = canvas.getContext('2d');
this.clientWidth = document.documentElement.clientWidth,
this.canvasWidth = Math.floor(this.clientWidth * 550 / 750),//canvas宽 = 屏幕宽 * 设计稿里canvas宽 / 750
this.canvasHeight = Math.floor(this.clientWidth * 380 / 750),//canvas高 = 屏幕宽 * 设计稿里canvas高 / 750 canvas.style.width=this.canvasWidth+'px';
canvas.style.height=this.canvasHeight+'px';
console.log(canvas.style.backgroundImage);
this.drawPic()
},
drawPic() { ctx.beginPath();
ctx.fillStyle = '#999';//刮刮乐图层的填充色
ctx.lineCap = "round";//绘制的线结束时为圆形
ctx.lineJoin = "round";//当两条线交汇时创建圆形边角
ctx.lineWidth = 30;//单次刮开面积
ctx.fillRect(0, 0, this.canvasWidth, this.canvasHeight);
ctx.save();//保存画布上面的状态
ctx.closePath();
// ctx.clip(); ctx.globalCompositeOperation = 'destination-out';//新图像和原图像重合部分变透明 //下面代码是为了修复部分手机浏览器不支持destination-out
canvas.style.display="inherit"; },
touchStart(e){ e = e || window.event;
if (typeof e.touches !== 'undefined') {
e = e.touches[0];//获取触点
}
var x = e.pageX-e.target.offsetLeft,
y = e.pageY-e.target.offsetTop;
ctx.moveTo(x, y);
//touchmove事件
this.eventMove(e);
},
eventMove(e){
e = e || window.event;
if (typeof e.touches !== 'undefined') {
e = e.touches[0];
}
var x = e.pageX-e.target.offsetLeft,
y = e.pageY-e.target.offsetTop;
ctx.lineTo(x, y);
ctx.stroke();
this.clear();
},
clear() {
let data = ctx.getImageData(0, 0, this.canvasWidth, this.canvasHeight).data,//得到canvas的全部数据
half = 0;
//length = canvasWidth * canvasHeight * 4,一个像素块是一个对象rgba四个值,a范围为0~255
for (var i = 3, length = data.length; i < length; i += 4) {//因为有rgba四个值,下标0开始,所以初始i=3
data[i] === 0 && half++;//存在imageData对象时half加1 PS:该像素区域透明即为不存在该对象
}
//当刮开的区域大于等于30%时,则可以开始处理结果
if (half >= this.canvasWidth * this.canvasHeight * 0.3) {
// alert(111)
ctx.clearRect(0, 0, this.canvasWidth, this.canvasHeight);//清空画布
this.restart=true; }
},
StartTouch(){
this.start=false;
},
ContinueScratch(){
this.num--;
if(this.num<=0){
this.num=0;
console.log(this.num)
alert("没有剩余刮奖次数")
}else{
this.start=true;
this.restart=false;
ctx.restore();//恢复上面保存的画布内容
this.initCanvas();
}
}
}
}
</script>
<style scoped> .panel{
}
.panel{
}
.panel #canvas{
position: absolute;
top: 5.5rem;
left: 1rem;
border-radius: 10%;
/* background: url('../assets/scratch/prize2.png'); */
background-size:100% 100%;
}
.panel #canvasMask{
position: absolute;
top: 5.3rem;
left: 1rem;
width: 6rem;
height: 4rem;
overflow: hidden;
}
.panel #canvasMask .start{
width: 6rem;
height: 4rem;
display: flex;
/* background-color: sandybrown; */
padding-left: 1.2rem;
padding-top: 0.6rem;
}
.panel #canvasMask .start img{
display: inline-block;
width: 2rem;
height: 2rem;
}
.panel #canvasMask .start .startContain{
padding-top: 0.8rem;
}
.panel #canvasMask .start .startContain span{
display: block;
font-size: 0.3rem;
text-align: center;
}
.panel #canvasMask .start .startContain span:last-child{
margin-top: 0.2rem;
font-weight: bold;
}
.panel .reStart{
position: absolute;
top: 8.4rem;
left: 2.8rem;
color: red;
border: 0.01rem solid;
border-radius: 0.1rem;
padding: 0 0.1rem;
}
.panel .reStart span{
font-size: 0.4rem;
}
</style>

  

vue 刮刮乐功能实现的更多相关文章

  1. WP8下实现刮刮乐(橡皮擦)功能

    说到刮刮乐这个功能,我们最先想到的是上下两张(长方形)重叠,之后对上面这张图片进行操作. 我的想法是:通过手势,让手指划过的地方变成透明的,底部就会显示了. 那如何让图片变为透明呢?这就要对图片的像素 ...

  2. 游戏的套路你知道吗? H5 Canvas刮刮乐

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

  3. H5 Canvas刮刮乐

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

  4. canvas刮刮乐

    这周有点迷茫,不知道干嘛了,一天天就过去了!我在博客右侧公告栏加了qq交流,各位有好的主题,或者有趣的技术,欢迎交流!今天突发奇想,就写了2个h5 canvas的demo玩玩! demo一:刮刮乐 舍 ...

  5. 20行js代码制作网页刮刮乐

    分享一段用canvas和JS制作刮刮乐的代码,JS部分去掉注释不到20行代码效果如下 盖伦.jpg 刮刮乐.gif HTML部分 <body> ![](img/gailun.jpg) &l ...

  6. Android 撕衣服(刮刮乐游戏)

    项目简单介绍: 该项目为撕衣服,相似刮刮乐游戏 具体介绍: 用户启动项目后.载入一张图片,当用户点击图片的时候,点击的一片区域就会消失.从而显示出在这张图片以下的图片 这个小游戏相似与刮奖一样,刮开涂 ...

  7. 用Canvas画一个刮刮乐

    Canvas 通过 JavaScript 来绘制 2D图形.Canvas 是逐像素进行渲染的.开发者可以通过javascript脚本实现任意绘图.Canvas元素是HTML5的一部分,允许脚本语言动态 ...

  8. 刮刮乐自定义view

    说明:该代码是参考鸿洋大神的刮刮乐自定义view来写的. 实现:刮刮乐-刮奖的效果,如下效果 下面直接放代码了:只有一个自定义view,要实现真正的功能还需要进一步封装 /** * 自定义view-刮 ...

  9. [cocos2d-js]cc.RenderTexture几种用法(数字图片、刮刮乐效果)

    [转]http://blog.csdn.net/realcrazysun1/article/details/42393629 本文基于cocos2d-js 3.0版本引擎开发 RenderTextur ...

随机推荐

  1. vue中犯下的小错误(一)

    在开发采筑平台SRM的移动项目中:一个页面,感觉没啥错误,但是页面报错如下: 页面中的data或者mothods都没有任何问题,但是这个报错很是让人纠结,后来发现,在使用子组件时候: 此tabShow ...

  2. 本地Hadoop集群搭建

    什么是Hadoop? Hadoop是一个开源的Apache项目,通常用来进行大数据处理. Hadoop集群的架构: master节点维护分布式文件系统的所有信息,并负责调度资源分配,在Hadoop集群 ...

  3. mysql中实现更新数据+1,再次更新数据-1

    $sql="update article set comment=comment^1 where a_id=2"; 这条语句你会发现当你更新comment字段时为1,再次更新时为0 ...

  4. 性能测试进阶:(一)性能测试工具Locust

    An open source load testing tool. 一个开源性能测试工具. define user behaviour with python code, and swarm your ...

  5. Python专题——五分钟带你了解map、reduce和filter

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是Python专题第6篇文章,给大家介绍的是Python当中三个非常神奇的方法:map.reduce和filter. 不知道大家看到ma ...

  6. JAVA反射概念及使用详解(超详细)

    JAVA反射概念及使用详解 一.什么是反射? 反射:框架设计的灵魂 框架:半成品软件.可以在框架的基础上进行软件开发,简化编码 反射:将类的各个组成部分封装为其他对象,这就是反射机制 ​ 好处: ​ ...

  7. css hover 动画 transition:background-color 0.2s,color 0.2s; 外层套内层,正常是 里外层 鼠标上来 外层有hover,如果就想到里层hover触发外层hover,要用外层position 定义绝对定位,内层的hover跳出外层的div,这样视觉上就是两个单独的div,进行内外层联动。

    css hover 动画 transition:background-color 0.2s,color 0.2s; 外层套内层,正常是 里外层 鼠标上来 外层有hover,如果就想到里层hover触发 ...

  8. 深入解析Underscore.js源码架构

    Underscore.js是很有名的一个工具库,我也经常用他来处理对象,数组等,本文会深入解析Underscore源码架构,跟大家一起学习下他源码的亮点,然后模仿他写一个简单的架子来加深理解.他的源码 ...

  9. ATOMac - 基于Python的Mac应用Ui自动化库

    ATOMacTest 一.缘 起 近期工作需要对一款Mac端应用实现常用功能的自动化操作,同事推荐ATOMac这款工具,这几天简单研究了下,同时也发现现网介绍ATOMac的资料非常有限,故在此记录下A ...

  10. 我的MacbookPro进水了!维修过程记录

    电脑进水与解决方案 如果事情有变坏的可能,不管这种可能性有多小,它总会发生.---墨菲定律 进水过程 2020年03月21日日下午3点左右,不小心把水杯碰倒了,水通过电脑右侧的键盘处进入了大概有10毫 ...