GFramework/GFramework.Godot/input/AbstractGodotInputModule.cs
GwWuYou 028ece27db ```
refactor(input): 重构Godot输入模块为抽象基类并优化输入处理流程

将 `GodotInputModule` 重命名为 `AbstractGodotInputModule` 并改为抽象类,
以便支持更灵活的输入翻译器注册机制。引入 `GodotInputPhase` 枚举和
`GodotRawInput` 结构体以区分输入处理的不同阶段(捕获与冒泡)。
同时修改 `GodotInputTranslator` 仅在Bubble阶段生成游戏事件,提升输入处理精度。
```
2025-12-21 16:52:36 +08:00

82 lines
2.7 KiB
C#
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

using GFramework.Core.architecture;
using GFramework.Core.constants;
using GFramework.Game.input;
using GFramework.Godot.architecture;
using GFramework.Godot.extensions;
using Godot;
namespace GFramework.Godot.input;
/// <summary>
/// Godot输入模块类用于管理Godot游戏引擎中的输入系统
/// </summary>
/// <typeparam name="T">架构类型必须继承自Architecture且具有无参构造函数</typeparam>
public abstract class AbstractGodotInputModule<T> : AbstractGodotModule<T>
where T : Architecture<T>, new()
{
private GodotInputBridge? _node;
/// <summary>
/// 启用默认的输入转换器
/// </summary>
protected virtual bool EnableDefaultTranslator => false;
/// <summary>
/// 架构锚点节点的唯一标识名称
/// 用于在Godot场景树中创建和查找架构锚点节点
/// </summary>
private const string GodotInputBridgeName = $"__${GFrameworkConstants.FrameworkName}__GodotInputBridge__";
/// <summary>
/// 获取模块对应的节点对象
/// </summary>
/// <exception cref="InvalidOperationException">当节点尚未创建时抛出异常</exception>
public override Node Node => _node
?? throw new InvalidOperationException("Node not created yet");
private InputSystem _inputSystem = null!;
/// <summary>
/// 当模块被附加到架构时调用此方法
/// </summary>
/// <param name="architecture">要附加到的架构实例</param>
public override void OnAttach(Architecture<T> architecture)
{
// 创建Godot输入桥接节点并绑定输入系统
_node = new GodotInputBridge { Name = GodotInputBridgeName };
_node.Bind(_inputSystem);
}
/// <summary>
/// 当模块从架构中分离时调用此方法
/// </summary>
public override void OnDetach()
{
// 释放节点资源并清理引用
Node.QueueFreeX();
_node = null;
}
/// <summary>
/// 安装模块时调用此方法,用于获取所需的系统组件
/// </summary>
/// <param name="architecture">当前架构实例</param>
public override void Install(IArchitecture architecture)
{
// 从架构中获取输入系统实例
_inputSystem = architecture.GetSystem<InputSystem>()!;
if (EnableDefaultTranslator)
{
// 注册输入转换器
_inputSystem.RegisterTranslator(new GodotInputTranslator(), true);
}
RegisterTranslator(_inputSystem);
}
/// <summary>
/// 注册翻译器的抽象方法,由子类实现具体的注册逻辑
/// </summary>
/// <param name="inputSystem">输入系统实例</param>
protected abstract void RegisterTranslator(InputSystem inputSystem);
}