精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

亚洲aⅴ怡春院| 国产一区视频导航| 亚洲三级 欧美三级| 成年人在线观看视频免费| 大片免费播放在线视频| 国产一区激情在线| 91精品国产91久久久久福利| 国产精品亚洲无码| 亚洲欧美在线综合| 香蕉加勒比综合久久| 欧美精品一区二区三区四区五区| 亚洲一区二区影视| 亚洲三级色网| 久久精品国产免费观看| 波多野结衣影院| 欧美天堂在线| 精品国产91久久久| 黄色www在线观看| 美女欧美视频在线观看免费| 国产一区二区福利视频| 69av在线视频| 国产成人无码aa精品一区| 九色精品91| 日韩欧美成人午夜| 欧美伦理视频在线观看| 成人影音在线| 自拍偷拍亚洲综合| 久久综合中文色婷婷| 国产xxxxxx| 久草在线在线精品观看| 2025国产精品视频| 久久久99精品| 香蕉久久网站| 中文字幕久久久av一区| www.88av| 哺乳挤奶一区二区三区免费看| 在线播放91灌醉迷j高跟美女 | 国内精品视频在线观看| 日韩免费一区二区| 国产无色aaa| 日韩av免费| 色综合久久中文字幕| 老太脱裤子让老头玩xxxxx| 国产在线观看a视频| 中文字幕乱码久久午夜不卡| 欧美久久久久久久| 日韩av资源站| 26uuu亚洲| 精品欧美一区二区三区久久久| 成人av无码一区二区三区| 国产最新精品免费| 91视频九色网站| 国产精品免费无遮挡| 美女脱光内衣内裤视频久久网站| 国产精品 欧美在线| 国产www在线| 国产精品日韩| 欧美亚洲国产另类| 日本中文字幕久久| 老**午夜毛片一区二区三区 | 国产一区二区99| 亚洲精选在线| 性欧美在线看片a免费观看| 国产系列精品av| 在线综合亚洲| 国产91色在线|免| 秋霞av一区二区三区| 日韩国产欧美在线观看| 国产精品第一视频| 92久久精品一区二区| 精品亚洲国产成人av制服丝袜| 成人观看高清在线观看免费| 国产美女三级无套内谢| 国产成人午夜片在线观看高清观看| 99久久精品免费看国产四区| 亚洲免费成人在线| 99精品视频一区| 欧美日韩在线观看一区二区三区| 成人亚洲综合天堂| 亚洲天堂成人在线观看| 福利视频免费在线观看| 自拍一区在线观看| 欧美亚洲国产一区在线观看网站| 91精品999| **爰片久久毛片| 亚洲女人被黑人巨大进入al| 日韩av片在线| 国产精品mm| 青青在线视频一区二区三区| 在线播放国产一区| 成人中文字幕在线| 欧美成人一区二区在线| 男女啪啪在线观看| 午夜av电影一区| 亚洲国产成人va在线观看麻豆| 日韩视频一区二区三区四区| 精品视频在线观看日韩| 国产黄a三级三级| 伊人久久大香线蕉综合热线| 国产精品xxxxx| 99久久精品国产成人一区二区| 成人动漫视频在线| 亚洲成人自拍| а√天堂中文在线资源8| 91久久国产综合久久| 亚洲一区二区三区四区精品| 亚洲尤物av| 久久在线视频在线| 国产免费一区二区三区四区五区| 国产一区二区在线看| 国产专区一区二区| 大地资源网3页在线观看| 欧美视频不卡中文| 精品人妻一区二区三| 中文字幕亚洲影视| 欧美精品18videos性欧| 亚洲天堂自拍偷拍| 久久久蜜桃精品| 精品视频在线观看一区二区| 99九九久久| 日韩电影中文字幕av| 爱爱视频免费在线观看| 日韩影院在线观看| 精品蜜桃一区二区三区| а√中文在线8| 欧美色倩网站大全免费| 亚洲一区二区三区综合| 综合久久久久| 91精品国产自产在线| 国产小视频在线观看| 午夜日韩在线电影| 乱码一区二区三区| 自产国语精品视频| 91久久久在线| 永久免费在线观看视频| 91传媒视频在线播放| aaaaaav| 99在线精品视频在线观看| 99re国产视频| av网站在线看| 欧美一区二区三区视频在线 | 91网址在线观看精品| 青草国产精品| 国产精品欧美风情| 成人福利在线| 欧美在线视频不卡| 国产又粗又猛又爽又黄av| 久久精品人人| 欧洲亚洲一区二区三区四区五区| 丝袜老师在线| 亚洲欧洲一区二区三区在线观看| 日韩特级黄色片| 91蝌蚪porny| 久草综合在线观看| 精品黄色一级片| 国产欧美日韩免费| 免费观看在线黄色网| 制服视频三区第一页精品| 亚洲少妇xxx| 国产一区二区三区久久久 | 色一情一伦一子一伦一区| 9.1成人看片| 天堂va蜜桃一区二区三区漫画版| 欧美日韩高清在线一区| 欧美日韩视频免费观看| 中文字幕在线成人| 国产精品无码久久av| 亚洲嫩草精品久久| 99热超碰在线| 久久久国产精品一区二区中文| 日韩欧美一区二区在线观看 | 久久久久久九九九九九| 日本大胆欧美人术艺术动态| 亚洲一区二区不卡视频| 精品视频一区二区三区| 久久久久成人精品| 你懂的在线网址| 欧美吞精做爰啪啪高潮| 91视频综合网| 久久免费美女视频| 天天综合网久久| 亚洲午夜在线| 青青草原亚洲| 麻豆视频久久| 欧美亚洲另类激情另类| 日韩伦理在线电影| 欧美精品一区二| 亚洲AV无码成人精品区东京热| 国产精品网站在线| 久久久久无码精品| 天堂va蜜桃一区二区三区漫画版 | 精品自拍一区| 日韩大陆欧美高清视频区| 中文字幕激情视频| 亚洲国产精品自拍| 亚洲天堂精品一区| 成人激情小说网站| 色综合色综合色综合色综合| 在线精品一区| 一区二区不卡视频| 欧美综合精品| 亚洲综合自拍一区| 亚洲mmav| 国内精品免费午夜毛片| 天堂资源在线中文| 日韩精品中文字幕久久臀| 国产三级小视频| 色婷婷精品久久二区二区蜜臂av | 中文字幕免费在线播放| 久久精品国产99国产精品| 国产不卡一区二区视频| 国产精品国产三级国产在线观看| 久草精品电影| 精品中文在线| 国产免费成人av| 亚洲国产福利| 97精品国产97久久久久久| 在线观看美女网站大全免费| 日韩久久免费视频| 亚洲国产精品二区| 91麻豆精品91久久久久久清纯 | 一色道久久88加勒比一| 成人免费va视频| 网站在线你懂的| 奇米影视在线99精品| 日韩视频第二页| 激情自拍一区| www.成年人视频| 欧美大片专区| 日本精品免费视频| 91麻豆精品国产91久久久平台| 欧美一级二级三级九九九| 菁菁伊人国产精品| 国产精品自拍首页| 亚洲伊人影院| 成人黄动漫网站免费| 日韩精品一区二区三区中文在线| 国产日韩在线看片| 欧美91在线|欧美| 国产精品视频色| jizz内谢中国亚洲jizz| 欧美一级淫片播放口| yellow字幕网在线| 69久久夜色精品国产69乱青草| 日本动漫理论片在线观看网站 | 欧美gv在线观看| 97人人爽人人喊人人模波多| 99爱在线视频| 97超级碰在线看视频免费在线看| 爱情岛亚洲播放路线| 久久久久久久网站| 国产一二在线播放| 日本久久亚洲电影| 成人自拍视频网| 国产日韩精品在线播放| 一区二区三区| 99久久伊人精品影院| 亚洲精品一二三**| 国产午夜精品在线| 色橹橹欧美在线观看视频高清 | 男人的天堂在线免费视频| 亚洲精品日韩欧美| 国产高清视频在线观看| 色七七影院综合| 亚洲小说区图片区都市| 欧美精品激情视频| 日韩伦理在线| 国产精品久久久久久久久久| 欧美v亚洲v综合v国产v仙踪林| 成人性生交大片免费看视频直播| 秋霞影院一区| 久久久久久精| 久久看人人摘| www.亚洲成人网| 性欧美xxxx大乳国产app| 国产免费视频传媒| 国产综合一区二区| 中文字幕乱视频| 国产亚洲一区字幕| 丝袜 亚洲 另类 欧美 重口| 亚洲.国产.中文慕字在线| 中文字幕av第一页| 日韩视频免费观看高清在线视频| 天堂av资源在线| 色老头一区二区三区| 另类视频在线| 国产成人精品免费久久久久| 成人av在线播放| 久久久7777| 小小影院久久| 日本精品www| 国产精品一品二品| 久久久久久久久久久国产精品| 中文字幕在线一区免费| 91久久国产视频| 欧美日韩情趣电影| 天天综合在线视频| 久久综合久久八八| 亚洲午夜天堂| 91香蕉视频在线下载| 国产欧美日韩| 久久av综合网| 黑人巨大精品欧美一区| 久久丫精品国产亚洲av不卡| 亚洲六月丁香色婷婷综合久久 | 久久亚洲风情| 娇妻高潮浓精白浆xxⅹ| 国产精品久久久久久久午夜片| 久草精品视频在线观看| 在线观看91av| 国产精品一级伦理| 国产综合在线视频| 国产精品一区免费在线| 日日夜夜精品网站| 国产欧美日本| 女教师高潮黄又色视频| 国产女人aaa级久久久级| 国产午夜免费视频| 欧美一区二区三区在| 国产三级在线观看| 欧美一区二区三区免费视| 亚洲日本va| 9l视频自拍9l视频自拍| 美女mm1313爽爽久久久蜜臀| 性久久久久久久久久| 亚洲国产wwwccc36天堂| 国产精品无码免费播放| 中国日韩欧美久久久久久久久| 乡村艳史在线观看| 国产精品亚洲不卡a| 一区二区不卡| 青青草久久伊人| 国产精品久久久久久久久免费樱桃| 日韩中文字幕在线观看视频| 亚洲精品一区二区三区精华液| 在线免费av导航| 亚洲一区美女视频在线观看免费| 日韩片欧美片| 欧美日韩中文不卡| 国产精品传媒入口麻豆| 在线免费一级片| 色系列之999| 国产成人精品一区二区三区在线| 日韩av电影在线观看| 久久久久综合| 三年中国中文观看免费播放| 色婷婷亚洲综合| 国产高清在线看| 国产精品自产拍在线观看| 色婷婷亚洲mv天堂mv在影片| 午夜久久久精品| 国产精品久久99| 国产又粗又黄又爽视频| 久热精品视频在线观看| 久久丁香四色| 91黄色在线看| 久久综合久久鬼色| 精品无码一区二区三区的天堂| 亚洲视频自拍偷拍| 国精品产品一区| 中文字幕精品在线播放| 国产成人免费av在线| 国产午夜精品一区二区理论影院| 日韩电视剧免费观看网站| 中文日产幕无线码一区二区| 日韩欧美三级一区二区| 久久精品国产亚洲高清剧情介绍| a在线视频播放观看免费观看| 精品国偷自产国产一区| 色偷偷偷在线视频播放| 日韩电影在线播放| 国产精品资源网站| 日韩免费观看一区二区| 亚洲视频axxx| 日韩精品免费视频一区二区三区| 无码专区aaaaaa免费视频| 国产偷国产偷亚洲高清人白洁| 一级特黄aaa大片| 欧美激情国内偷拍| 国产精品一在线观看| 粉色视频免费看| 亚洲成人综合视频| 北岛玲一区二区三区| 91色视频在线导航| 国产一级久久| 欧日韩不卡视频| 亚洲第一中文字幕在线观看| sis001欧美| 亚洲成年人专区| 久久综合九色综合欧美亚洲| 一本色道久久综合亚洲| 久久免费精品日本久久中文字幕| 国产乱码精品一区二区亚洲 | 亚洲三级电影| 成人观看免费完整观看| 亚洲欧洲精品一区二区三区不卡| 少妇人妻精品一区二区三区| 国产欧美一区二区三区久久| 99精品久久| 萌白酱视频在线|