一个简单的线下转盘活动,指定记录,有增速度和减速

代码在此,请品尝

在线地址:JS Bin - Collaborative JavaScript Debugging

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title><style>* {margin: 0;padding: 0;}.circle {width: 400px;height: 400px;border: 1px solid red;position: relative;margin: 50px auto;}.circle::after {content: "";display: block;width: 100%;height: 1px;background-color: red;position: absolute;left: 0;top: 50%;transform: translateY(-50%);}.circle::before {content: "";display: block;height: 100%;width: 1px;background-color: red;position: absolute;left: 50%;top: 0;transform: translateX(-50%);}.item {position: absolute;}.arrow {width: 50px;height: 50px;position: absolute;left: 50%;top: 50%;margin-left: -25px;margin-top: -25px;background-color: antiquewhite;border-radius: 100%;}.arrow::after {content: "";display: block;width: 10px;height: 40px;position: absolute;left: 50%;top: -40px;transform: translateX(-50%);background-color: antiquewhite;}.result {margin: 0 auto;display: flex;justify-content: center;}</style>
</head><body><div id="result" class="result"></div><div class="circle"><div class="item" style="left:30px;top:30px"><div>游园一场</div><div>游园活动0%</div></div><div class="item" style="right:30px;top:30px"><div>果切</div><div>果切活动89%</div></div><div class="item" style="right:30px;bottom:30px"><div>小礼品</div><div>小礼品10%</div></div><div class="item" style="left:30px;bottom:30px"><div>谢谢</div><div>感谢参与1%</div></div><div class="arrow" id="arrow"></div></div><div style="display: flex; justify-content: center;"><button id="start">开始游戏</button></div><script>function getRandomNumber(min, max) {return Math.floor(Math.random() * (max - min + 1)) + min;}function getTargetRoute() {// 设定中奖几率 果切活动89% 小礼品10% 感谢参与1% 游园活动0% (将游园活动的0几率排除)  const fruitChance = 89;const giftChance = 10;const thankChance = 1;// 计算总的中奖几率 const totalChance = fruitChance + giftChance + thankChance;// 生成一个0到totalChance-1之间的随机数  const randomNum = Math.floor(Math.random() * totalChance);//基础圈数const baseRoute = 360 * this.getRandomNumber(4, 10)// 根据随机数确定中奖结果  let result;let roateif (randomNum < fruitChance) {result = '果切';roate = baseRoute + this.getRandomNumber(10, 80) //不是0到90 为了防止落在边边,造成分歧} else if (randomNum < fruitChance + giftChance) {result = '小礼品';roate = baseRoute + this.getRandomNumber(100, 170)} else {result = '感谢参与';roate = baseRoute + this.getRandomNumber(280, 350)}return {result,roate}}let timer = null;let playing = false;function startGame(targetInfo) {const {result,roate} = targetInfo;//初始速度let speed = 1;//初始旋转位置let currentRoate = 0;document.querySelector("#result").innerHTML = `即将中奖的是:${result}`const dom = document.querySelector("#arrow");clearInterval(timer)playing = true;timer = setInterval(() => {currentRoate += speed;dom.style.transform = 'rotate(' + currentRoate + 'deg)';const percent = currentRoate / roate;if (percent < 0.7) {speed += 0.1;console.log("速度增加", speed)}else if (percent >= 0.7 && speed > 0.5) {//speed > 0.5是用来兜底的,否则还没到目标节点speed -= 0.2;console.log("速度减少", speed)}if (currentRoate >= roate) {clearInterval(timer);playing = false;alert(`中大奖了:${result}`)}}, 20)}document.querySelector("#start").onclick = function () {if (playing) {return;}//提前获取开奖结果,和旋转角度const targetInfo = getTargetRoute();//开始游戏startGame(targetInfo);}</script>
</body></html>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/13124.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

git 合并commit

操作步骤 合并commit cd xxx/ git checkout a8c0efegfwgtw # 最新commit git reset rhgertheryhg --soft # 最初的commit git status git checkout -b test1 git commit -m "test1" git branch git push origin test1 git tag test1_v0.0.1 git push origin test1_…

Tomcat无法连通的调试方法1-service方式无法连通

作者&#xff1a;私语茶馆 1.局域网Tomcat服务不通 组网如下&#xff1a; 问题&#xff1a; Tomcat Server 服务方式启动后&#xff0c;无法访问&#xff0c;但命令行方式启动可以。IP地址都在同网段或不同网段现象都一样。 2.Tomcat 服务安装与调试 在Windows下&#xff0c;…

计算机系列之排序算法

20、排序算法 1、直接插入排序&#xff08;这里以从小到大排序为例&#xff09; ◆要注意的是&#xff0c;前提条件是前i-1个元素是有序的&#xff0c;第i个元素依次从第i-1个元素往前比较&#xff0c;直到找到一个比第i个元素值小的元素&#xff0c;而后插入&#xff0c;插入…

软件工程课程设计之酒店管理系统的设计与实现

这是一个简化的酒店管理系统的需求分析文档、系统设计文档、测试文档的结构概述&#xff0c;以及部分实现阶段的代码示例。详细设计阶段的数据字典、ER图、模块分类图将以文字描述形式给出&#xff0c;而完整的代码未完全实现。这里只做软件工程部分的设计需求说明哈&#xff5…

表现层设计模式_1.MVC模式

1.MVC模式三个核心模块 MVC是一种目前广泛流行的软件设计模式。近年来&#xff0c;随着Java EE的成熟&#xff0c;MVC成为了Java EE平台上推荐的一种设计模式。MVC强制性地把一个应用的输入、处理、输出流程按照视图、控制、模型的方式进行分离&#xff0c;形成了控制器…

有关登录安全,测试人该知道些什么?

作为测试&#xff0c;给我们一个关键词“登录”&#xff0c;我们可能想到的用例设计更多的是什么用户名、密码校验是否合法、是否为空、是否正确等等之类的场景。 但在如今信息化的时代&#xff0c;“登录安全”已经是一个很热门且普遍的的话题了&#xff0c;今天给大家简单分…

Java设计模式——装饰者模式

Java设计模式——装饰者模式 1.简介 装饰者模式&#xff08;Decorator Pattern&#xff09;是一种结构型设计模式&#xff0c;它允许用户通过在一个对象上动态地添加职责或行为来增强其功能。这种类型的设计模式属于对象结构型模式&#xff0c;在不需要改变一个对象的内部结构…

基于国产LoRa的智慧农业解决方案--ASR6601、SX1278

我国《数字乡村发展战略纲要》明确指出“要推进农业数字化转型”&#xff0c;加快推广云计算、大数据、物联网、人工智能在农业生产经营管理中的运用。 然而&#xff0c;目前我国的农业数字化转型还面临着诸多挑战。我国整体农业机械化程度和自动化控制水平仍然较低。由于农田面…

Golang RPC实现-day02

导航 Golang RPC实现一、客户端异步并发多个请求1、 客户端结构体2、 一个客户端&#xff0c;异步发送多个请求&#xff0c;使用call结构体代表客户端的每次请求3、客户端并发多个请求4、客户端接收请求 Golang RPC实现 day01 我们实现了简单的服务端和客户端。我们简单总结一…

蓝桥杯-外卖店优先级(简单写法)

“饱了么”外卖系统中维护着 N 家外卖店&#xff0c;编号 1∼N。 每家外卖店都有一个优先级&#xff0c;初始时 (0 时刻) 优先级都为 0。 每经过 1 个时间单位&#xff0c;如果外卖店没有订单&#xff0c;则优先级会减少 1&#xff0c;最低减到 0&#xff1b;而如果外卖店有订…

【数据结构】双向循环链表专题解析

实现自己既定的目标&#xff0c;必须能耐得住寂寞单干。&#x1f493;&#x1f493;&#x1f493; 目录 •✨说在前面 &#x1f34b;知识点一&#xff1a;双向链表的结构 • &#x1f330;1."哨兵位"节点 • &#x1f330;2.双向带头循环链表的结构 &#x1f34b;…

基于java的超级玛丽游戏的设计与实现(论文 + 源码)

Java的超级玛丽游戏.zip资源-CSDN文库https://download.csdn.net/download/JW_559/89313347 基于java的超级玛丽游戏的设计与实现 摘要 近年来&#xff0c;Java作为一种新的编程语言&#xff0c;以其简单性、可移植性和平台无关性等优点&#xff0c;得到了广泛地应用。J2SE称…

(程序设计语言)传值、传引用

1、传值&#xff08;传递值&#xff09;&#xff1a; 在传值的情况下&#xff0c;函数接收到的是参数的一个副本&#xff0c;而不是参数本身。这意味着函数内部对参数的修改不会影响到原始值。传值通常用于基本数据类型&#xff08;如整数、浮点数、布尔值等&#xff09;的传递…

微信小程序原生全局状态管理——wxminishareddata

一个基于原生小程序的 mini 轻量全局状态管理库&#xff0c;跨页面/组件数据共享渲染。 全局状态 data 支持所有 Page 和 Component。类似 Vuex 的使用适合原生小程序&#xff0c;即使后期引入&#xff0c;也只需增加几行代码。目前为第一版&#xff0c;很粗糙&#xff0c;但也…

前端 CSS 经典:CSS 包含块

前言&#xff1a;CSS 总的来说就两块&#xff0c;样式计算和视觉格式化模型&#xff0c;而包含块就是视觉格式化模型的重要内容&#xff0c;理解包含块的定义&#xff0c;对于 CSS 布局有更好的帮助。 1. 概念 什么叫包含块&#xff0c;指的是一个区域&#xff0c;某一个元素在…

华焰天下晋升质量管理三大体系和产品3C认证实力级

华焰天下&#xff0c;作为业界领先的新能源灶具企业&#xff0c;一直以来都致力于追求卓越的质量管理和产品创新。近日&#xff0c;华焰天下成功晋升为质量管理三大体系先进管理&#xff0c;并成功获得了产品3C认证&#xff0c;这标志着我们在质量管理和产品安全方面迈出了坚实…

ThreadLocal,一次到位

一、定义 ThreadLocal是线程私有变量&#xff0c;用于保存每个线程的私有数据。 那么什么情况下需要进行线程隔离 二、源码分析 public class ThreadLocalTest01 {ThreadLocal<Integer> t new ThreadLocal<>();public void test() {t.set(1);Integer integer…

传输层协议——TCP协议

TCP协议又叫传输控制协议&#xff0c;TCP/IP协议是计算机通信网络中目前使用最多的协议&#xff0c;同时也融入了生活的方方面面&#xff0c;不管是浏览网页使用的http/https协议、物联网设备使用的MQTT/MQTTS协议与下载文件使用的ftp协议、工业以太网中使用的Modbus TCP协议等…

JVM学习-虚拟机栈

虚拟机栈 每个线程创建时都会创建一个虚拟机栈&#xff0c;其内部保存一个个栈帧&#xff0c;对应一次次Java方法调用&#xff0c;栈是线程私有的。 生命周期: 与线程相同 作用 主管Java程序的运行&#xff0c;它保存方法的局部变量、部分结果、并参与方法的调用和返回。 …

PyTorch之list、ndarray、tensor数据类型相互转换

温故而知新&#xff0c;可以为师矣&#xff01; 一、参考资料 python中list、numpy、torch.tensor之间的相互转换 二、常用操作 list 转 numpy ndarray np.array(list) import numpy as npa_list [[j for j in range(5)] for i in range(3)] a_ndarray np.array(a_lis…