精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

使用Javascript和CSS3實現一個轉盤小游戲(實戰篇)

開發 前端
本文技術路線采用和上篇文章教你用200行代碼寫一個愛豆拼拼樂H5小游戲(附源碼)同樣的技術,即均使用本人自己寫的dom庫去簡化dom操作,具體需要掌握的知識點如下。

本文主要介紹如何使用原生javascript和Css3來實現一個在各大移動應用中經常出現的轉盤游戲,由于改實現可以有不同方式,如果熟悉canvas的話也可以用canvas實現,本文采用js和css實現主要考慮到復雜度較小性能較好,所以如果有更好的方案,也可以隨時和我交流。

前言

本文技術路線采用和上篇文章教你用200行代碼寫一個愛豆拼拼樂H5小游戲(附源碼)同樣的技術,即均使用本人自己寫的dom庫去簡化dom操作,具體需要掌握的知識點有:

  • css3 背景漸變,transform,transition
  • less循環的使用
  • javascript基本隨機算法
  • 文檔片段 documentFragment的使用

由于文章沒有太高深的技術,關鍵是思路,所以接下來開始我們的實現介紹。

效果圖

 å›¾ç‰‡

實現思路

實現思路分兩部分,第一部分是用css繪制轉盤背景,第二部分是通過js實現轉盤的轉動以及轉動隨機性的實現。

1. 繪制轉盤背景

我們采用背景漸變的方式去實現條紋交替的扇形,原理就是通過繪制一個半圓,并在半圓里加漸變來實現,如下圖:

實現將方形變成半圓的css我們通過border-radius來實現:

  1. width: 150px; 
  2. height: 300px; 
  3. border-radius: 0 150px 150px 0; 

我們再通過css的線性漸變,這樣本基本上可以實現一個小的扇形區域:

漸變的代碼如下:

  1. background-image: linear-gradient(120deg, #f6d365, #f6d365 75px, transparent 75px); 

實現了一個扇形,我們自然可以通過計算,比如我們扇形弧度為30deg,那么我們需要12個扇形即可組成一個圓,為了方便,我們使用less的循環來實現:

  1. .loop(@n) when (@n >= 0) { 
  2.     .loop(@n - 1); 
  3.     .piece-@{n} { 
  4.         transform: rotate(-30deg * (@n + 1)); 
  5.     }  

還有一個細節是,我們需要改變變換的中心點,讓每個扇形都以一個中心點渲染,這樣才可以組成一個完整的圓:

  1. transform-origin: left center; 

完整的css大致如下:

  1. .piece-wrap { 
  2.     position: relative
  3.     width: 300px; 
  4.     height: 300px; 
  5.     margin: 100px auto  auto 173px; 
  6.     transform-origin: left center; 
  7.     transition: transform 16s cubic-bezier(0,.47,.31,1.03); 
  8.     .piece { 
  9.         position: absolute
  10.         left: 0; 
  11.         top: 0; 
  12.         width: 150px; 
  13.         height: 300px; 
  14.         border-radius: 0 150px 150px 0; 
  15.         transform-origin: left center; 
  16.         span { 
  17.             margin-left: 16px; 
  18.             margin-top: 20px; 
  19.             display: inline-block; 
  20.             color: #fff; 
  21.         } 
  22.         &:nth-child(2n) { 
  23.             background-image: linear-gradient(120deg, #f6d365, #f6d365 75px, transparent 75px); 
  24.         } 
  25.         &:nth-child(2n+1) { 
  26.             background-image: linear-gradient(120deg, #ff5858, #ff5858 75px, transparent 75px); 
  27.         } 
  28.     } 
  29.  
  30.     .loop(@n) when (@n >= 0) { 
  31.         .loop(@n - 1); 
  32.         .piece-@{n} { 
  33.             transform: rotate(-30deg * (@n + 1)); 
  34.         }  
  35.     } 
  36.  
  37.     .loop(11); 

2.javascript實現轉盤邏輯

由于轉盤的轉動是隨機的,所以我們需要每次點擊開始按鈕都要隨機生成一個角度,但是仔細分析一些平臺會發現轉盤每次都至少轉動n圈后才會滿滿開始停下,所以我們會給轉盤一個初始的角度,比如720deg,1080deg,這樣能保證轉盤至少轉動n圈才停下來。

另一個注意點是我們要如何通過轉動角度知道轉盤停下來后的位置?這里處于性能問題,我們盡量不操作dom,通過數據控制,我們可以通過每次隨機后得到的角度和單位扇形區域的弧度來計算停下來的位置,公式如下:

totalRadis = initRadis + radis * n + radis/2totalRadis為轉動的角度,

initRadis為初始化角度,radis為扇形的角度,radis/2是中獎的范圍,這里主要用來定位用的,n是隨機數,接下來我將解釋n的作用。

那么怎么實現隨機角度呢?我們一般會想通過寫個隨機函數去做,不過這里有一種新的思路,就是通過隨機生成中獎的位置來實現隨機角度,由于我的扇形為30度,一共有12個扇形獎品區,所以索引為0-11。因此,上面講到的n,就是我們的隨機索引,我們只需要寫個生成指定范圍的隨機數就可以了。

了解了以上知識,我們開始準備初始化數據:

  1. // 轉盤抽獎數據 
  2.     var wards = ['1元''2元''3元''5元''再來',  
  3.      '算法''0.5元''0.1元''0.2元''0.6元'
  4.      '0.5元''來']; 

渲染獎品數據,這里我們用了DocumentFragment,雖然對簡單渲染沒有必要,但是后期可能會很有用:

  1. // 渲染dom 
  2. var fragment = document.createDocumentFragment(); 
  3. for(var i=0, len = wards.length; i < len; i++) { 
  4.     var piece = document.createElement('div'); 
  5.     piece.className = 'piece piece-' + i; 
  6.     piece.innerHTML = '<span>' + wards[i] + '</span>'
  7.     fragment.appendChild(piece); 
  8.  
  9. $('#piece_wrap')[0].appendChild(fragment); 

生成指定范圍的隨機數的方法:

  1. // 生成從 start到end的隨機數 
  2. function randomArr(start, end) { 
  3.     return Math.round(start + Math.random()* (end - start)) 

當我們點擊開始按鈕時,我將通過改變轉盤的transform來讓其運動起來:

  1. // 轉動邏輯 
  2.     var radis = 30,  // 每個扇形區域的度數 
  3.             n = randomArr(0, 360/radis),  // 計算隨機中獎的位置 
  4.     initRadis = 720,   // 初始轉動的角度 
  5.          time = 16 * 1000,    // 轉動時間  
  6.          once = true,    // 限制一個轉動周期只能點擊一次 
  7.    totalRadis = initRadis + radis * n + radis/2;  // 轉動角度計算公式 
  8. $('.start').on('click'function(){ 
  9.     if(once) { 
  10.         once = false
  11.         $('#piece_wrap').css({ 
  12.             'transform':'rotate(' + totalRadis + 'deg)'
  13.             'transition''transform 16s cubic-bezier(0,.47,.31,1.03)' 
  14.         }); 
  15.         setTimeout(function(){ 
  16.             once = true
  17.             alert('恭喜你抽中了' + wards[n] + '!'); 
  18.             $('#piece_wrap').css({ 
  19.                 'transform':'rotate(' + 0 + 'deg)'
  20.                 'transition''none' 
  21.             }); 
  22.         }, time
  23.     } 
  24.          
  25.     }) 

核心代碼就這些,怎么樣,是不是很簡單呢?

 

責任編輯:姜華 來源: 趣談前端
相關推薦

2020-11-30 06:20:13

javascript

2015-05-27 07:44:34

日歷控件 jQueryCSS3

2017-05-11 15:20:52

CSS3動畫前端

2021-04-13 06:35:13

Elixir語言編程語言軟件開發

2015-04-23 15:40:59

CSS3叮當貓

2020-12-09 11:32:10

CSS前端代碼

2012-01-04 13:55:23

Canvas

2012-05-27 18:28:46

jQuery Mobi

2021-09-08 22:28:13

前端Css3動畫

2012-06-21 14:20:16

CSS3

2014-04-29 10:39:27

CSS3JavaScript

2021-08-15 22:52:30

前端H5拼圖

2012-02-24 09:11:45

jQuery

2022-02-20 14:45:33

3D動畫CSS3前端

2013-01-30 15:59:29

adobeCSS3HTML5

2022-03-24 07:57:58

Python水果忍者游戲

2012-05-30 09:22:56

Hybrid App助HTML5JavaScript

2021-06-09 08:30:52

CSS33D旋轉視圖3D動畫

2021-01-15 18:37:49

CSS3Filters視覺

2023-09-25 12:35:27

Python
點贊
收藏

51CTO技術棧公眾號

久久精品国产99久久6| 网站一区二区| 国产精品欧美久久久久一区二区| 国产啪精品视频| 黄色片在线观看网站| 亚洲不卡在线| 91黄色小视频| 黄色影视在线观看| 手机福利在线| 日韩电影免费在线看| 理论片在线不卡免费观看| 波多野结衣办公室双飞 | 日韩专区在线观看| 国产精品无码自拍| gogo亚洲高清大胆美女人体| 亚洲男人天堂av网| 日本精品一区二区| 亚洲精品911| 奇米综合一区二区三区精品视频| 欧美丰满少妇xxxxx| 无码国产69精品久久久久同性| 九色精品蝌蚪| 欧美性猛交xxxxxxxx| 日本中文字幕在线视频观看| av电影在线播放高清免费观看| 成人做爰69片免费看网站| 国产精品国产三级国产专播精品人| www.99re7| 日韩欧美高清| 亚洲精品日韩在线| 精品久久久久久无码人妻| 欧美一级做一级爱a做片性| 欧美日韩一区二区在线播放| 少妇大叫太大太粗太爽了a片小说| 9191在线| 久久精品亚洲乱码伦伦中文 | 国产精品国产馆在线真实露脸| 精品国产日本| 欧美一区深夜视频| 一区二区三区少妇| 榴莲视频成人app| 欧美视频日韩视频在线观看| 好吊妞无缓冲视频观看| 牛牛精品在线视频| 亚洲天堂av一区| 天堂精品一区二区三区| 男人的天堂在线| 99国产欧美另类久久久精品 | 一区二区三区自拍视频| 这里只有精品电影| 欧美特黄aaa| 91精品国产66| 欧美日韩情趣电影| 91热这里只有精品| 九九热线视频只有这里最精品| 精品久久中文字幕久久av| 僵尸世界大战2 在线播放| 人人澡人人添人人爽一区二区| 亚洲欧美日韩一区二区| 麻豆md0077饥渴少妇| 麻豆视频在线观看免费网站| 中文字幕亚洲电影| 青少年xxxxx性开放hg| 含羞草www国产在线视频| 亚洲天堂成人| av一区二区不卡| 97夜夜澡人人双人人人喊| 国产视频一区二区三| 另类人妖一区二区av| 国产在线999| 99久久久国产精品无码网爆| 国产乱人伦偷精品视频不卡| www.久久久| 日韩中文字幕免费观看| 91天堂素人约啪| 天堂av一区二区| 国产最新在线| 亚洲成av人影院在线观看网| 每日在线观看av| 三级成人黄色影院| 精品视频免费看| 亚洲一级片免费观看| a看欧美黄色女同性恋| 日韩高清av一区二区三区| 美女脱光内衣内裤| 国产韩日影视精品| 欧美极品美女电影一区| 国产一区二区99| 美女在线观看视频一区二区| 91入口在线观看| 亚洲色图另类小说| 亚洲国产高清在线| 一二三在线视频| 亚洲少妇视频| 91精品国产91久久久久久一区二区 | 在线观看一区视频| 欧美在线一级视频| 国产精品系列视频| 99re热这里只有精品免费视频| 亚洲国产一区在线| 国产丝袜视频在线播放| 在线看国产日韩| 三上悠亚 电影| 国产成人精品三级高清久久91| 久久精品亚洲一区| 伊人手机在线视频| 国产剧情一区二区三区| 欧美午夜欧美| 久久香蕉av| 欧美日韩视频一区二区| 国产毛片毛片毛片毛片毛片毛片| 91嫩草亚洲精品| 欧美有码在线观看视频| 国产成人精品亚洲精品色欲| 久久久久一区二区三区四区| 亚洲乱码日产精品bd在线观看| 向日葵视频成人app网址| 欧美精品一区男女天堂| 男女性高潮免费网站| 日韩经典一区二区| 国偷自产av一区二区三区小尤奈| v片在线观看| 在线日韩一区二区| 少妇激情一区二区三区视频| 一级欧洲+日本+国产| 国产精品69久久| www.蜜臀av.com| 中文字幕日韩精品一区| 在线免费观看视频黄| 久久大胆人体视频| 欧美男插女视频| 国产精品久久久久久久久久久久久久久久久久 | 欧美成免费一区二区视频| 欧美亚洲国产视频| 国 产 黄 色 大 片| 亚洲精品国产无天堂网2021| 亚洲最大天堂网| 精品国产一区二区三区四区| 538国产精品一区二区免费视频| 午夜美女福利视频| 亚洲女厕所小便bbb| 天天干天天玩天天操| 国产videos久久| 日本三级韩国三级久久| 青青操视频在线| 欧美日韩国产一中文字不卡 | 久久婷婷久久一区二区三区| 久久这里只有精品18| 亚洲电影一区| 久久91精品国产| www.爱爱.com| 亚洲综合一二区| 免费不卡av网站| 午夜视频一区| 国产九色精品| 涩涩涩视频在线观看| 国产偷亚洲偷欧美偷精品| 日日夜夜狠狠操| 国产丝袜在线精品| 日韩一区二区三区不卡视频| 久久国产成人午夜av影院宅| 成人a在线视频| 老司机精品影院| 日韩亚洲电影在线| 黄网站免费在线| av成人免费在线| 四虎永久在线精品无码视频| 妖精视频一区二区三区免费观看| 热门国产精品亚洲第一区在线| 黄色片视频在线观看| 在线一区二区三区四区五区| 日本美女xxx| 国模娜娜一区二区三区| 日本大片免费看| 中文字幕亚洲影视| 国产欧美韩国高清| 四虎av在线| 日韩av资源在线播放| 久久久久久无码精品大片| 国产精品久久久一本精品 | 不卡一区中文字幕| 欧美重口乱码一区二区| 福利一区视频| 欧美激情xxxx| 青青操在线视频| 欧美日韩国产综合一区二区| 国产精品久久久久久久精| 成人一二三区视频| 国产精品久久久久9999小说| 羞羞答答成人影院www| 国产自产在线视频一区| 神马久久资源| 九九视频这里只有精品| 欧美一区二区少妇| 在线电影国产精品| 国产女同在线观看| 国产精品久久久久久久久免费丝袜 | 国产福利在线导航| 国产不卡视频一区二区三区| 日韩网址在线观看| 亚洲a一区二区三区| 久久精品国产理论片免费| 日韩一级特黄| 欧美在线观看网址综合| 免费在线观看av网站| 日韩成人av在线播放| 国产一区二区三区四区视频| 精品毛片网大全| 精品国产精品国产精品| 久久色.com| www.四虎精品| 麻豆精品视频在线观看| 男女激情无遮挡| 911精品美国片911久久久| 欧美精品二区三区四区免费看视频| 日韩精品一级| 国产日韩欧美另类| 欧美艳星kaydenkross| 欧美极品少妇xxxxⅹ免费视频| 永久免费在线观看视频| 国产视频精品久久久| www.av在线.com| 欧美另类久久久品| 久久人人爽人人爽人人片av免费| 亚洲va欧美va人人爽| 午夜爽爽爽男女免费观看| 久久久久九九视频| 国产老熟女伦老熟妇露脸| 国产精品18久久久久久久久| 在线看的黄色网址| 肉丝袜脚交视频一区二区| 91免费黄视频| 亚洲国产国产亚洲一二三| 日本女人高潮视频| 99久久夜色精品国产亚洲狼| 性欧美精品一区二区三区在线播放| 里番精品3d一二三区| 国产精品日韩二区| 99久久香蕉| 99精品欧美一区二区三区| 成人51免费| 成人国产在线视频| 4438五月综合| 国产这里只有精品| 伊人久久精品| 91老司机精品视频| 国产高清亚洲| 91成人在线看| 成人av综合网| 精品国产免费一区二区三区| 天天躁日日躁狠狠躁欧美巨大小说| 国产精品国产三级国产专区53| av不卡一区二区| 精品91免费| 妖精视频一区二区三区| 青青草国产精品| 成人av二区| 小说区视频区图片区| 综合国产精品| 人妻夜夜添夜夜无码av| 国产亚洲精品bv在线观看| 国产精品亚洲αv天堂无码| 日韩中文字幕av电影| 少妇一级淫免费放| 国产在线精品一区在线观看麻豆| www.色.com| 在线观看免费网站黄| 亚洲一级二级三级在线免费观看| 免费一级特黄特色大片| 精品久久中文字幕| 欧美人一级淫片a免费播放| 欧美人伦禁忌dvd放荡欲情| 国产成人精品免费看视频| 亚洲成av人乱码色午夜| 青梅竹马是消防员在线| www.亚洲免费视频| 污片在线免费观看| 69av在线播放| 精品九九久久| 成人在线观看av| 欧美极品在线观看| 一区二区三区四区视频在线| 国内揄拍国内精品久久| 99爱视频在线| 精品亚洲成a人在线观看| 一级黄色大片免费看| 久久久久久久免费视频了| 国产精品视频在| 亚洲国产一区二区在线播放| chinese国产精品| 91精品欧美一区二区三区综合在 | 伊人久久综合视频| 欧美日韩精品三区| 狠狠躁日日躁夜夜躁av| 亚洲一区二区福利| 色呦呦呦在线观看| 国产成人精品免费久久久久| 精品三级国产| 日本一区视频在线播放| 午夜亚洲福利| 99视频在线免费| 成人高清免费观看| 日韩一卡二卡在线观看| 偷拍日韩校园综合在线| 国产麻豆免费视频| 日韩高清中文字幕| 中文字幕在线观看播放| 国产精品黄色av| 国产精品丝袜在线播放| 中文字幕欧美日韩一区二区| 亚洲巨乳在线| 深夜视频在线观看| 国产精品女主播在线观看| 国产一级精品视频| 欧美一级电影网站| 日本最新在线视频| 日韩免费观看网站| 欧美激情网址| 精品免费久久久久久久| 久久99精品一区二区三区三区| 中文字幕网站在线观看| 午夜精品久久久久久久| www.天堂av.com| 日韩中文字幕在线视频播放| av免费在线一区| 蜜桃91精品入口| 亚洲国产美女| 久久久无码人妻精品无码| 亚洲天天做日日做天天谢日日欢| 日韩精选在线观看| 精品一区二区三区三区| 久久青草伊人| 国产精品国产一区二区| 午夜精品毛片| 中文字幕资源在线观看| 中文字幕精品一区二区精品绿巨人 | 春暖花开成人亚洲区| 全亚洲最色的网站在线观看| 日本欧美高清| 国产精品免费入口| 99久久99久久精品免费看蜜桃| 日本少妇做爰全过程毛片| 欧美videossexotv100| 1区2区在线观看| 亚洲自拍另类欧美丝袜| 欧美一区不卡| 亚洲国产综合av| 一区二区三区中文字幕| 国内精品偷拍视频| 欧美黄色性视频| 国产精品美女在线观看直播| 国产九九九九九| 99精品视频免费在线观看| 男女啊啊啊视频| 亚洲欧美变态国产另类| 欧美一级大片| 亚洲午夜久久久影院伊人| 久久99久国产精品黄毛片色诱| 少妇被躁爽到高潮无码文| 5858s免费视频成人| huan性巨大欧美| 国产精品三区在线| 亚洲资源av| 手机免费观看av| 91精品国产综合久久精品麻豆 | 欧美美女一区| 在线免费av播放| 亚洲欧美激情小说另类| 丰满人妻妇伦又伦精品国产| 91爱爱小视频k| 精品视频97| 亚洲AV无码久久精品国产一区| 亚洲国产精品麻豆| 国产亚洲依依| 成人网在线免费看| 国内精品福利| 亚洲色成人网站www永久四虎| 欧美日韩国产影片| 后进极品白嫩翘臀在线播放| 精品国产乱码久久久久久郑州公司 | 99精品在线看| 91av在线免费观看| 色135综合网| 成年人小视频在线观看| 色综合久久久网| 成人日日夜夜| 免费在线国产精品| 黄色资源网久久资源365| 国产午夜精品无码| 最近2019年日本中文免费字幕| 视频精品一区| 青青在线视频观看| 亚洲免费在线看| 飘雪影视在线观看免费观看 | 国产在线拍揄自揄拍无码| 国产成人av电影在线观看| 成人免费毛片男人用品| 久久最新资源网| 夜夜春成人影院| 亚洲区 欧美区|