Unity3D简陋版跑酷游戏

简介: Unity3D简陋版跑酷游戏

功能演示


image.gif

链接:https://pan.baidu.com/s/1E_2JXWlVJNf3S5l-dH2UuQ提取码:dm5e

视频教学:Unity3D大作业 超级简陋版的跑酷游戏_哔哩哔哩_bilibili

功能简介


本次跑酷游戏主要从跑道,UI设计,目标物体,玩家四个方向来进行设计制作,跑道不断向前移动,给别人一种玩家在不断前进的错觉,跑道上设计了大概赛道2%的陷阱,当然后期可以把难度提高;UI方面主要是设计计时器,这里我们规定一局游戏的限时为65s,计分板即是我们吃到金币的数量,生命值则是100,如果撞到障碍墙则丢失20的血量,如果没有跳过陷阱则直接死亡;目标物体,则在跑道上设计了大概跑道44%的金币,1%的延时器,这里解释以下,延时器就是,可以帮助我们加长5S对此局游戏的时间,5%的吸金石,在3S内可以吸附附近所有的金币,如果连续捡到吸金石,则时间可以叠加,还有最后一个就是障碍墙,碰到则丢失20的生命值;玩家,为了简便这里使用的是unity自带的小球,让大家能看出来它是移动的,像小人一样在奔跑,则让它自旋起来,并用不同颜色的小球在每个节点进行替换,拥有左右移动,跳跃等功能。具体如下所示:

image.png

制作步骤


1.搭建跑道

 我们使用unity自带的cube,将其进行铺开展平,为了增添游戏色彩,决定在上面添加一些蓝色和红色的箭头,此工作用ps完成,一节跑道毕竟太短,将其复制多个跑道,并用代码控制后面的跑道用完撤回到前面不断循环,给玩家一种不断向前跑动的错觉。

image.png

部分代码如下:首先定义一块小平地,设置小平地的数量为15,使用for循环生成若干个小平地,用if判断Land是否为蓝色。

public class Lands : MonoBehaviour {
public Transform land; // 一块小平地
public int landNums = 15; // 小平地的数量
public bool isGameScene = true;
// Use this for initialization
void Start () {
float start = land.GetComponent<Land>().startPosZ;
float delta = land.localScale.z * 10;
bool blue = true;
// 生成若干小Land
for (int i = 0; i < landNums; i++) {
Transform newLand = Instantiate(land) as Transform;
newLand.SetParent(this.transform);
newLand.localPosition = new Vector3(0, 0, start + i * delta);
if (blue)
newLand.SendMessage("SetColorBlue");
blue = !blue;
if (!isGameScene) {
newLand.GetComponent<Land>().isGameScene = false;
continue;
}
if (i >= landNums / 3)
newLand.GetComponent<Land>().setObjectsOnStart = true;
}
}

为了让玩家有更好的体验,天空的背景和周围的植被需要进行修饰。

image.png

2.实现玩家功能

首先让玩家自旋并不断地变换颜色,类似于小人不断地奔跑,玩家按住”A”,”D”可以实现向左,向右移动,按住”w”或”SPACE”可以实现跳跃功能。

image.png

部分的代码如下所示:把跳跃,自旋,左右移动分别写一个函数来进行对应的判别。

void FixedUpdate () {
// 跳跃
if ((Input.GetKeyDown (KeyCode.W) || Input.GetButtonDown ("Jump")) && canJump) {
AudioSource.PlayClipAtPoint (jump, this.transform.position);
rg.velocity = Vector3.up * jumpGravity * Time.deltaTime;
}
if (this.transform.position.y >= 5) {
rg.velocity = new Vector3 (0, 0, 0);
}
}
// Update is called once per frame
void Update () {
if (status > 0)
return;
// 自旋
transform.Rotate (Vector3.right * Time.deltaTime * rotateSpeed);
if (moveStatus > 0) {
if (moveDeltaTime <= 0.1f) {
moveDeltaTime += Time.deltaTime;
this.transform.position = Vector3.Lerp(moveFrom, moveTo, moveDeltaTime / 0.1f);
} else {
moveDeltaTime = 0.0f;
moveStatus = 0;
this.transform.position = moveTo;
}
}
// 左右移动事件响应
if (Input.GetKeyDown (KeyCode.A)) {
moveLeft ();
} else if (Input.GetKeyDown (KeyCode.D)) {
moveRight ();
}
// 渐变
if (colorDeltaTime <= changeColorTime) {
colorDeltaTime += Time.deltaTime;
render.material.color = Color.Lerp (Color.red, Color.yellow, colorDeltaTime / changeColorTime);
} else if (colorDeltaTime <= 2 * changeColorTime) {
colorDeltaTime += Time.deltaTime;
render.material.color = Color.Lerp (Color.yellow,
                                    Color.red,
                                    (colorDeltaTime - changeColorTime) / changeColorTime);
} else {
colorDeltaTime = 0.0f;
}
}
void moveLeft () {
if (transform.position.x > 0 && moveStatus == 0) {
moveFrom = new Vector3(posRightX, transform.position.y, transform.position.z);
moveTo = new Vector3(0, transform.position.y, transform.position.z);
moveStatus = 1;
} else if (transform.position.x == 0 && moveStatus == 0) {
moveFrom = new Vector3(0, transform.position.y, transform.position.z);
moveTo = new Vector3(posLeftX, transform.position.y, transform.position.z);
moveStatus = 1;
}
}
void moveRight () {
if (transform.position.x < 0 && moveStatus == 0) {
moveFrom = new Vector3(posLeftX, transform.position.y, transform.position.z);
moveTo = new Vector3(0, transform.position.y, transform.position.z);
moveStatus = 1;
} else if (transform.position.x == 0 && moveStatus == 0) {
moveFrom = new Vector3(0, transform.position.y, transform.position.z);
moveTo = new Vector3(posRightX, transform.position.y, transform.position.z);
moveStatus = 1;
}
}

3.物体生成和金币实现

金币的生成即是玩家得分的重要关键,也是游戏难度的体现,我们大概设计跑道的44%是金币,金币出现的位置要设计随机,不能简单的都是一排左,或者右,以此来增加游戏的难度,每捡到一个游戏金币,左下面的得分会自动加1.

image.png

部分代码如下所示:

// 控制生成金币统一靠左边或者是靠右边
int coinSide = Random.Range (0f, 1f) <= 0.5f ? -1 : 1;
for (int i = 0; i < 3; i++) {
// 生成一个随机数
float r1 = Random.Range (0f, 1f);
float posX = 0f;
if (r1 <= 0.01f) { // 1%是延时器
posX = Random.Range (-1, 2) * 3f; // 0, -3, 3
addTime5s [addTime5Nums].transform.localPosition = new Vector3 (posX, 1f, 3.5f - i * 3.5f);
addTime5s [addTime5Nums].SetActive (true);
addTime5Nums++;
} else if (r1 <= 0.06f) { // 5%是吸铁石
posX = Random.Range (-1, 2) * 3f; // 0, -3, 3
magnets [magnetNums].transform.localPosition = new Vector3 (posX, 1f, 3.5f - i * 3.5f);
magnets [magnetNums].SetActive (true);
magnetNums++;
} else if (r1 <= 0.50f) { // 44%是金币
int r2 = Random.Range (0, 2) * coinSide;
posX = 3.0f * r2; // x坐标要么是0,要么是±3
coins [coinNums].transform.localPosition = new Vector3 (posX, 0.58f, 3.5f - i * 3.5f);
coins [coinNums].SetActive (true);
coinNums++;
}

4.障碍墙实现

如果一个跑道上没有阻碍物,那么游戏变得索然无味,所以我们在此基础上设置了障碍墙,有的墙宽,有的墙薄一点,墙宽的可以使用”w”进行二段跳,玩家没有跳过去的话,血量将减去20,直到为0则游戏结束。

image.png

部分代码如下所示:

if (r <= 0.02f) { // 2%是陷阱
this.gameObject.SetActive (false);
} else if (r <= 0.12f) { // 10% 是障碍墙
// 生成一堵墙
bool genWide = Random.Range (0f, 1f) <= 0.25; // 生成宽墙的概率为25%
float x;
if (genWide) {
wideWall.transform.localPosition = new Vector3 (0, 1, 0);
wideWall.SetActive (true);
} else {
x = Random.Range (-1, 2) * 2.5f; // 0, -2.5, 2.5
wall.transform.localPosition = new Vector3 (x, 1, 0);
wall.SetActive (true);
}

5游戏计时实现

为了让游戏更具挑战性,我们给游戏添加倒计时功能,就是让玩家在规定时间内,闯关成功并得到的金币最多。

image.png

部分代码如下:

// 倒计时
IEnumerator countDown () {
while (dstGameTime > 0  && status == 0) {
timerText.text = dstGameTime.ToString ();
yield return new WaitForSeconds (1.0f);
dstGameTime--;
timerText.text = dstGameTime.ToString ();
}
if (status == 0)
StopGame (1);
}

6.延时器和陷阱的完善

延时器就是,在跑道上设计大概1%的数量,捡到则可以在倒计时上增加5s,给玩家更多的机会去拾取金币得到更多的分,陷阱的设计意思就是断崖,如果玩家没有跳过去,直接死亡。

image.png

部分代码如下:

if (r1 <= 0.01f) { // 1%是延时器
posX = Random.Range (-1, 2) * 3f; // 0, -3, 3
addTime5s [addTime5Nums].transform.localPosition = new Vector3 (posX, 1f, 3.5f - i * 3.5f);
addTime5s [addTime5Nums].SetActive (true);
addTime5Nums++;
if (r <= 0.02f) { // 2%是陷阱
this.gameObject.SetActive (false);
}

7.吸金石实现

吸金石的作用就是,捡到即可在3s内吸附附近所有的金币,如果连续捡到吸金石,则时间叠加。

image.png

部分代码如下:

else if (r1 <= 0.06f) { // 5%是吸金石
posX = Random.Range (-1, 2) * 3f; // 0, -3, 3
magnets [magnetNums].transform.localPosition = new Vector3 (posX, 1f, 3.5f - i * 3.5f);
magnets [magnetNums].SetActive (true);
magnetNums++
}
相关文章
|
3月前
|
图形学 C#
超实用!深度解析Unity引擎,手把手教你从零开始构建精美的2D平面冒险游戏,涵盖资源导入、角色控制与动画、碰撞检测等核心技巧,打造沉浸式游戏体验完全指南
【8月更文挑战第31天】本文是 Unity 2D 游戏开发的全面指南,手把手教你从零开始构建精美的平面冒险游戏。首先,通过 Unity Hub 创建 2D 项目并导入游戏资源。接着,编写 `PlayerController` 脚本来实现角色移动,并添加动画以增强视觉效果。最后,通过 Collider 2D 组件实现碰撞检测等游戏机制。每一步均展示 Unity 在 2D 游戏开发中的强大功能。
176 6
|
2月前
|
测试技术 C# 图形学
掌握Unity调试与测试的终极指南:从内置调试工具到自动化测试框架,全方位保障游戏品质不踩坑,打造流畅游戏体验的必备技能大揭秘!
【9月更文挑战第1天】在开发游戏时,Unity 引擎让创意变为现实。但软件开发中难免遇到 Bug,若不解决,将严重影响用户体验。调试与测试成为确保游戏质量的最后一道防线。本文介绍如何利用 Unity 的调试工具高效排查问题,并通过 Profiler 分析性能瓶颈。此外,Unity Test Framework 支持自动化测试,提高开发效率。结合单元测试与集成测试,确保游戏逻辑正确无误。对于在线游戏,还需进行压力测试以验证服务器稳定性。总之,调试与测试贯穿游戏开发全流程,确保最终作品既好玩又稳定。
105 4
|
3月前
|
图形学 缓存 算法
掌握这五大绝招,让您的Unity游戏瞬间加载完毕,从此告别漫长等待,大幅提升玩家首次体验的满意度与留存率!
【8月更文挑战第31天】游戏的加载时间是影响玩家初次体验的关键因素,特别是在移动设备上。本文介绍了几种常见的Unity游戏加载优化方法,包括资源的预加载与异步加载、使用AssetBundles管理动态资源、纹理和模型优化、合理利用缓存系统以及脚本优化。通过具体示例代码展示了如何实现异步加载场景,并提出了针对不同资源的优化策略。综合运用这些技术可以显著缩短加载时间,提升玩家满意度。
152 5
|
2月前
|
前端开发 图形学 开发者
【独家揭秘】那些让你的游戏瞬间鲜活起来的Unity UI动画技巧:从零开始打造动态按钮,提升玩家交互体验的绝招大公开!
【9月更文挑战第1天】在游戏开发领域,Unity 是最受欢迎的游戏引擎之一,其强大的跨平台发布能力和丰富的功能集让开发者能够迅速打造出高质量的游戏。优秀的 UI 设计对于游戏至关重要,尤其是在手游市场,出色的 UI 能给玩家留下深刻的第一印象。Unity 的 UGUI 系统提供了一整套解决方案,包括 Canvas、Image 和 Button 等组件,支持添加各种动画效果。
136 3
|
2月前
|
设计模式 存储 人工智能
深度解析Unity游戏开发:从零构建可扩展与可维护的游戏架构,让你的游戏项目在模块化设计、脚本对象运用及状态模式处理中焕发新生,实现高效迭代与团队协作的完美平衡之路
【9月更文挑战第1天】游戏开发中的架构设计是项目成功的关键。良好的架构能提升开发效率并确保项目的长期可维护性和可扩展性。在使用Unity引擎时,合理的架构尤为重要。本文探讨了如何在Unity中实现可扩展且易维护的游戏架构,包括模块化设计、使用脚本对象管理数据、应用设计模式(如状态模式)及采用MVC/MVVM架构模式。通过这些方法,可以显著提高开发效率和游戏质量。例如,模块化设计将游戏拆分为独立模块。
185 3
|
3月前
|
图形学 开发者 存储
超越基础教程:深度拆解Unity地形编辑器的每一个隐藏角落,让你的游戏世界既浩瀚无垠又细节满满——从新手到高手的全面技巧升级秘籍
【8月更文挑战第31天】Unity地形编辑器是游戏开发中的重要工具,可快速创建复杂多变的游戏环境。本文通过比较不同地形编辑技术,详细介绍如何利用其功能构建广阔且精细的游戏世界,并提供具体示例代码,展示从基础地形绘制到植被与纹理添加的全过程。通过学习这些技巧,开发者能显著提升游戏画面质量和玩家体验。
152 3
|
3月前
|
图形学 机器学习/深度学习 人工智能
颠覆传统游戏开发,解锁未来娱乐新纪元:深度解析如何运用Unity引擎结合机器学习技术,打造具备自我进化能力的智能游戏角色,彻底改变你的游戏体验——从基础设置到高级应用全面指南
【8月更文挑战第31天】本文探讨了如何在Unity中利用机器学习增强游戏智能。作为领先的游戏开发引擎,Unity通过ML-Agents Toolkit等工具支持AI代理的强化学习训练,使游戏角色能自主学习完成任务。文章提供了一个迷宫游戏示例及其C#脚本,展示了环境观察、动作响应及奖励机制的设计,并介绍了如何设置训练流程。此外,还提到了Unity与其他机器学习框架(如TensorFlow和PyTorch)的集成,以实现更复杂的游戏玩法。通过这些技术,游戏的智能化程度得以显著提升,为玩家带来更丰富的体验。
64 1
|
3月前
|
图形学 数据可视化 开发者
超实用Unity Shader Graph教程:从零开始打造令人惊叹的游戏视觉特效,让你的作品瞬间高大上,附带示例代码与详细步骤解析!
【8月更文挑战第31天】Unity Shader Graph 是 Unity 引擎中的强大工具,通过可视化编程帮助开发者轻松创建复杂且炫酷的视觉效果。本文将指导你使用 Shader Graph 实现三种效果:彩虹色渐变着色器、动态光效和水波纹效果。首先确保安装最新版 Unity 并启用 Shader Graph。创建新材质和着色器图谱后,利用节点库中的预定义节点,在编辑区连接节点定义着色器行为。
252 0
|
3月前
|
图形学
小功能⭐️获取Unity游戏物体上,所挂载组件的名称
小功能⭐️获取Unity游戏物体上,所挂载组件的名称
|
2月前
|
图形学 C++ C#
Unity插件开发全攻略:从零起步教你用C++扩展游戏功能,解锁Unity新玩法的详细步骤与实战技巧大公开
【8月更文挑战第31天】Unity 是一款功能强大的游戏开发引擎,支持多平台发布并拥有丰富的插件生态系统。本文介绍 Unity 插件开发基础,帮助读者从零开始编写自定义插件以扩展其功能。插件通常用 C++ 编写,通过 Mono C# 运行时调用,需在不同平台上编译。文中详细讲解了开发环境搭建、简单插件编写及在 Unity 中调用的方法,包括创建 C# 封装脚本和处理跨平台问题,助力开发者提升游戏开发效率。
211 0