塔防游戏 Day3
1. 添加按钮动画
选择 Button->Transition 为 Animation ,然后自定义四种状态动画即可。

2. 控制升级面板的显示和隐藏
// 升级处理
// 若点击同一炮塔,并且面板已显示
if (mapCube.turretGo == selectedTurret && upgradeCanvas.activeInHierarchy)
{
HideUpgradeUI(); // 隐藏面板
}
else // 否则显示面部
{
ShowUpgradeUI(mapCube.transform.position, mapCube.isUpgraded);
}
selectedTurret = mapCube.turretGo;
// 显示升级面板
void ShowUpgradeUI(Vector3 pos, bool isDisableUpgrade)
{
upgradeCanvas.SetActive(true); // 显示面板
upgradeCanvas.transform.position = pos; // 放在合适的位置
upgradeButton.interactable = !isDisableUpgrade; // 升级按钮是否可用
} // 隐藏升级面板
void HideUpgradeUI()
{
upgradeCanvas.SetActive(false);
}
3. 给升级面板添加动画
// 显示升级面板
void ShowUpgradeUI(Vector3 pos, bool isDisableUpgrade)
{
StopCoroutine("HideUpgradeUI()"); // 开始协程
upgradeCanvas.SetActive(false);
upgradeCanvas.SetActive(true); // 显示面板
upgradeCanvas.transform.position = pos; // 放在合适的位置
upgradeButton.interactable = !isDisableUpgrade; // 升级按钮是否可用
} // 隐藏升级面板
IEnumerator HideUpgradeUI()
{
upgradeCanvasAnimator.SetTrigger("Hide");
yield return new WaitForSeconds(0.5f);
upgradeCanvas.SetActive(false);
}
4. 控制升级和拆毁炮台
// 点击按钮触发函数
public void onUpgradeButtonDown()
{
selectedMapCube.UpdateTurret();
StartCoroutine(HideUpgradeUI());
} public void onDestroyButtonDown()
{
selectedMapCube.DestroyTurret();
StartCoroutine(HideUpgradeUI());
}
// 升级炮塔
public void UpdateTurret()
{
if (isUpgraded) return;
Destroy(turretGo);
turretGo = GameObject.Instantiate(turretData.turretUpgradedPrefab, transform.position, Quaternion.identity);
isUpgraded = true;
// 产生特效
GameObject effect = GameObject.Instantiate(buildEffect, transform.position, Quaternion.identity);
Destroy(effect, 1.5f); // 1.5秒后销毁特效
} // 拆毁炮台
public void DestroyTurret()
{
Destroy(turretGo);
isUpgraded = false; // 初始化
turretGo = null;
turretData = null;
// 产生特效
GameObject effect = GameObject.Instantiate(buildEffect, transform.position, Quaternion.identity);
Destroy(effect, 1.5f); // 1.5秒后销毁特效
}
5. 添加激光炮塔
添加 LineRenderer 组件。

if (enemys.Count > )
{
// 设置激光的开始位置和结尾位置
laserRenderer.SetPositions(new Vector3[] { firePosition.position, enemys[].transform.position });
}
4. 游戏失败情况处理
// 游戏失败
public void fail()
{
MessageText.text = "失 败";
endUI.SetActive(true);
enemySpawner.Stop(); // 停止生成敌人
}
public void Stop()
{
StopCoroutine(coroutine); // 停止协程
}
5. 菜单设计


// 点击开始游戏按钮
public void OnButtonStart()
{
SceneManager.LoadScene();
} // 点击退出按钮
public void OnButtonExit()
{
#if UNITY_EDITOR
UnityEditor.EditorApplication.isPlaying = false;
#else
Application.Quit();
#endif
}
完!!!
塔防游戏 Day3的更多相关文章
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(三)
一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)篇 二.本篇目标: l 说说游戏中各种角色的动作.属性以及重构思路 l 进行代码重构让色狼大叔和 ...
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(二)
一.前提: 完成前一篇的内容. 具体参考:Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)篇 二.本篇目标: l 说说关于cocos2dx手机分辨率适配 l 对前一篇完成的塔防游戏原型进 ...
- Cocos2d-x3.x塔防游戏(保卫萝卜)从零开始(一)
一.前提: 完成Hello Game项目的创建编译. 具体参考:Cocos2dx.3x_Hello Game项目创建篇 二.本篇目标: l 说说关于塔防游戏的想法和思路 l 实现一个简单的塔防游戏 ...
- 三国塔防游戏android源码
三国塔防游戏源码,这个游戏源码比较完整的,因为上传有20M限制,把代码工程包分开了,主文件是TFGame,其他res大家按照安卓包加进去就行,欢迎下载并交流 ,大家可以参考一下吧.<ignore ...
- HTML5塔防游戏——《三国塔防》 - Yorhom's Game Box
h3{ font-size:20px; } HTML5塔防游戏--<三国塔防> 游戏介绍: <三国塔防>是一款基于HTML5和Javascript的2D塔防游戏.游戏中除了塔防 ...
- HTML5另类塔防游戏 -《三国战线》公布
关于本作 游戏介绍 本游戏是一款另类塔防游戏.本作以三国这段历史为题材,提供了从颍川之战到官渡之战.官渡之战到夷陵之战.夷陵之战到五丈原之战等15个关卡.在每一个关卡中,你会控制一名三国武将与出现的敌 ...
- [译]终极塔防——运用HTML5从头创建一个塔防游戏
翻译共享一篇CodeProject的高星力作,原文地址:http://www.codeproject.com/Articles/737238/Ultimate-Tower-Defense 下载演示项目 ...
- 使用Unity创建塔防游戏(Part2)
How to Create a Tower Defense Game in Unity – Part 2 原文地址:https://www.raywenderlich.com/107529/unity ...
- 使用Unity创建塔防游戏(Part1)
How to Create a Tower Defense Game in Unity - Part1 原文作者:Barbara Reichart 文章原译:http://www.cnblogs.co ...
随机推荐
- [转]:What happens to older developers?
原文链接可能失效. This post is old but will remain on the front page for the time being. 140313. Jeff Jenkin ...
- IE中拖放问题
1.所有的元素上都能绑定放置目标的事件,但并不保证此元素是有效的放置对象. 默认情况下,IE中只有文本框(<input/>或<textarea/>)是网页上唯一有效的放置目标. ...
- java project 项目在 linux 下面部署方法
1.前提是安装好了响应的开发和部署环境,例如jdk. 2.在Linux下运行可执行Jar包,首先准备jar包,一般的编译工具Eclipse,jbuilder都提供export功能,可以生成jar包. ...
- 表格头部与左侧内容随滚动条位置改变而改变(基于jQuery)
效果图如下: HTML代码: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta chars ...
- 8.Python编写登录接口
1.python需安装flask,在命令行窗口输入:pip3 install flask 2.代码如下所示: from flask import Flask,request,jsonify,sessi ...
- 初学HTML之HTML介绍
众所周知现在的H5.大数据.云计算都是热门的.其实想学好一门语言重点是多看多想多写多练. 我在博客中会从基础开始讲解HTML4.0.中间加入HTML5的新标签 在这先给大家推荐几个开发工具: note ...
- 【经验】实现STL算法时遇到的模板编译错误问题
在实现set_union算法时调用了自己写的copy算法,出现了以下问题. Error 1 error C2665: 'xyz_stl::__copy' : none of the 2 overloa ...
- java代码-----运用endWith()和start()方法
总结: package com.a.b; //startWith().和endWith()是检查一个字符串是否以一个特定的字符序列开始或结束 public class Sdfs { public st ...
- python(ValueError: invalid literal for int() with base 10: 'abc' ‘1.0‘’’)强制类型转换
int()函数只能转化数字组成的字符串,看例子: >>> a=' >>> int(a) 123 >>> b='abc' >>> ...
- 关于使用PyExecJS+nodejs使用与js反混淆
来源:https://cuiqingcai.com/5024.html 梳理这篇博客的时候出问题,我默认的是jscript作为pyexcJs的引擎,问题很大,大部分的js都无法加载,各种包用不了,只能 ...