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

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)
中文字幕免费精品_亚洲视频自拍_亚洲综合国产激情另类一区_色综合咪咪久久
影音先锋日韩有码| 影院欧美亚洲| 亚洲精美视频| 国产日韩一区二区| 国产精品美女久久福利网站| 亚洲在线观看免费| 翔田千里一区二区| 亚洲国产经典视频| 这里只有视频精品| 一本色道88久久加勒比精品| 性亚洲最疯狂xxxx高清| 男人的天堂亚洲| 国产精品日本精品| 亚洲国产精品一区二区尤物区 | 欧美日韩一区在线| 欧美性事在线| 国产亚洲欧美一区二区三区| 亚洲国产一区二区三区高清 | 国产一区99| 欧美日韩一二区| 欧美日韩在线免费视频| 激情欧美国产欧美| 久久精品亚洲一区二区| 久久精品中文字幕免费mv| 欧美日韩国产一区二区| 在线精品一区| 久久久久综合一区二区三区| 久久精品亚洲精品| 亚洲欧美国产另类| 亚洲激情视频在线| 亚洲欧洲日本国产| 亚洲特色特黄| 久久成人国产精品| 欧美色图麻豆| 影音先锋欧美精品| 欧美激情第五页| 国产精品久久久久影院色老大 | av不卡免费看| 亚洲电影视频在线| 国产精品美女久久久| 欧美一区二区啪啪| 欧美人与性动交cc0o| 亚洲二区视频在线| 日韩视频免费观看高清完整版| 欧美黄色片免费观看| 欧美日韩国产成人在线免费| 一区二区三区鲁丝不卡| 国产精品欧美精品| 亚洲天堂偷拍| 国产精品护士白丝一区av| 亚洲欧美中文日韩在线| 黑丝一区二区三区| 欧美激情亚洲另类| 午夜精彩视频在线观看不卡| 国产女人精品视频| 久久麻豆一区二区| 亚洲第一福利视频| 欧美日韩在线精品| 午夜精品免费在线| 伊人男人综合视频网| 美女精品在线| 亚洲欧美日韩高清| 在线观看视频亚洲| 欧美日韩亚洲免费| 久久婷婷成人综合色| 一区二区三区四区五区在线| 国产婷婷成人久久av免费高清 | 中文国产成人精品| 国产精品久久久久久久久果冻传媒 | 久久av一区| 亚洲国产导航| 国产精品日韩欧美一区二区| 免费观看在线综合| 亚洲欧美国产三级| 亚洲精品视频一区二区三区| 国产毛片精品国产一区二区三区| 免费视频亚洲| 性欧美精品高清| 99视频一区二区三区| 国产九九精品视频| 欧美日韩国产综合视频在线观看中文 | 久久精品最新地址| 亚洲欧洲精品一区二区三区波多野1战4| 欧美日韩视频一区二区三区| 久久久久久久综合| 亚洲美女视频网| 亚洲国产精品高清久久久| 欧美亚洲不卡| 欧美风情在线观看| 久久久精品国产免费观看同学| 亚洲一区三区视频在线观看| 亚洲精品久久在线| 亚洲电影在线免费观看| 国产欧美在线看| 欧美性开放视频| 欧美视频亚洲视频| 欧美日韩精品在线观看| 欧美日本免费一区二区三区| 欧美国产一区二区三区激情无套| 欧美一区二区三区的| 99re8这里有精品热视频免费| 亚洲国产一区二区三区a毛片 | 午夜精品美女久久久久av福利| 日韩视频免费在线观看| 最新高清无码专区| 日韩视频不卡中文| 一区二区三区产品免费精品久久75 | 亚洲天堂网在线观看| 亚洲精品午夜精品| 欧美人妖在线观看| 欧美日韩国产综合久久| 伊人精品久久久久7777| 亚洲国产日韩在线| 亚洲国产精品久久| 亚洲精品久久嫩草网站秘色| 国产精品永久入口久久久| 亚洲一区久久| 一区二区欧美日韩| 一二三区精品福利视频| 日韩视频中文字幕| 最新亚洲视频| 日韩视频第一页| 亚洲免费在线电影| 久久国产精品久久久久久| 久久久久88色偷偷免费| 久久久久一区二区| 欧美freesex交免费视频| 欧美国产91| 国产精品福利在线| 国产精品久久97| 狠狠色狠狠色综合日日tαg| 91久久国产自产拍夜夜嗨| 一本久久a久久精品亚洲| 一区二区三区欧美| 久久精品国产亚洲一区二区三区 | 欧美日在线观看| 欧美日韩成人综合在线一区二区| 欧美精品一卡| 国产欧美精品久久| 亚洲日本中文字幕| 性欧美18~19sex高清播放| 久久欧美中文字幕| 欧美午夜不卡在线观看免费 | 国产丝袜美腿一区二区三区| 黄色亚洲精品| 亚洲午夜在线观看视频在线| 久久裸体艺术| 国产精品久久久久久久久果冻传媒 | 国产区日韩欧美| 91久久精品视频| 亚洲一区二区伦理| 麻豆久久久9性大片| 国产精品亚洲人在线观看| 91久久精品久久国产性色也91| 亚洲欧美综合| 欧美日韩视频在线一区二区观看视频| 国产精品一二三视频| 亚洲人午夜精品| 久久久久久久久久久久久9999| 国产精品高清在线观看| 影音先锋另类| 亚洲伊人网站| 欧美色视频在线| 亚洲精品国产视频| 久久夜色精品| 在线电影一区| 欧美一区永久视频免费观看| 国产精品家教| 亚洲图片欧美日产| 欧美午夜宅男影院| 日韩视频免费大全中文字幕| 欧美福利影院| 在线看日韩欧美| 久久午夜精品| 红杏aⅴ成人免费视频| 久久久久91| 国内久久婷婷综合| 久久综合久久综合久久| 亚洲第一精品夜夜躁人人爽| 裸体女人亚洲精品一区| 亚洲国产精品一区二区尤物区 | 亚洲精品午夜| 欧美理论片在线观看| 亚洲精品中文字| 免费看黄裸体一级大秀欧美| 欧美日韩综合另类| 亚洲影院色无极综合| 国产精品久久久久久久久婷婷| 这里只有精品丝袜| 国产精品高潮呻吟久久| 亚洲一区久久久| 国内成人精品一区| 猛干欧美女孩| 日韩一级黄色片| 国产美女高潮久久白浆| 久久久噜噜噜久久久| 亚洲精品黄色| 国产精品久久久久久久久久妞妞| 欧美一级欧美一级在线播放| 国产自产在线视频一区|