GeWuYou 9c27aa5927 feat(ui): 添加对已存在UI页面的路由推送支持
- 在UiRouterBase中新增Push方法重载,支持直接推送已创建的IUiPageBehavior实例
- 统一页面推送逻辑到DoPushPageInternal方法,同时处理工厂创建和现有页面
- 更新Replace方法使用新的页面推送逻辑
- 优化日志输出,统一使用View.GetType().Name获取页面类型名称
- 为新功能添加完整的XML文档注释
- 在IUiRouter接口中定义新的Push方法重载签名
2026-01-19 22:00:00 +08:00

94 lines
3.2 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.system;
using GFramework.Game.Abstractions.enums;
namespace GFramework.Game.Abstractions.ui;
/// <summary>
/// UI路由管理器接口用于管理UI界面的导航和切换操作
/// </summary>
public interface IUiRouter : ISystem
{
/// <summary>
/// 获取当前UI栈深度
/// </summary>
int Count { get; }
/// <summary>
/// 绑定UI根节点
/// </summary>
/// <param name="root">UI根节点接口实例</param>
void BindRoot(IUiRoot root);
/// <summary>
/// 将指定的UI界面压入路由栈显示新的UI界面
/// </summary>
/// <param name="uiKey">UI界面的唯一标识符</param>
/// <param name="param">进入界面的参数,可为空</param>
/// <param name="policy">界面切换策略默认为Exclusive独占</param>
void Push(string uiKey, IUiPageEnterParam? param = null, UiTransitionPolicy policy = UiTransitionPolicy.Exclusive);
/// <summary>
/// 将已存在的UI页面压入路由栈
/// 用于预挂载节点或调试场景
/// </summary>
/// <param name="page">已创建的UI页面行为实例</param>
/// <param name="param">进入界面的参数,可为空</param>
/// <param name="policy">界面切换策略,默认为Exclusive(独占)</param>
void Push(IUiPageBehavior page, IUiPageEnterParam? param = null,
UiTransitionPolicy policy = UiTransitionPolicy.Exclusive);
/// <summary>
/// 弹出路由栈顶的UI界面返回到上一个界面
/// </summary>
/// <param name="policy">界面弹出策略默认为Destroy销毁</param>
void Pop(UiPopPolicy policy = UiPopPolicy.Destroy);
/// <summary>
/// 替换当前UI界面为指定的新界面
/// </summary>
/// <param name="uiKey">新UI界面的唯一标识符</param>
/// <param name="param">进入界面的参数,可为空</param>
/// <param name="popPolicy">界面弹出策略,默认为销毁当前界面</param>
/// <param name="pushPolicy">界面过渡策略,默认为独占模式</param>
void Replace(
string uiKey,
IUiPageEnterParam? param = null,
UiPopPolicy popPolicy = UiPopPolicy.Destroy,
UiTransitionPolicy pushPolicy = UiTransitionPolicy.Exclusive
);
/// <summary>
/// 清空所有UI界面重置路由状态
/// </summary>
void Clear();
/// <summary>
/// 注册UI切换处理器
/// </summary>
/// <param name="handler">处理器实例</param>
/// <param name="options">执行选项</param>
void RegisterHandler(IUiTransitionHandler handler, UiTransitionHandlerOptions? options = null);
/// <summary>
/// 注销UI切换处理器
/// </summary>
/// <param name="handler">处理器实例</param>
void UnregisterHandler(IUiTransitionHandler handler);
/// <summary>
/// 获取当前栈顶UI的Key
/// </summary>
/// <returns>当前UI Key如果栈为空返回空字符串</returns>
string Peek();
/// <summary>
/// 判断指定UI是否为当前栈顶UI
/// </summary>
bool IsTop(string uiKey);
/// <summary>
/// 判断指定UI是否存在于UI栈中
/// </summary>
bool Contains(string uiKey);
}