100个 Unity小游戏系列六 -Unity 抽奖游戏专题四 翻卡游戏

一、演示效果

二、知识点讲解

2.1 布局

  void CreateItems(){reward_data_list = reward_data_list ?? new List<RewardData>();reward_data_list.Clear();for (int i = 0; i < ItemCount; i++){GameObject item;if (i + 1 <= itemParent.childCount){item = itemParent.GetChild(i).gameObject;}else{item = Instantiate(itemParent.GetChild(0).gameObject, itemParent);}item.transform.localPosition = initPosArr[i];item.transform.localScale = Vector3.one;var cardGraphics = item.transform.Find("Graphics").GetComponent<RectTransform>();RefreshCardData(cardGraphics, false, rewardDatas[i]);SetCardOpen(false, item.GetComponent<Button>(), true, rewardDatas[i]);}StartAnim(rewardDatas);}/// <summary>/// 明牌,洗牌动画/// </summary>private void StartAnim(RewardData[] rewardsArr){CardSelectable = false;if (rewardsArr.Length != itemParent.childCount){Debug.LogErrorFormat("rewards length is not equals cards count:{0}", itemParent.childCount);return;}isSwapCard = true;var seqAnim = DOTween.Sequence();seqAnim.AppendInterval(2f);seqAnim.AppendCallback(() =>{int overCount = itemParent.childCount;for (int i = 0; i < itemParent.childCount; i++){SetCardOpen(false, itemParent.GetChild(i).GetComponent<Button>(), false, null, 0.2f, () =>{//所有卡片翻回去之后开始洗牌if (--overCount <= 0){List<int> cardsList = new List<int>();for (int childIndex = 0; childIndex < itemParent.childCount; childIndex++){cardsList.Add(childIndex);}SwapCards(cardsList, 10, () =>{RefreshCardADState(false);CardSelectable = true;});}});}});}

2.2 转动逻辑

 private void SwapCards(List<int> cardsList, int swapCount, Action onComplete){if (swapCount <= 0){onComplete?.Invoke();return;}SwapCardAnim(cardsList, () =>{ListRandom(cardsList);SwapCards(cardsList, --swapCount, onComplete);});}public static void ListRandom<T>(List<T> sources){int index;T temp;for (int i = 0; i < sources.Count; i++){index = UnityEngine.Random.Range(0, sources.Count);if (index != i){temp = sources[i];sources[i] = sources[index];sources[index] = temp;}}}/// <summary>/// 洗牌动画/// </summary>/// <param name="onSwapOver"></param>private void SwapCardAnim(List<int> cardsindexList, Action onSwapOver){if (itemParent.childCount % 2 != 0){Debug.LogError("cardsRoot 卡片个数不能为奇数");return;}int moveMission = itemParent.childCount;TweenCallback onMoveOver = () =>{if (--moveMission <= 0){onSwapOver?.Invoke();}};for (int i = 0; i < cardsindexList.Count; i += 2){var indexA = cardsindexList[i];var indexB = cardsindexList[i + 1];var cardA = itemParent.GetChild(indexA);var cardB = itemParent.GetChild(indexB);float moveDuration = Vector2.Distance(initPosArr[indexA], initPosArr[indexB]) / 1500;moveDuration = Mathf.Clamp(moveDuration, 0, 0.18f);cardA.DOLocalMove(initPosArr[indexB], moveDuration).onComplete = onMoveOver;cardB.DOLocalMove(initPosArr[indexA], moveDuration).onComplete = onMoveOver;}}private void SetCardOpen(bool isUser, Button cardBt, bool isOpen, RewardData reward = null, float duration = 0.2f, Action onCardAnimOver = null){if (isOpen && reward == null){Debug.LogError("翻卡传入奖励数据为null");return;}if (isUser && !CardSelectable){return;}CardSelectable = false;int texIndex = 0;int colorIndex = 0;string tmStr = string.Empty;Vector3 halfRotate = new Vector3(0, 90, 0);if (isOpen){texIndex = reward.type;colorIndex = reward.type - 1;tmStr = reward.amount.ToString();halfRotate.y = 270;}cardBt.interactable = !isOpen;var card = cardBt.transform;var cardGraphics = card.Find("Graphics").GetComponent<RectTransform>();var seqAnim = DOTween.Sequence();seqAnim.Append(cardGraphics.DOLocalRotate(halfRotate, duration).SetEase(Ease.Linear));seqAnim.AppendCallback(() =>{RefreshCardData(cardGraphics, isOpen, reward);});seqAnim.Append(cardGraphics.DOLocalRotate(halfRotate + Vector3.up * 90, duration).SetEase(Ease.Linear));seqAnim.onComplete = () =>{if (!isUser){//CardSelectable = true;onCardAnimOver?.Invoke();}};if (isUser){card.SetSiblingIndex(itemParent.childCount);//float moveDuration = Vector2.Distance(card.transform.localPosition, Vector3.zero) / 400;//moveDuration = Mathf.Clamp(moveDuration, 0, 0.4f);//card.DOMove(Vector3.zero, moveDuration);//card.DOScale(1.4f, moveDuration).onComplete = () =>//{//    var moveSeq = DOTween.Sequence();//    moveSeq.AppendInterval(1.0f);//    moveSeq.AppendCallback(() =>//    {//        var smallCard = smallCardsRoot.GetChild(CurClaimIndex);//        moveDuration = Mathf.Clamp(Vector2.Distance(card.position, smallCard.position) / 10, 0, 0.4f);//        card.DOScale(smallCard.GetComponent<RectTransform>().sizeDelta.x / card.GetComponent<RectTransform>().sizeDelta.x, moveDuration);//        card.DOMove(smallCard.position, moveDuration).onComplete = () =>//        {//            CardSelectable = true;//            GF.Sound.PlaySound("poker_end.wav", false);//            //加奖励//            GF.UserData.ClaimReward(UserDataType.LuckpokerRedpacket, reward, GF.UserData.GameUIForm.gameMainView.levelSocreTxt.transform);//            onCardAnimOver?.Invoke();//        };//    });//};CardSelectable = true;onCardAnimOver?.Invoke();}}

三 、完整代码逻辑

https://github.com/lixianjun0903/luckydraw-master.git

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

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

相关文章

前端基础入门三大核心之HTML篇:Webpack、Vite、Grunt、Gulp的场景与实战运用

前端基础入门三大核心之HTML篇&#xff1a;Webpack、Vite、Grunt、Gulp的场景与实战运用 一、Webpack&#xff1a;模块打包与优化的集大成者基本概念与作用应用场景实战例 二、Vite&#xff1a;快速开发的现代化构建利器基本概念应用场景实战例 三、Gulp&#xff1a;任务自动化…

护网期间遇到的几个上传bypass waf、edr

1. weblogic部署war的时候 http/1.1 改成http/2绕过waf 其实jar和ear部署应该也可以&#xff0c;但是我没成功。 2. tomcat windows的话部署 1.war变成 1.w/a/r 应该是 1.w\a\r 3. 上传绕过waf filename"x.jsp" 换成 filename x.jsp 还不行把 把ban…

【MySQL精通之路】SQL优化(1)-查询优化(7)-嵌套循环联接

主博客&#xff1a; 【MySQL精通之路】SQL优化(1)-查询优化-CSDN博客 上一篇&#xff1a; 【MySQL精通之路】SQL优化(1)-查询优化(6)-索引条件下推-CSDN博客 下一篇&#xff1a; 1.嵌套循环连接算法 一个简单的嵌套循环联接&#xff08;NLJ&#xff09;算法一次从循环中的…

Python解析网页-requests_html

目录 1、什么是requests_html 2、安装与配置 3、快速入门 4、图片下载 1.什么是requests_html requests_html是一个Python库&#xff0c;用于从Web页面中提取数据。 它提供了对HTML内容的解析和处理功能&#xff0c;使您可以轻松地从网页中提取文本、链接、图像和其他元素。…

python字典形式的字符串转换成python字典的两种方法eval()和json.loads()

有时候我们需要将python字典形式的字符串转化成python字典&#xff0c;有两种方法&#xff1a; 方法一&#xff1a;eval() dic_str "{name:jack, age:18, gender:male}" # dic_str {"name":"jane", "age":27, "gender":…

嵌入式UI开发-lvgl+wsl2+vscode系列:4、动画(Animations)

文章目录 一、前言二、动画示例1、示例1&#xff08;基础按钮label的组合动画&#xff09;2、示例2&#xff08;回放效果动画&#xff09;3、示例3&#xff08;贝塞尔曲线3动画&#xff09;4、示例4&#xff08;动画时间轴&#xff09; 三、最后 一、前言 接下来我们进行动画的…

Golang | Leetcode Golang题解之第101题对称二叉树

题目&#xff1a; 题解&#xff1a; func isSymmetric(root *TreeNode) bool {u, v : root, rootq : []*TreeNode{}q append(q, u)q append(q, v)for len(q) > 0 {u, v q[0], q[1]q q[2:]if u nil && v nil {continue}if u nil || v nil {return false}if …

pnpm使用教程

pnpm&#xff08;Performant npm&#xff09;是一个高性能的包管理器&#xff0c;旨在解决npm和yarn中的问题&#xff0c;提供更快的安装速度、节省磁盘空间、良好的monorepo支持以及高级安全性。下面是一个简要的pnpm使用教程&#xff1a; 安装 pnpm 通过 npm 安装 在已安装…

JWT使用方法

目录 基础概念 依赖 生成令牌 工具类 控制层 解析令牌 工具类 网关过滤器 效果 基础概念 Json web token (JWT), 是为了在网络应用环境间传递声明而执行的一种基于JSON的开放标准&#xff08;(RFC 7519).该token被设计为紧凑且安全的&#xff0c;特别适用于分布式站点…

Kubernetes 文档 / 概念 / 服务、负载均衡和联网 / 服务(Service)

Kubernetes 文档 / 概念 / 服务、负载均衡和联网 / 服务&#xff08;Service&#xff09; 此文档从 Kubernetes 官网摘录 中文地址 英文地址 Kubernetes 中的 Service Service API 是 Kubernetes 的组成部分&#xff0c;它是一种抽象&#xff0c;帮助你将 Pod 集合在网络上公…

AI绘画工具

AI绘画工具利用人工智能技术生成艺术作品&#xff0c;这些工具通常基于深度学习算法&#xff0c;尤其是生成对抗网络&#xff08;GANs&#xff09;。以下是一些流行的AI绘画工具&#xff1a; DeepArt&#xff1a;使用神经风格迁移技术&#xff0c;将任何图片转换成著名画家的风…

深入解读力扣154题:寻找旋转排序数组中的最小值 II(多种方法及详细ASCII图解)

❤️❤️❤️ 欢迎来到我的博客。希望您能在这里找到既有价值又有趣的内容&#xff0c;和我一起探索、学习和成长。欢迎评论区畅所欲言、享受知识的乐趣&#xff01; 推荐&#xff1a;数据分析螺丝钉的首页 格物致知 终身学习 期待您的关注 导航&#xff1a; LeetCode解锁100…

弘君资本:沪指跌0.46%,电力板块逆市爆发,半导体板块强势

28日&#xff0c;沪指早盘窄幅震动&#xff0c;午后回落走低&#xff1b;深证成指、创业板指大幅下探&#xff1b;两市成交额小幅萎缩。 截至收盘&#xff0c;沪指跌0.46%报3109.57点&#xff0c;深证成指跌1.23%报9391.05点&#xff0c;创业板指跌1.35%报1806.25点&#xff0c…

Windows 11 HBuilder X的安装和环境搭建教程

文章目录 目录 文章目录 安装流程 小结 概要安装流程技术细节小结 概要 HBuilder X是一个由DCloud推出的集成开发环境&#xff08;IDE&#xff09;&#xff0c;主要用于构建基于HTML、CSS和JavaScript的跨平台应用程序&#xff0c;如微信小程序、App、H5等。它提供了丰富的功能…

【Unity】颜色混合计算

在图形渲染中&#xff0c;颜色混合&#xff08;Color Blending&#xff09;是指将多个颜色值组合在一起以生成最终显示的颜色。颜色混合技术广泛用于处理半透明效果、光照效果和后期处理效果。以下是一些常见的颜色混合模式&#xff1a; 1. 正常混合&#xff08;Normal Blendi…

每日力扣刷题day02(从零开始版)

文章目录 2024.5.23&#xff08;5题&#xff09;1929. 数组串联题解一题解二 1281. 整数的各位积和之差题解一题解二 1137. 第 N 个泰波那契数题解一题解二 2413. 最小偶倍速题解一题解二 2778. 特殊元素平方和题解一题解二 2024.5.23&#xff08;5题&#xff09; 1929. 数组串…

【八股系列】webpack打包时Hash码是怎样生成的?随机值存在一样的情况,如何避免?

文章目录 1. Hash码的生成2. 避免Hash码一致2.1 确保文件内容唯一&#xff1a;2.2 使用chunkhash&#xff1a;2.3 增加文件名前缀&#xff1a;2.4 优化哈希算法&#xff1a;2.5 使用Module IDs&#xff1a;2.6 配置webpack输出选项&#xff1a; 3. 配置生成Hash的规则 1. Hash码…

简单四步完成基于云服务器ARL资产侦察灯塔系统搭建

简单四步完成基于云服务器ARL资产侦察灯塔系统搭建及使用 前言 官网介绍&#xff1a;ARL全称-Asset Reconnaissance Lighthouse&#xff0c;中文含义&#xff1a;资产侦察灯塔系统。 旨在快速侦察与目标关联的互联网资产&#xff0c;构建基础资产信息库。 协助甲方安全团队或…

Elasticsearch reindex操作

需求 我有一个index&#xff1a;test_1&#xff0c;这个index由于各种原因&#xff0c;mapping中出现了下面的type&#xff1a; "u_ori_id_list" : {"type" : "text","fields" : {"keyword" : {"type" : "…

DragonKnight CTF复现(一)

这次的 re 题也是挺难的&#xff0c;按 wp 来学习一波 elec_go 下次遇到这种给了很多东西&#xff0c;又不知道怎么分析的&#xff0c;先百度一下。 Electron程序逆向&#xff08;asar归档解包&#xff09;_asar解包-CSDN博客 [原创] electron开发、打包与逆向分析-软件逆向-…