GFramework/GFramework.Godot/Text/Effects/RichTextFlyInEffect.cs
GeWuYou e5ad29314e feat(text): 添加富文本效果系统和颜色标记功能
- 实现 RichTextEffectBase 基类提供统一的标签命名和参数读取逻辑
- 添加 RichTextBlueEffect、RichTextGoldEffect、RichTextGreenEffect 和 RichTextRedEffect 颜色标记效果
- 添加 RichTextFadeInEffect、RichTextFlyInEffect、RichTextJitterEffect 和 RichTextSineEffect 动画效果
- 实现 DefaultRichTextEffectRegistry 默认效果注册表
- 创建 GfRichTextLabel 富文本标签宿主组件
- 添加 IRichTextEffectRegistry 效果注册表接口
- 实现 RichTextEffectEntry、RichTextEffectsController 和 RichTextProfile 配置管理类
- 添加 RichTextMarkup 语义化标签构建辅助方法
- 创建 RichTextMarkupTests 和 RichTextProfileTests 单元测试
2026-04-18 11:58:40 +08:00

65 lines
1.9 KiB
C#

namespace GFramework.Godot.Text.Effects;
/// <summary>
/// 为文本提供逐字符飞入效果。
/// </summary>
[GlobalClass]
[Tool]
public partial class RichTextFlyInEffect : RichTextEffectBase
{
private readonly bool _animatedEffectsEnabled;
/// <summary>
/// 初始化飞入效果。
/// </summary>
/// <param name="animatedEffectsEnabled">是否允许动态效果实际生效。</param>
public RichTextFlyInEffect(bool animatedEffectsEnabled = true)
{
_animatedEffectsEnabled = animatedEffectsEnabled;
}
/// <summary>
/// 获取标签名。
/// </summary>
protected override string TagName => "fly_in";
/// <summary>
/// 应用飞入动画。
/// </summary>
/// <param name="charFx">当前字符上下文。</param>
/// <returns>始终返回 <see langword="true" />。</returns>
public override bool _ProcessCustomFX(CharFXTransform charFx)
{
if (!_animatedEffectsEnabled)
{
return true;
}
var startOffset = new Vector2(
GetFloat(charFx, "offset_x", 12f),
GetFloat(charFx, "offset_y", 0f));
var speed = GetFloat(charFx, "speed", 3.0f);
var tick = GetFloat(charFx, "tick", 0.015f);
var progress = Mathf.Clamp((float)(charFx.ElapsedTime * speed - charFx.RelativeIndex * tick), 0f, 1f);
var eased = EaseOutQuad(progress);
charFx.Offset += startOffset * (1f - eased);
var color = charFx.Color;
color.A = eased;
charFx.Color = color;
ApplyVisibility(charFx);
return true;
}
/// <summary>
/// 计算二次缓出值。
/// </summary>
/// <param name="value">归一化进度。</param>
/// <returns>缓出后的进度。</returns>
private static float EaseOutQuad(float value)
{
return 1f - (1f - value) * (1f - value);
}
}