国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

前端: 用Javascript實現一個轉盤小游戲?

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

[[354632]]

 本文主要介紹如何使用原生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的線性漸變,這樣本基本上可以實現一個小的扇形區域:

我們再通過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.     }) 

核心代碼就這些,怎么樣,是不是很簡單呢?如果想體驗實際案例效果和技術交流,或者感受更多原創h5游戲源碼,可以關注下方體驗哦

 

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

2021-03-30 05:58:01

JavascriptCss3轉盤小游戲

2022-03-24 07:57:58

Python水果忍者游戲

2020-12-09 11:32:10

CSS前端代碼

2023-11-29 08:10:36

javascriptH5游戲

2021-04-13 06:35:13

Elixir語言編程語言軟件開發

2021-06-25 10:38:05

JavaScript編譯器前端開發

2023-09-25 12:35:27

Python

2011-11-03 09:13:27

JavaScript

2021-01-15 12:15:36

鴻蒙HarmonyOS游戲

2021-08-15 22:52:30

前端H5拼圖

2011-10-21 09:10:12

JavaScript

2023-10-10 13:28:44

Pythonpygame

2023-07-06 20:40:57

圣誕抽抽樂H5

2022-10-21 14:21:46

JavaScript筆記技能

2021-02-05 16:03:48

JavaScript游戲學習前端

2015-06-29 11:30:07

JavaScript小烏龜推箱子

2012-01-04 13:55:23

Canvas

2013-04-08 10:54:51

Javascript

2012-09-24 11:11:32

HTML5游戲開發JavaScript

2011-03-15 13:19:11

jQuery
點贊
收藏

51CTO技術棧公眾號

亚洲一区二区免费在线| 国产亚洲精品精品国产亚洲综合| 99热这里只有精品在线播放| 香蕉av一区| 日日av拍夜夜添久久免费| 奇米亚洲欧美| 国产精品久久久久永久免费观看| 国产精品高潮呻吟| 精品丝袜一区二区三区| 欧美孕妇与黑人孕交| 天天影院图片亚洲| 成人看片爽爽爽| 亚洲美女啪啪| 亚洲一区二区成人在线观看| 成人动漫视频在线观看完整版| 国产国语**毛片高清视频| 国产麻豆一区| 成人午夜大片免费观看| 国产精品丝袜久久久久久app| 一区二区av在线| 9色视频在线观看| 欧美成人ⅴideosxxxxx| 国产视频一区在线观看一区免费| 欧美日韩美女在线| 欧美美乳视频网站在线观看| 午夜精品一区| 视频在线观看一区| 九九热精品在线| 国产视频资源| 在线精品在线| 日韩电影大片中文字幕| 三级黄色的网站| 日本不卡免费一区| 亚洲国产视频网站| 99久久精品免费看国产四区| 麻豆视频在线观看免费网站| 国产日韩一区| 久久久久亚洲精品成人网小说| 绯色av一区二区| 国内精品伊人久久久久影院对白| 欧美精品午夜视频| 中文字幕在线免费专区| 国产麻豆欧美日韩一区| 中文字幕第一区综合| 国产精品99久久久久久www | 神马伦理电影| 国产伦精品一区二区三区在线观看| av免费观看久久| 91社区在线高清| 日韩三级在线免费观看| 日韩精品一区二区三区| 欧美精品久久久久久久久| re久久精品视频| 久久亚洲高清| 成人激情av网| 好男人社区在线视频| 欧美猛男超大videosgay| 国产日韩电影| 国产精品91视频| 久久久久久9| caopor在线视频| 91国偷自产一区二区三区成为亚洲经典 | 免费h在线看| 98视频在线噜噜噜国产| 亚洲国产精品一区制服丝袜| 国产亚洲精品久久久久久久| 亚洲一区中文日韩| 中文在线最新版地址| 国产精品亚发布| 成人午夜电影小说| 超碰在线影院| 欧美极品少妇与黑人| 久久人人精品| 能在线观看av网站| 中文字幕日韩av| 欧美日韩影院| 九七影院理论片| 亚洲视频在线看| 1024成人| 激情婷婷丁香| 日韩中文字幕国产| 天堂一区二区在线| 在线观看视频污| 精品综合久久久久久97| 水蜜桃久久夜色精品一区的特点 | 国产一区二区香蕉| 99精品黄色片免费大全| 欧美r级在线| 国产精品视频在线播放| 国产亚洲短视频| 日韩在线伦理| ts人妖另类在线| √…a在线天堂一区| 日韩欧美一区二区三区免费观看| 精品无人乱码一区二区三区的优势| 亚洲欧美日韩国产综合在线| 台湾天天综合人成在线| 欧美 日韩 国产 在线观看| 欧美日本在线观看| 综合久久一区| 在线看视频你懂的| 日本亚洲欧美三级| 国产精品情趣视频| 在线精品自拍| 无码人妻丰满熟妇区五十路百度| 亚洲人a成www在线影院| 日本不卡在线视频| 精品黄色免费中文电影在线播放| 91亚洲精华国产精华| 亚洲图片自拍偷拍| 久久av资源| 国产a国产a国产a| 91产国在线观看动作片喷水| 国产午夜一区二区三区| 久久福利在线| 精品少妇在线视频| 亚洲香蕉成人av网站在线观看| 日韩电影免费在线| 超碰在线观看免费| 日韩欧美一区二区三区四区五区 | 调教视频免费在线观看| 成人免费观看网站| 欧美在线观看一二区| 午夜日本精品| 狠狠v欧美ⅴ日韩v亚洲v大胸| 国产精品一二三视频| 亚洲va国产天堂va久久en| 丝袜久久网站| 国产对白在线正在播放| 国产精品日韩精品| 欧美性xxxxx极品| 在线精品观看| 高清电影在线观看免费| 永久免费在线看片视频| 精品视频久久久久久久| 国产成人精品免费一区二区| yiren22亚洲综合| 国产成人黄色片| 午夜精品一区二区三区在线视| 亚洲丝袜美腿综合| 欧美电影免费播放| 97超碰人人在线| 日本午夜精品一区二区| 亚洲人成人99网站| 亚洲国产成人午夜在线一区| 成人看的视频| 麻豆视频在线观看免费| 成人黄色片免费| 欧美福利视频在线观看| 一区二区三区不卡视频在线观看| 一个色综合网| 菠萝蜜视频国产在线播放| 91九色国产ts另类人妖| 欧美裸身视频免费观看| 亚洲老司机在线| 国产精品日本欧美一区二区三区| 色a资源在线| 日韩少妇内射免费播放18禁裸乳| 性色av一区二区三区| 色域天天综合网| 国产专区综合网| 久草精品视频| 999在线视频| 国产妇女馒头高清泬20p多| 欧美怡春院一区二区三区| 欧美性videos高清精品| 久久黄色级2电影| 99久久婷婷国产综合精品青牛牛 | 夜夜操天天操亚洲| 午夜亚洲性色视频| 北岛玲精品视频在线观看| 一二三中文字幕在线| 在线视频91| 国产成人精品久久亚洲高清不卡| 欧美一区二区精美| 国产日产欧产精品推荐色 | 91精品国产自产在线老师啪| 亚洲精品一区二区三区蜜桃下载| 久久久精品日韩欧美| 精品69视频一区二区三区Q| 国产精品麻豆成人av电影艾秋| 超碰96在线| 97碰在线视频| av一区二区在线看| 欧美乱妇40p| 欧美一卡二卡在线| 亚洲欧美在线另类| 蜜臀av一区二区三区| 激情综合网站| 日韩久久一区二区三区| 亚洲成人影院在线观看| 六月婷婷在线视频| 国产午夜精品一区| 欧美激情免费在线| 精品国产一区二区三区av性色 | 成人满18在线观看网站免费| 日韩国产高清一区| 国产精品你懂得| 不卡av在线网站| 欧美大片顶级少妇|