Godot Engine:Flappy Bird中小鸟死亡后弹窗的制作

0305210203 学生2021 2023-06-20 23:50:02

 

https://blog.csdn.net/dyf1055318607/article/details/130142632

本篇文章写的是是开发游戏的老王留的课后练习,项目的前一部分是老王上课做的,哈哈!

在做之前先来看一看做弹窗需要用到的节点类型吧

TextureRect类型:用于在UI上显示图片
Label类型:用于显示UI上显示成绩
AnimationPlayer类型:信息板动画容器

 1、搭建如下图的场景树

将素材中的score.png图片添加到TextureRect的Texture中 

 启用Expand,然后按住Shift将得分板拖拽到合适的大小,移动到窗口下面 

将显示窗口分别移动到对应位置,并且在Text中任意输入内容,方便我们调整位置和字体大小。

将Label best和Label score中属性中的Align和V Align均设置为center。

Align:控制文本的水平对齐。支持左对齐、居中对齐、右对齐和填充,或者两端对齐。

V Align:控制文本的垂直对齐。支持顶部、中心、底部和填充。

 字体设置 

 给TextureRect添加AnimationPlayer节点

设置AnimationPlayer

一共需要两个动画,一个是游戏进行时得分板隐藏的动画,一个是游戏结束后展示得分板的动画

得分板显示

该动画博主做了10帧,得分板从下向上弹出

 

 具体的操作步骤如下

将动画进度条拖拽到第0帧处,插入关键帧

将动画进度条拖拽到第10帧,将得分板移动到最终位置,插入关键帧 

得分板隐藏

该动画只需要1帧,操作方法和上图一致

最后一步,也是最重要的一步啦,那就是代码控制

在此之前,先对老王项目里的GameData.gd的代码稍稍改动一下啪,因为试了好多种写法,总会报错。

 

 

 给Texture Rect添加脚本代码内容如下


 
  1. extends TextureRect

  2.  
  3. func _ready():

  4. add_to_group("GAME_OVER")

  5.  
  6. func on_game_over():

  7. $Labelscore.text=str(GameData.Score)

  8. $Labelbest.text=str(GameData.record)

  9. $AnimationPlayer.play("show")

 下面我们来看看结果

 

 

...全文
331 回复 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

137

社区成员

发帖
与我相关
我的任务
社区描述
游戏开发教学区
开发语言 高校
社区管理员
  • 开发游戏的老王
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧