GFramework/GFramework.Game/ui/handler/LoggingTransitionHandler.cs
GeWuYou 65d56d0696 refactor(scene): 重构场景路由系统并迁移资源注册接口
- 将场景路由基类从同步改为异步实现,支持场景栈管理
- 添加场景行为接口定义及相关的进入参数接口
- 实现场景的压入、弹出、替换和清空等栈操作功能
- 迁移UI资源注册接口到资产模块下
- 移除缓存淘汰策略枚举并更新UI切换阶段命名空间引用
- 优化日志记录器创建方式和统一命名空间规范
2026-02-15 16:59:09 +08:00

48 lines
1.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.Abstractions.logging;
using GFramework.Core.logging;
using GFramework.Game.Abstractions.enums;
using GFramework.Game.Abstractions.ui;
namespace GFramework.Game.ui.handler;
/// <summary>
/// 日志UI切换处理器用于记录UI切换的详细信息
/// </summary>
public sealed class LoggingTransitionHandler : UiTransitionHandlerBase
{
/// <summary>
/// 日志记录器实例用于记录UI切换相关信息
/// </summary>
private static readonly ILogger Log = LoggerFactoryResolver.Provider.CreateLogger(nameof(LoggingTransitionHandler));
/// <summary>
/// 获取处理器优先级,数值越大优先级越高
/// </summary>
public override int Priority => 999;
/// <summary>
/// 获取处理器处理的UI切换阶段处理所有阶段
/// </summary>
public override UiTransitionPhases Phases => UiTransitionPhases.All;
/// <summary>
/// 处理UI切换事件的异步方法
/// </summary>
/// <param name="event">UI切换事件对象包含切换的相关信息</param>
/// <param name="cancellationToken">取消令牌,用于控制异步操作的取消</param>
/// <returns>表示异步操作的任务</returns>
public override Task HandleAsync(UiTransitionEvent @event, CancellationToken cancellationToken)
{
// 记录UI切换的详细信息到日志
Log.Info(
"UI Transition: Phases={0}, Type={1}, From={2}, To={3}, Policy={4}",
@event.Get<string>("Phases", "Unknown"),
@event.TransitionType,
@event.FromUiKey,
@event.ToUiKey ?? "None",
@event.Policy
);
return Task.CompletedTask;
}
}