canvas刮奖效果

上次写刮奖效果都一年前了,那时候还是百度找的源码给改的,自己其实也是迷迷糊糊的,这次因为让妹子写,然后想着自己也重新整理下。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <title>刮奖效果</title>
    <style type="text/css">
    #canvas{
        display: block;
        margin:0 auto;
    }
    </style>
</head>
<body>
    <canvas id="canvas"></canvas>

    <script type="text/javascript">
    // 初始化,设置canva的宽(width)、高(height),涂抹画笔的直径(r),背景图片(img)(即底层的图片),上层遮罩层
    var width=440;
    var height=440;
    var r=20;
    var img = new Image();
    img.src="1.jpg";
    var canvas=document.getElementById("canvas");
    canvas.style.backgroundImage=‘url(‘+img.src+‘)‘;
    canvas.width=width;
    canvas.height=height;
    var ctx=canvas.getContext("2d");
    ctx.fillStyle="#ccc";
    ctx.fillRect(0,0,width,height);                    //绘制上层的涂层
    ctx.globalCompositeOperation="destination-out";    //在源图像外显示目标图像。只有源图像外的目标图像部分会被显示,源图像是透明的。
    var isMove=false;

    var el=new Array();
    el.x=canvas.offsetLeft;
    el.y=canvas.offsetTop;
    /************************************
    方式一:利用arc来模拟两端圆角的直线
    ***********************************/
    //按下时
    function touchStart(e){
        e.preventDefault();
        isMove=true;
        ctx.closePath();
    }
    // 移动时
    function touchMove(e){
        e.preventDefault();
        var x,y;
        if(isMove){
            if(e.targetTouches){                    //移动端
                var touch=e.targetTouches[0];
                x=touch.clientX-el.x;                //坐标矫正
                y=touch.clientY-el.y;
            }else{                                    //pc端
                x=e.pageX-el.x;
                y=e.pageY-el.y;
            }
            ctx.beginPath();
            ctx.arc(x,y,r,0,Math.PI*2);                //绘制笔触
            ctx.fill();
            ctx.closePath();                        //每次闭合路径
        }
    }
    // 离开时
    function touchEnd(e){
        e.preventDefault();
        isMove=false ;
        ctx.closePath();
        //涂抹区域百分比
        var imgData=ctx.getImageData(0,0,width,height);//返回ImageData对象,该对象拷贝画布指定的像素数据
        var pixles=imgData.data;
        var transNum=0;
        //rgba以数组形式储存在imageData中,
        // r=imgData.data[0];
        // g=imgData.data[1];
        // b=imgData.data[2];
        // a=imgData.data[3];
        for(var i=3,j=pixles.length;i<j;i+=4){
            var a=pixles[i];
            if(a==0){
                transNum++
            }
        }
        var transPercent=transNum/(pixles.length/4);//透明度比
        console.log(transPercent);
        //超过某个值显示所有
        if(transPercent>0.5){
            ctx.fillRect(0,0,width,height);
        }
    }

    /**************************************************************************
    方式二:ctx.lineTo(x,y)来画直线,用ctx.lineCap="round";来设置直线两端的圆角
    当滑的很快的时候,这种效果比第一种好
    ***************************************************************************/
    //按下时
    // function touchStart(e){
    //     e.preventDefault();
    //     isMove=true;
    //     var x,y;
    //     if(e.targetTouches){                    //移动端
    //         var touch=e.targetTouches[0];
    //         x=touch.clientX-el.x;
    //         y=touch.clientY-el.y;
    //     }else{                                    //pc端
    //         x=touch.clientX-el.x;
    //         y=touch.clientY-el.y;
    //     }
    //     ctx.beginPath();
    //     ctx.lineCap="round";
    //     ctx.lineJoin="round";
    //     ctx.lineWidth=r;
    //     ctx.moveTo(x,y);

    // }
    // // 移动时
    // function touchMove(e){
    //     e.preventDefault();
    //     var x,y;
    //     if(isMove){
    //         if(e.targetTouches){                    //移动端
    //             var touch=e.targetTouches[0];
    //             x=touch.clientX;
    //             y=touch.clientY;
    //         }else{                                    //pc端
    //             x=e.pageX;
    //             y=e.pageY;
    //         }
    //         ctx.lineTo(x,y);                        //绘制笔触
    //         ctx.stroke();
    //     }
    // }
    // // 离开时
    // function touchEnd(e){
    //     e.preventDefault();
    //     isMove=false ;
    //     ctx.closePath();
    // }

    // 事件监听
    canvas.addEventListener("touchstart",touchStart);
    canvas.addEventListener("mousedown",touchStart);
    canvas.addEventListener("touchmove",touchMove);
    canvas.addEventListener("mousemove",touchMove);
    canvas.addEventListener("touchend",touchEnd);
    canvas.addEventListener("mouseup",touchEnd);
    </script>
</body>
</html>
时间: 2024-12-06 04:55:14

canvas刮奖效果的相关文章

简单入门canvas - 通过刮奖效果来学习

一 .前言 一直在做PC端的前端开发,从互联网到行业软件.最近发现移动端已经成为前端必备技能了,真是不能停止学习.HTML5新增的一些东西,canvas是用的比较多也比较复杂的一个,简单的入门了一下,通过一个刮奖效果来学习. 二.canvas基础 本文的目标是做一个刮奖效果,但是如果都不知道canvas是怎么回事,那么肯定也无法进行下去,所以先讲讲canvas基础吧. 首先,该怎么理解canvas,思来想去,最好的理解办法应该就是把canvas理解为一个空白的画纸,一张你可以在上面画画的纸. 然

HTML5实现刮奖效果

原文:HTML5实现刮奖效果 要实现刮奖效果,最重要的是要找到一种方法:当刮开上层的涂层是就能看到下层的结果.而HTML5的canvas API中有一个属性globalCompositeOperation,这个属性有多个值,而实现刮奖效果要用到的值就是destination-out.意思就是:在已有内容和新图形不重叠的地方,已有内容保留,所有其他内容成为透明.这样可能不好理解,后面实现的时候会解释.有了globalCompositeOperation这个属性,实现过程就很简单了. 我们需要有两个

刮刮卡刮奖效果

//代码框架 <div class="content-box"> <div id="demo1" class="scratchpad"></div> <div id="demo1-percent"> </div> <script type="text/javascript"> $('#demo1').wScratchPad({ size

canvas 利用canvas中的globalCompositeOperation 绘制刮奖 效果

<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title></title> <style> body { height: 1000px; } </style> </head> <body> <div style="position: relative; width: 300p

HTML5模仿刮奖效果-页面涂抹消失插件wScratch

前言 HTML5的canvas有很多应用点,如绘画板.图形绘制.游戏交互.彩票刮刮乐等,除了这些,还有个比较好的点就是主页涂抹一部分之后,页面消失进入主要内容. wScratch是一个模拟刮刮卡的jQuery插件,可以设置刮开纯色或者图像. 演示 显示刮卡百分比 到达一定百分比清空 属性设置 可用的属性,以下是默认值 1 2 3 4 5 6 7 8 9 10 $('#elem').wScratchPad({ size        : 5,          // The size of the

android刮刮奖效果

自定义View盖在textView上 import android.content.Context; import android.graphics.Bitmap; import android.graphics.Bitmap.Config; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Paint; import android.graphics.Path; impo

使用HTML5实现刮刮卡效果

原文地址:http://www.phpthinking.com/archives/525 你玩过刮刮卡么?一不小心可以中奖的那种.今天我给大家分享一个基于HTML5技术实现的刮刮卡效果,在PC上只需按住鼠标,在手机上你只需按住指头,轻轻刮去图层就可以模拟真实的刮奖效果. 我们利用HTML5的画布Canvas,结合其提供的API,在Canvas元素上绘制一个灰色蒙层,然后通过检测用户鼠标移到和手势来绘制一个透明的图形,这样就能看到Canvas背景下的真实图片,就达到刮刮卡效果. 点击下载源码 HT

JS框架_(JQuery.js)模拟刮奖

纯CSS模拟刮奖效果 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatibl

使用Canvas对象实现“刮刮乐”效果

在淘宝.京东等电商举办活动的时候,经常可以看到在移动客户端推出的各种刮奖活动,而这种活动也受到了很多人的喜爱.从客户端的体验来说,这种效果应该是通过网页来实现的,那么,我们使用Android的自带控件能不能实现这种刮刮乐的效果呢?当然可以,本篇文章将介绍使用Canvas这个对象,如何实现"刮刮乐"的效果. 先看效果图 下面我们看一下如何使用代码实现 布局文件 <FrameLayout xmlns:android="http://schemas.android.com/a