中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久

Html5實(shí)現(xiàn)移動(dòng)端、PC端 刮刮卡效果
來源:易賢網(wǎng) 閱讀:1921 次 日期:2016-08-01 14:59:48
溫馨提示:易賢網(wǎng)小編為您整理了“Html5實(shí)現(xiàn)移動(dòng)端、PC端 刮刮卡效果”,方便廣大網(wǎng)友查閱!

這篇文章主要介紹了 Html5實(shí)現(xiàn)移動(dòng)端、PC端 刮刮卡效果的相關(guān)資料,需要的朋友可以參考下

刮刮卡需求:

每一位用戶有三次刮刮卡的機(jī)會(huì)

本次刮刮卡的結(jié)果會(huì)覆蓋上次的結(jié)果

刮刮卡的中獎(jiǎng)幾率呈現(xiàn)為遞增的曲線(保證三次中必須有一次中獎(jiǎng))

刮出的結(jié)果包含按鈕既(領(lǐng)取獎(jiǎng)品 or 再來一次 )

分享活動(dòng)獎(jiǎng)品升級(jí)(這里主要是微信分享的回調(diào)了)

我們自己的需求,今天就說怎么制作刮刮卡,有這樣需求的可以找我要源碼

第一、body創(chuàng)建Canvas

XML/HTML Code

<div class="info" id="prize">  

     <span id="prompt"></span>  

     <span class="btn" id="ok">領(lǐng)取獎(jiǎng)品</span>  

    <span class="btn" id="no">再來一次</span>  

 </div>  

 <canvas id="c1" class="canvas"></canvas>  

這里我們首先創(chuàng)建了一個(gè)Canvas,并且在canvas底部加上了刮開后的效果。

第二、 頁(yè)面加載后開始初始化畫布

首先定義一些需要的變量

XML/HTML Code

var c1; //畫布   

 var ctx; //畫筆   

 var ismousedown; //標(biāo)志用戶是否按下鼠標(biāo)或開始觸摸   

 var isOk=0; //標(biāo)志用戶是否已經(jīng)刮開了一半以上   

 var fontem = parseInt(window.getComputedStyle(document.documentElement, null)["font-size"]);//這是為了不同分辨率上配合@media自動(dòng)調(diào)節(jié)刮的寬度  

頁(yè)面加載后開始初始化畫布(這樣子就可以在頁(yè)面創(chuàng)建一個(gè)畫布了)

XML/HTML Code

window.onload = function(){    

    c1 = document.getElementById("c1");   

    //這里很關(guān)鍵,canvas自帶兩個(gè)屬性width、height,我理解為畫布的分辨率,跟style中的width、height意義不同。   

    //最好設(shè)置成跟畫布在頁(yè)面中的實(shí)際大小一樣   

    //不然canvas中的坐標(biāo)跟鼠標(biāo)的坐標(biāo)無法匹配   

    c1c1.width=c1.clientWidth;   

    c1c1.height=c1.clientHeight;   

    ctx = c1.getContext("2d");   

    //PC端的處理   

    c1.addEventListener("mousemove",eventMove,false);   

    c1.addEventListener("mousedown",eventDown,false);   

    c1.addEventListener("mouseup",eventUp,false);   

    //移動(dòng)端的處理   

    c1.addEventListener('touchstart', eventDown,false);   

    c1.addEventListener('touchend', eventUp,false);   

    c1.addEventListener('touchmove', eventMove,false);   

    //初始化   

    initCanvas();   

 }  

第三、畫灰色的矩形鋪滿

XML/HTML Code

function initCanvas(){//網(wǎng)上的做法是給canvas設(shè)置一張背景圖片,我這里的做法是直接在canvas下面另外放了個(gè)div   

     //c1.style.backgroundImage="url(中獎(jiǎng)圖片.jpg)";   

     ctx.globalCompositeOperation = "source-over";   

     ctx.fillStyle = '#aaaaaa';   

     ctx.fillRect(0,0,c1.clientWidth,c1.clientHeight);   

     ctx.fill();   

     ctx.font = "Bold 30px Arial";   

                 ctx.textAlign = "center";   

                 ctx.fillStyle = "#999999";   

                 ctx.fillText("刮一刮",c1.width/2,50);//把這個(gè)屬性設(shè)為這個(gè)就可以做出圓形橡皮擦的效果   

     //有些老的手機(jī)自帶瀏覽器不支持destination-out,下面的代碼中有修復(fù)的方法   

     ctx.globalCompositeOperation = 'destination-out';}  

第四、鼠標(biāo)按下 和 觸摸開始

XML/HTML Code

function eventDown(e){   

    e.preventDefault();   

    ismousedown=true;}  

第五、鼠標(biāo)抬起 和 觸摸結(jié)束

XML/HTML Code

function eventUp(e){   

    e.preventDefault();   

    //得到canvas的全部數(shù)據(jù)   

    var a = ctx.getImageData(0,0,c1.width,c1.height);   

    var j=0;   

    for(var i=3;i<a.data.length;i+=4){   

        if(a.data[i]==0)j++;   

    }   

    //當(dāng)被刮開的區(qū)域等于一半時(shí),則可以開始處理結(jié)果   

    if(j>=a.data.length/8){   

        isOk = 1;   

    }   

    ismousedown=false;   

 }  

第六、鼠標(biāo)移動(dòng) 和 觸摸移動(dòng)

XML/HTML Code

//鼠標(biāo)移動(dòng) 和 觸摸移動(dòng)   

function eventMove(e){   

    e.preventDefault();   

    if(ismousedown) {   

        if(e.changedTouches){   

            ee=e.changedTouches[e.changedTouches.length-1];   

        }   

        var topY = document.getElementById("top").offsetTop;   

        var oX = c1.offsetLeft,   

        oY = c1.offsetTop+topY;   

        var x = (e.clientX + document.body.scrollLeft || e.pageX) - oX || 0,   

        y = (e.clientY + document.body.scrollTop || e.pageY) - oY || 0;   

        //畫360度的弧線,就是一個(gè)圓,因?yàn)樵O(shè)置了ctx.globalCompositeOperation = 'destination-out';   

        //畫出來是透明的   

        ctx.beginPath();   

        ctx.arc(x, y, fontem*1.2, 0, Math.PI * 2,true);   

        //下面3行代碼是為了修復(fù)部分手機(jī)瀏覽器不支持destination-out   

        //我也不是很清楚這樣做的原理是什么   

        c1.style.display = 'none';   

        c1.offsetHeight;   

        c1.style.display = 'inherit';    

        ctx.fill();   

    }   

    if(isOk){   

        var btn = document.getElementsByClassName("btn");   

            for(var i=0; i<btn.length; i++){   

                btn[i].style.zIndex = '3';   

            }   

            document.getElementsByClassName("btn")[0].style.zIndex="3";   

    }   

}  

第七: 如果沒有抽中再來一次

很明顯,再來一次就是初始化所有的值,畫布重新加載,但是如果有次數(shù)限制的需求,務(wù)必在這里計(jì)算清楚。

注:由于我們要求的比較多今天就不說怎么計(jì)算中獎(jiǎng)概率的方法了。

以上所述是小編給大家介紹的 Html5實(shí)現(xiàn)移動(dòng)端、PC端 刮刮卡效果,希望對(duì)大家有所幫助

更多信息請(qǐng)查看網(wǎng)頁(yè)制作
易賢網(wǎng)手機(jī)網(wǎng)站地址:Html5實(shí)現(xiàn)移動(dòng)端、PC端 刮刮卡效果
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!
相關(guān)閱讀網(wǎng)頁(yè)制作

2026上岸·考公考編培訓(xùn)報(bào)班

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
欧美精品一区二区在线观看| 久久久水蜜桃av免费网站| 久久综合九色99| 91久久久亚洲精品| 欧美午夜剧场| 久久精品国产一区二区三区| 亚洲欧洲一区二区三区| 欧美视频一区二区| 欧美在线一级va免费观看| 91久久精品国产91久久性色tv| 国产精品成人aaaaa网站| 久久久久亚洲综合| 一区二区三区视频在线看| 国产综合18久久久久久| 国产精品v日韩精品v欧美精品网站| 久久久国产一区二区三区| aⅴ色国产欧美| 黄色影院成人| 国产精品久久久久久久久久久久久 | 一区二区三区精品在线| 国产一区二区三区黄| 欧美精品免费观看二区| 欧美中文字幕在线播放| 亚洲人成在线观看| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ入口 | 国产精品国产三级国产普通话99| 久久艳片www.17c.com| 亚洲男人的天堂在线观看| 亚洲三级毛片| 国语自产精品视频在线看8查询8 | 欧美国产精品劲爆| 亚洲香蕉在线观看| 亚洲精品一区二区三区av| 精品成人在线观看| 国产日本欧美一区二区三区在线| 欧美人妖另类| 久久精品日产第一区二区| 中文一区二区| 亚洲麻豆国产自偷在线| 亚洲国产成人精品久久久国产成人一区| 国产精品亚洲一区| 欧美视频二区| 欧美日韩福利| 欧美区一区二| 欧美高清视频在线| 免费亚洲一区二区| 久久这里有精品视频| 久久国产精品一区二区| 亚洲人成亚洲人成在线观看图片 | 国产精品高潮粉嫩av| 欧美精彩视频一区二区三区| 葵司免费一区二区三区四区五区| 亚洲一区免费看| 亚洲视频狠狠| 亚洲一二三区在线| 亚洲午夜久久久久久久久电影院| 一区二区三区免费看| 一区二区三区色| 亚洲私人影院| 亚洲免费大片| 在线视频你懂得一区| 中日韩美女免费视频网址在线观看 | 亚洲私人影院在线观看| 日韩系列欧美系列| 在线观看欧美精品| 亚洲大片免费看| 亚洲国产成人精品久久久国产成人一区 | 亚洲国产精品一区| 亚洲国产一区在线观看| 亚洲国产精品综合| 91久久精品美女高潮| 亚洲人成毛片在线播放| 亚洲精品免费在线播放| 一本大道久久a久久综合婷婷| 99精品黄色片免费大全| 一区二区三区国产| 亚洲一区二区视频| 亚洲一区免费看| 亚洲综合另类| 久久成人人人人精品欧| 久久亚洲精品伦理| 欧美激情导航| 欧美亚州一区二区三区| 国产婷婷色一区二区三区四区| 国产无一区二区| 在线观看视频亚洲| 99ri日韩精品视频| 亚洲欧美99| 亚洲综合电影一区二区三区| 午夜一区二区三视频在线观看| 欧美中在线观看| 快播亚洲色图| 欧美视频免费看| 国产亚洲毛片| 亚洲人成7777| 亚洲在线1234| 老妇喷水一区二区三区| 欧美日韩亚洲一区二区| 蜜桃av一区二区| 欧美大片第1页| 国产精品xnxxcom| 激情综合久久| 亚洲精品一区二区网址| 激情久久久久| 中国av一区| 久久久免费av| 欧美日韩一区二区三区在线看 | 亚洲成人在线视频网站| 亚洲美女淫视频| 午夜视频一区二区| 欧美大秀在线观看 | 免费成人av在线看| 国产精品高潮呻吟久久| 黑人巨大精品欧美一区二区| 在线观看视频日韩| 亚洲视频国产视频| 久久久噜久噜久久综合| 欧美午夜不卡视频| 悠悠资源网亚洲青| 亚洲一区二区三区精品动漫| 久久影院午夜片一区| 欧美日韩一级黄| 国一区二区在线观看| 亚洲一区二区三| 欧美freesex交免费视频| 国产乱码精品一区二区三区不卡| 伊人蜜桃色噜噜激情综合| 亚洲一区二区精品视频| 欧美电影免费观看高清| 国产亚洲人成网站在线观看| 99视频热这里只有精品免费| 久久久另类综合| 国产精品久久夜| 日韩写真在线| 美女精品在线观看| 国产精品a久久久久| 伊人一区二区三区久久精品| 亚洲一区观看| 欧美日本韩国在线| 在线看不卡av| 欧美在线观看日本一区| 欧美日韩亚洲精品内裤| 亚洲国产成人porn| 午夜精品久久久久99热蜜桃导演| 欧美久久综合| 99热这里只有精品8| 亚洲午夜三级在线| 国产精品高清一区二区三区| 亚洲五月婷婷| 国产精品青草综合久久久久99 | 亚洲国产视频一区二区| 老牛影视一区二区三区| 在线免费精品视频| 亚洲欧美一区二区精品久久久| 免费日韩精品中文字幕视频在线| 伊人狠狠色j香婷婷综合| 另类欧美日韩国产在线| 亚洲黄网站在线观看| 欧美激情精品久久久久久黑人| 日韩一级黄色片| 国产精品99免视看9| 香蕉国产精品偷在线观看不卡| 国产日韩欧美自拍| 久久综合九色综合欧美狠狠| 亚洲国产一区二区三区在线播| 欧美精品激情blacked18| 一区二区三区高清不卡| 国产精品乱子乱xxxx| 久久国产精品一区二区| 永久免费精品影视网站| 欧美激情一区二区久久久| 一区二区三区波多野结衣在线观看| 国产精品久久久久毛片软件| 欧美一区1区三区3区公司| 在线观看的日韩av| 欧美精品aa| 亚洲欧美日韩电影| 黄色日韩网站| 欧美日韩成人综合天天影院| 亚洲欧美一区二区精品久久久| 精品成人久久| 欧美精选一区| 亚洲中无吗在线| 激情久久一区| 欧美日韩情趣电影| 欧美伊人久久| 亚洲精选视频免费看| 国产精品永久免费观看| 久久综合色8888| 在线视频精品一| 国产一区二区三区久久久久久久久| 免费中文日韩| 亚洲欧美在线观看| 亚洲人成人99网站| 国产欧美在线播放| 欧美激情无毛| 久久精品国产亚洲5555| 99国产精品99久久久久久| 国产亚洲一级| 欧美日本二区|