【Godot4.1】Godot实现闪烁效果(Godot使用定时器实现定时触发的效果)

文章目录

准备工作

如果你希望配置C#编写脚本,可以查看如下教程:
Godot配置C#语言编写脚本

创建Sprite2D

首先弄一个用于显示的Sprite2D,右键单击任意节点,然后选择添加子节点,接着选择Sprite2D,如下图所示。

创建Timer节点

与上一小节一样,创建Timer节点。

编写脚本

然后在 _Ready() 方法中获取目标 Sprite2D 节点并设置 Timer,代码如下。

csharp 复制代码
	[Export]
    public NodePath TargetNodePath;

    private Sprite2D targetSprite;
    private Timer timer;
        public override void _Ready()
    {
        targetSprite = GetNode<Sprite2D>(TargetNodePath);
        timer = GetNode<Timer>("Timer");
        // 启动闪烁效果
        StartBlinking();
    }
        private void StartBlinking()
    {
        // 每 0.5 秒切换可见性
        timer.WaitTime = 0.5f;
        timer.OneShot = false;
        timer.Start();
		timer.Timeout+=OnTimerTimeout;
    }

    private void OnTimerTimeout()
    {
        targetSprite.Visible = !targetSprite.Visible;
    }

在上面代码中,我们定义了 StartBlinking() 方法,该方法会设置 Timer 的等待时间和循环触发,并连接 Timer 的 timeout 信号到 OnTimerTimeout() 方法。

当我们设置 timer.WaitTime = 0.5f; 时,指定了 Timer 的等待时间为 0.5 秒。这意味着 Timer 将在每次触发之前等待 0.5 秒。接下来,设置 timer.OneShot = false;,这表示 Timer 将在完成一次计时后不会停止。当 Timer 完成一次计时后,会再次等待指定的时间后继续触发。简单点讲,通过设置 timer.OneShot = false;,我们创建了一个重复触发的 Timer。

信号部分就是委托,如果不明白,可以看如下教程:
Godot信号教程

OnTimerTimeout() 方法会在 Timer 的 timeout 信号触发时切换目标 Sprite 的可见性。通过调用 StartBlinking() 方法启动闪烁效果。

接着回到编辑器中,在检查器中找到BlinkingEffect脚本的属性,点击一下Target Node Path属性,在弹出的窗口中选择Sprite2D节点,即可为其赋值。

运行后,你可以看到目标 Sprite2D 将会以 0.5 秒的间隔闪烁显示和隐藏。

完整代码

完整代码如下所示:

csharp 复制代码
using Godot;
using System;

public partial class BlinkingEffect : Node
{
	[Export]
    public NodePath TargetNodePath;

    private Sprite2D targetSprite;
    private Timer timer;

    public override void _Ready()
    {
        targetSprite = GetNode<Sprite2D>(TargetNodePath);
        timer = GetNode<Timer>("Timer");

        // 启动闪烁效果
        StartBlinking();
    }

    private void StartBlinking()
    {
        // 每 0.5 秒切换可见性
        timer.WaitTime = 0.5f;
        timer.OneShot = false;
        timer.Start();
		timer.Timeout+=OnTimerTimeout;
    }

    private void OnTimerTimeout()
    {
        targetSprite.Visible = !targetSprite.Visible;
    }
}

运行效果

运行效果如下所示:

相关推荐
▍ 小太阳 ☼18 小时前
Unity2022Navigation系统打开方式
unity·游戏引擎
c#上位机18 小时前
wpf之MVVM中只读属性更新界面
c#·wpf·mvvm
技术支持者python,php21 小时前
winform本地上位机-ModbusRTC1.上位机控制台与数据监控(数据监控架构思维与图表系列)
c#
qq_1702647521 小时前
unity升级对ab变更的影响
unity·游戏引擎
AA陈超1 天前
虚幻引擎5 GAS开发俯视角RPG游戏 P05-04 使用效果应用游戏标签
c++·游戏·ue5·游戏引擎·虚幻
kalvin_y_liu1 天前
DeploySharp开源发布:让C#部署深度学习模型更加简单
深度学习·开源·c#
不伤欣1 天前
Unity Mask镂空效果(常用于新手引导或高亮显示UI元素)
游戏·ui·unity·游戏引擎
c#上位机1 天前
wpf之GroupBox
c#·wpf
CodeCraft Studio1 天前
国产化PDF处理控件Spire.PDF教程:C#中轻松修改 PDF 文档内容
前端·pdf·c#·.net·spire.pdf·编辑pdf·修改pdf
mit6.8241 天前
[C# starter-kit] Domain Entities | `AuditableEntity`基类 | 跟踪变化 | 软删除
数据库·microsoft·c#