【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;
    }
}

运行效果

运行效果如下所示:

相关推荐
程序猿多布2 小时前
XLua教程之Lua调用C#
unity·c#·lua·xlua
唐青枫2 小时前
FluentData 从入门到精通:C#.NET 数据访问最佳实践
c#·.net
张晓~1833994812111 小时前
短视频矩阵源码-视频剪辑+AI智能体开发接入技术分享
c语言·c++·人工智能·矩阵·c#·php·音视频
almighty2713 小时前
C# DataGridView表头自定义设置全攻略
数据库·c#·winform·datagridview·自定义表头
绀目澄清13 小时前
unity UGUI 鼠标画线
unity·计算机外设·游戏引擎
Magnum Lehar14 小时前
3d wpf游戏引擎的导入文件功能c++的.h实现
3d·游戏引擎·wpf
作孽就得先起床14 小时前
unity pcd 二进制版 简单显示文件对象(单色)
unity·游戏引擎
arbboter15 小时前
【自动化】深入浅出UIAutomationClient:C#桌面自动化实战指南
运维·c#·自动化·inspect·uiautomation·uia·桌面自动化
文弱书生65616 小时前
5.后台运行设置和包设计与实现
服务器·开发语言·c#
大飞pkz19 小时前
【设计模式】题目小练2
开发语言·设计模式·c#·题目小练