cocosCreator实现两种效果转盘抽奖

2024-04-12 17:36

本文主要是介绍cocosCreator实现两种效果转盘抽奖,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言: cocosCreator实现两种效果转盘抽奖。

今天完成策划给的2个抽奖需求,我把核心逻辑提取出来并拓展了一个功能更丰富的效果,抛砖引玉分享出来。
远程Gitee: 稍后上传

一、转盘抽奖

A:使用cc.tween().to功能+缓动函数实现旋转。
优点:简单易懂,方便控制。
缺点:功能单一
在这里插入图片描述
B:使用适应对时间的插值计算 + cc.tween().by 。
奖励展示跟随指针选中效果
使用了es6写法,对于页游可能在部分浏览器上不支持(比如360的兼容模式),可改成es写法
在这里插入图片描述

二、轮询抽奖

同样使用了2中方式实现。
在这里插入图片描述

三、代码展示(展示转盘抽奖B方案)

节点树和脚本挂载
在这里插入图片描述

GameControl脚本

import GoLuckDraw from "./GoLuckDraw";const { ccclass, property } = cc._decorator;@ccclass
export default class GameControl extends cc.Component {@property(cc.Node)public RewardPre: cc.Node = null;   //奖励预制节点  public AwardNode: cc.Node;         //奖励父节public Pointer: cc.Node;           //指针public LuckDraw: GoLuckDraw;       //旋转组件public rewardCount: number = 12;                     //奖品个数      public avgAngle: number = 360 / this.rewardCount;   //平均角度private angleStep = Math.PI * 2 / this.rewardCount; //平均弧度private radius: number = 240;                       //半径private curIndex: number = 0;    //当前奖励下标private tagetIndex: number = 0;  //目标奖励下标private reawadArr: Array<Number> = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9 ,10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33];  //奖品名称onLoad() {this.AwardNode = cc.find("ZhuanPanRoot/BackGround/AwardNode", this.node);this.Pointer = cc.find("ZhuanPanRoot/BackGround/CentreNode/Pointer", this.node);this.LuckDraw = cc.find("ZhuanPanRoot", this.node).getComponent(GoLuckDraw);}start() {this._InitAwardPre();}private _InitAwardPre() {for (let i = 0; i < this.rewardCount; i++) {const angle = i * this.angleStep; // 计算当前点的角度  const x = this.radius * Math.cos(angle); // 使用余弦计算x偏移量        const y = this.radius * Math.sin(angle); // 使用正弦计算y偏移量  let rewardPre = cc.instantiate(this.RewardPre);rewardPre.x = y, rewardPre.y = x;rewardPre.parent = this.AwardNode;rewardPre.active = true;rewardPre.getChildByName('label').getComponent(cc.Label).string = i.toString();}}//开始抽奖private isTurnIng = false;public BtnCallBack() {if (this.isTurnIng) {return;}this.isTurnIng = true;let awardIndex = Math.floor(Math.random() * this.rewardCount);this.tagetIndex = awardIndex;console.log("========>>>>", awardIndex, this.reawadArr[awardIndex]);this.LuckDraw.StartLuckDraw(this, this.curIndex, this.tagetIndex, 4, 4);this.LuckDraw.CompleteCallBack = () => {this.curIndex = this.tagetIndex;this.isTurnIng = false;}}// update (dt) {}
}

GoLuckDraw

import GameControl from "./GameControl";const { ccclass, property } = cc._decorator;@ccclass
export default class GoLuckDraw extends cc.Component {public CompleteCallBack: () => void;private EndDarwTick: number = 2;    //最后一轮的秒数为2秒;private CurIndex: number;           //起始位置private StopIndex: number;          //停止位置private Allticks: number;           //总秒数private MaxCount: number;           //轮数private MainThis: GameControl;private ByAngle: number;onLoad() {}/*** * @param curIndex   起始位置* @param stopIndex  结束位置* @param allticks   总时长* @param maxCount      轮次*/public StartLuckDraw(gameControl: GameControl, curIndex: number, stopIndex: number, allticks: number, maxCount: number) {this.MainThis = gameControl;this.ByAngle = this.MainThis.avgAngle * -1;this.CurIndex = curIndex;this.StopIndex = stopIndex + this.MainThis.rewardCount;this.Allticks = allticks > 3 ? allticks : 3;this.MaxCount = maxCount;this.LuckDrawRounds();}private async LuckDrawRounds() {let time1 = 0, time2 = 0;let sumCount = this.MaxCount * this.MainThis.rewardCount;let avgTime = (this.Allticks - this.EndDarwTick) / sumCount;  //平均时间for (let i = this.CurIndex; i < sumCount; i++) {time1 = cc.misc.lerp(0, avgTime * 2, (1 / sumCount) * (i + 1));cc.tween(this.MainThis.Pointer).by(time1, { angle: this.ByAngle }).start();this.SetAwardState(i);await this.SleepTime(time1);}avgTime = this.EndDarwTick / this.StopIndex;for (let i = 0; i < this.StopIndex; i++) {time2 = cc.misc.lerp(time1, avgTime * 2, (1 / this.StopIndex) * (i + 1));cc.tween(this.MainThis.Pointer).by(time2, { angle: this.ByAngle  }).start();this.SetAwardState(i);await this.SleepTime(time2);}this.SetAwardState(this.StopIndex);await this.SleepTime(1);if (this.CompleteCallBack != null) {this.CompleteCallBack();}}private SleepTime(time: number): Promise<void> {return new Promise((resolve, reject) => {this.scheduleOnce(() => {resolve();}, time);})}private SetAwardState(index: number) {let _index = index % this.MainThis.rewardCount;let label: cc.Node;let lastIndex = _index - 1 < 0 ? this.MainThis.rewardCount - 1 : _index - 1;label = this.MainThis.AwardNode.children[lastIndex]?.getChildByName("label");if (label) {label.color = cc.Color.WHITE;}label = this.MainThis.AwardNode.children[_index]?.getChildByName("label");if (label) {label.color = cc.Color.RED;}}
}

这篇关于cocosCreator实现两种效果转盘抽奖的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/897793

相关文章

Java实现字节字符转bcd编码

《Java实现字节字符转bcd编码》BCD是一种将十进制数字编码为二进制的表示方式,常用于数字显示和存储,本文将介绍如何在Java中实现字节字符转BCD码的过程,需要的小伙伴可以了解下... 目录前言BCD码是什么Java实现字节转bcd编码方法补充总结前言BCD码(Binary-Coded Decima

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

SpringBoot全局域名替换的实现

《SpringBoot全局域名替换的实现》本文主要介绍了SpringBoot全局域名替换的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录 项目结构⚙️ 配置文件application.yml️ 配置类AppProperties.Ja

Python实现批量CSV转Excel的高性能处理方案

《Python实现批量CSV转Excel的高性能处理方案》在日常办公中,我们经常需要将CSV格式的数据转换为Excel文件,本文将介绍一个基于Python的高性能解决方案,感兴趣的小伙伴可以跟随小编一... 目录一、场景需求二、技术方案三、核心代码四、批量处理方案五、性能优化六、使用示例完整代码七、小结一、

Java实现将HTML文件与字符串转换为图片

《Java实现将HTML文件与字符串转换为图片》在Java开发中,我们经常会遇到将HTML内容转换为图片的需求,本文小编就来和大家详细讲讲如何使用FreeSpire.DocforJava库来实现这一功... 目录前言核心实现:html 转图片完整代码场景 1:转换本地 HTML 文件为图片场景 2:转换 H

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

C#实现一键批量合并PDF文档

《C#实现一键批量合并PDF文档》这篇文章主要为大家详细介绍了如何使用C#实现一键批量合并PDF文档功能,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言效果展示功能实现1、添加文件2、文件分组(书签)3、定义页码范围4、自定义显示5、定义页面尺寸6、PDF批量合并7、其他方法

SpringBoot实现不同接口指定上传文件大小的具体步骤

《SpringBoot实现不同接口指定上传文件大小的具体步骤》:本文主要介绍在SpringBoot中通过自定义注解、AOP拦截和配置文件实现不同接口上传文件大小限制的方法,强调需设置全局阈值远大于... 目录一  springboot实现不同接口指定文件大小1.1 思路说明1.2 工程启动说明二 具体实施2

Python实现精确小数计算的完全指南

《Python实现精确小数计算的完全指南》在金融计算、科学实验和工程领域,浮点数精度问题一直是开发者面临的重大挑战,本文将深入解析Python精确小数计算技术体系,感兴趣的小伙伴可以了解一下... 目录引言:小数精度问题的核心挑战一、浮点数精度问题分析1.1 浮点数精度陷阱1.2 浮点数误差来源二、基础解决

Java实现在Word文档中添加文本水印和图片水印的操作指南

《Java实现在Word文档中添加文本水印和图片水印的操作指南》在当今数字时代,文档的自动化处理与安全防护变得尤为重要,无论是为了保护版权、推广品牌,还是为了在文档中加入特定的标识,为Word文档添加... 目录引言Spire.Doc for Java:高效Word文档处理的利器代码实战:使用Java为Wo