【制作100个unity游戏之27】使用unity复刻经典游戏《植物大战僵尸》,制作属于自己的植物大战僵尸随机版和杂交版7(附带项目源码)

本文主要是介绍【制作100个unity游戏之27】使用unity复刻经典游戏《植物大战僵尸》,制作属于自己的植物大战僵尸随机版和杂交版7(附带项目源码),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最终效果

在这里插入图片描述

系列导航

文章目录

  • 最终效果
  • 系列导航
  • 前言
  • 绘制进度条UI
  • 控制关卡进度测试
  • 按配置表使用关卡进度变化
  • 源码
  • 结束语

前言

本节主要实现关卡进度条的功能

绘制进度条UI

在这里插入图片描述

控制关卡进度测试

新增ProgressPanel代码,控制关卡进度

public class ProgressPanel : MonoBehaviour
{private GameObject progress;private GameObject head;private TextMeshProUGUI levelText;private GameObject flagPrefab;//旗帜预制体void Start(){progress = transform.Find("进度条").gameObject;head = transform.Find("僵尸头").gameObject;levelText = transform.Find("关卡文本").gameObject.GetComponent<TextMeshProUGUI>();flagPrefab = Resources.Load("Prefabs/UI/旗帜") as GameObject;//TODO:测试SetPercent(0.2f);SetFlagPercent(0.4f);SetFlagPercent(0.6f);SetFlagPercent(0.8f);SetLevelText(1);}//设置进度条和僵尸头位置public void SetPercent(float per){// 图片进度条progress.GetComponent<Image>().fillAmount = per;// 进度条宽度float width = progress.GetComponent<RectTransform>().sizeDelta.x;float rightX = width / 2;// 设置头的x轴位置:最右边的位置 - 进度条宽度*进度值head.GetComponent<RectTransform>().localPosition = new Vector2(rightX - per * width, 0);}//设置旗帜位置public void SetFlagPercent(float per){// 进度条宽度float width = progress.GetComponent<RectTransform>().sizeDelta.x;float rightX = width / 2;// 创建新的旗子GameObject newFlag = Instantiate(flagPrefab);//false:表示保持newFlag相对于世界坐标的位置、旋转和缩放不变,即不将newFlag的局部坐标和旋转值随着父级对象的变化而改变。newFlag.transform.SetParent(transform, false);// 设置位置newFlag.GetComponent<RectTransform>().localPosition = new Vector2(rightX - per * width, 7f);//把Head对象在其父级对象中的层级顺序置于最后,也就是显示在所有其他同级对象的最上方。head.transform.SetAsLastSibling();}//设置关卡文本public void SetLevelText(int per){levelText.text = "关卡 " + per;}
}

配置信息
在这里插入图片描述

在这里插入图片描述

测试运行效果,可以看到旗帜生成位置和进度条都正常
在这里插入图片描述

按配置表使用关卡进度变化

首先去除前面的测试代码,修改UIManager

public class UIManager : MonoBehaviour
{public static UIManager Instance { get; private set; }public TextMeshProUGUI sunSumText;public ProgressPanel progressPanel;int zombieDiedCount = 0;//死亡僵尸数量private void Awake(){Instance = this;}private void Start(){Init();zombieDiedCount = 0;InitProgressPanel();}public void Init(){sunSumText.text = GameManager.Instance.sunSum.ToString();}//初始化进度条public void InitProgressPanel(){// 初始化进度为0progressPanel.SetPercent(0);int count = GameManager.Instance.listData.Count;string progressId = GameManager.Instance.listData[0]["progressId"];// 遍历数据列表,设置旗帜的位置for (int i = 0; i < count; i++){// 获取当前字典数据Dictionary<string, string> dic = GameManager.Instance.listData[i];if (progressId != dic["progressId"]){progressPanel.SetFlagPercent((float)i / count);}progressId = dic["progressId"];}}//更新进度public void UpdateProgressPanel(){zombieDiedCount++;progressPanel.SetPercent((float)zombieDiedCount / GameManager.Instance.listData.Count);}
}

修改GenerateZombies里的ZombieDied方法,每次僵尸死亡时调用UpdateProgressPanel方法,更新UI进度,当然你也可以在僵尸生成时调用,具体看你的需求

//更新进度UI
UIManager.Instance.UpdateProgressPanel();

效果
在这里插入图片描述

源码

源码不出意外的话我会放在最后一节

结束语

赠人玫瑰,手有余香!如果文章内容对你有所帮助,请不要吝啬你的点赞评论和关注,以便我第一时间收到反馈,你的每一次支持都是我不断创作的最大动力。当然如果你发现了文章中存在错误或者有更好的解决方法,也欢迎评论私信告诉我哦!

好了,我是向宇,https://xiangyu.blog.csdn.net

一位在小公司默默奋斗的开发者,出于兴趣爱好,最近开始自学unity,闲暇之余,边学习边记录分享,站在巨人的肩膀上,通过学习前辈们的经验总是会给我很多帮助和启发!php是工作,unity是生活!如果你遇到任何问题,也欢迎你评论私信找我, 虽然有些问题我也不一定会,但是我会查阅各方资料,争取给出最好的建议,希望可以帮助更多想学编程的人,共勉~

在这里插入图片描述

这篇关于【制作100个unity游戏之27】使用unity复刻经典游戏《植物大战僵尸》,制作属于自己的植物大战僵尸随机版和杂交版7(附带项目源码)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

Pandas透视表(Pivot Table)的具体使用

《Pandas透视表(PivotTable)的具体使用》透视表用于在数据分析和处理过程中进行数据重塑和汇总,本文就来介绍一下Pandas透视表(PivotTable)的具体使用,感兴趣的可以了解一下... 目录前言什么是透视表?使用步骤1. 引入必要的库2. 读取数据3. 创建透视表4. 查看透视表总结前言

Python 交互式可视化的利器Bokeh的使用

《Python交互式可视化的利器Bokeh的使用》Bokeh是一个专注于Web端交互式数据可视化的Python库,本文主要介绍了Python交互式可视化的利器Bokeh的使用,具有一定的参考价值,感... 目录1. Bokeh 简介1.1 为什么选择 Bokeh1.2 安装与环境配置2. Bokeh 基础2

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

如何使用 Python 读取 Excel 数据

《如何使用Python读取Excel数据》:本文主要介绍使用Python读取Excel数据的详细教程,通过pandas和openpyxl,你可以轻松读取Excel文件,并进行各种数据处理操... 目录使用 python 读取 Excel 数据的详细教程1. 安装必要的依赖2. 读取 Excel 文件3. 读

SpringBoot项目中报错The field screenShot exceeds its maximum permitted size of 1048576 bytes.的问题及解决

《SpringBoot项目中报错ThefieldscreenShotexceedsitsmaximumpermittedsizeof1048576bytes.的问题及解决》这篇文章... 目录项目场景问题描述原因分析解决方案总结项目场景javascript提示:项目相关背景:项目场景:基于Spring

解决Maven项目idea找不到本地仓库jar包问题以及使用mvn install:install-file

《解决Maven项目idea找不到本地仓库jar包问题以及使用mvninstall:install-file》:本文主要介绍解决Maven项目idea找不到本地仓库jar包问题以及使用mvnin... 目录Maven项目idea找不到本地仓库jar包以及使用mvn install:install-file基