千家信息网

如何使用Javascript和CSS3实现一个转盘小游戏

发表于:2025-11-17 作者:千家信息网编辑
千家信息网最后更新 2025年11月17日,这篇文章主要介绍了如何使用Javascript和CSS3实现一个转盘小游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。具体需要掌握的
千家信息网最后更新 2025年11月17日如何使用Javascript和CSS3实现一个转盘小游戏

这篇文章主要介绍了如何使用Javascript和CSS3实现一个转盘小游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

具体需要掌握的知识点有:

  • css3 背景渐变,transform,transition

  • less循环的使用

  • javascript基本随机算法

  • 文档片段 documentFragment的使用

由于文章没有太高深的技术,关键是思路,所以接下来开始我们的实现介绍。

效果图

实现思路

实现思路分两部分,第一部分是用css绘制转盘背景,第二部分是通过js实现转盘的转动以及转动随机性的实现。

1. 绘制转盘背景

我们采用背景渐变的方式去实现条纹交替的扇形,原理就是通过绘制一个半圆,并在半圆里加渐变来实现,如下图:

实现将方形变成半圆的css我们通过border-radius来实现:

width: 150px; height: 300px; border-radius: 0 150px 150px 0;

我们再通过css的线性渐变,这样本基本上可以实现一个小的扇形区域:

渐变的代码如下:

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

实现了一个扇形,我们自然可以通过计算,比如我们扇形弧度为30deg,那么我们需要12个扇形即可组成一个圆,为了方便,我们使用less的循环来实现:

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

还有一个细节是,我们需要改变变换的中心点,让每个扇形都以一个中心点渲染,这样才可以组成一个完整的圆:

transform-origin: left center;

完整的css大致如下:

.piece-wrap {     position: relative;     width: 300px;     height: 300px;     margin: 100px auto  auto 173px;     transform-origin: left center;     transition: transform 16s cubic-bezier(0,.47,.31,1.03);     .piece {         position: absolute;         left: 0;         top: 0;         width: 150px;         height: 300px;         border-radius: 0 150px 150px 0;         transform-origin: left center;         span {             margin-left: 16px;             margin-top: 20px;             display: inline-block;             color: #fff;         }         &:nth-child(2n) {             background-image: linear-gradient(120deg, #f6d365, #f6d365 75px, transparent 75px);         }         &:nth-child(2n+1) {             background-image: linear-gradient(120deg, #ff5858, #ff5858 75px, transparent 75px);         }     }      .loop(@n) when (@n >= 0) {         .loop(@n - 1);         .piece-@{n} {             transform: rotate(-30deg * (@n + 1));         }      }      .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,就是我们的随机索引,我们只需要写个生成指定范围的随机数就可以了。

了解了以上知识,我们开始准备初始化数据:

// 转盘抽奖数据     var wards = ['1元', '2元', '3元', '5元', '再来',       '算法', '0.5元', '0.1元', '0.2元', '0.6元',      '0.5元', '来'];

渲染奖品数据,这里我们用了DocumentFragment,虽然对简单渲染没有必要,但是后期可能会很有用:

// 渲染dom var fragment = document.createDocumentFragment(); for(var i=0, len = wards.length; i < len; i++) {     var piece = document.createElement('div');     piece.className = 'piece piece-' + i;     piece[xss_clean] = '' + wards[i] + '';     fragment.appendChild(piece); }  $('#piece_wrap')[0].appendChild(fragment);

生成指定范围的随机数的方法:

// 生成从 start到end的随机数 function randomArr(start, end) {     return Math.round(start + Math.random()* (end - start)) }

当我们点击开始按钮时,我将通过改变转盘的transform来让其运动起来:

// 转动逻辑     var radis = 30,  // 每个扇形区域的度数             n = randomArr(0, 360/radis),  // 计算随机中奖的位置     initRadis = 720,   // 初始转动的角度          time = 16 * 1000,    // 转动时间           once = true,    // 限制一个转动周期只能点击一次    totalRadis = initRadis + radis * n + radis/2;  // 转动角度计算公式 $('.start').on('click', function(){     if(once) {         once = false;         $('#piece_wrap').css({             'transform':'rotate(' + totalRadis + 'deg)',             'transition': 'transform 16s cubic-bezier(0,.47,.31,1.03)'         });         setTimeout(function(){             once = true;             alert('恭喜你抽中了' + wards[n] + '!');             $('#piece_wrap').css({                 'transform':'rotate(' + 0 + 'deg)',                 'transition': 'none'             });         }, time)     }              })

感谢你能够认真阅读完这篇文章,希望小编分享的"如何使用Javascript和CSS3实现一个转盘小游戏"这篇文章对大家有帮助,同时也希望大家多多支持,关注行业资讯频道,更多相关知识等着你来学习!

转盘 扇形 角度 生成 位置 思路 数据 篇文章 背景 随机数 区域 半圆 就是 知识 范围 小游戏 接下来 中心点 公式 可以通过 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 数据库定义上机实验报告 mc服务器无法连接 数据存到服务器 公安大学网络安全保卫专业 数据库应用技术课堂 网络技术的具体内容 大学教务系统有没有备份数据库 广东工控软件开发定制 上海软件开发哪家公司好 移动云的数据库产品功能 开源数据库索引服务 管理软件开发业务流程 网络安全检查公安局 以下哪些数据库可以获取考试资源 供电公司网络安全工作亮点 山东易搜互联网科技有限公司武迪 nike解析服务器时发生错误 服务器虚拟化显卡有用吗 蔚来汽车网络安全吗 企业单位网络安全的重要性 阿里云服务器系统回滚 如何定义数据库错误 指纹考勤机无法下载数据库 失落的方舟子服务器不一样 做网络安全领域的公司 网络安全禁止usb 计算机网络技术实习周志 服务器虚拟化显卡有用吗 软件开发公司怎么记账 软件开发算高薪嘛
0