Avalonia 本身不内置 Docking 功能,需通过第三方库 Avalonia.Dock 实现专业停靠界面;它支持拖拽、标签页、布局序列化,模仿 Visual Studio 布局体验,是当前最成熟稳定的方案。
Avalonia 本身不内置 Docking(停靠)功能,但可以通过第三方库 Avalonia.Dock 实现专业、可拖拽、可停靠、支持标签页和布局序列化的多窗格界面。它模仿 Visual Studio 或 Rider 的布局体验,是目前 Avalonia 生态中最成熟稳定的停靠方案。
在项目中通过 NuGet 安
装核心包:
安装后,在 XAML 中添加命名空间引用:
核心是 DockManager + LayoutRoot + LayoutPanel + LayoutDocumentPane / LayoutAnchorablePane。典型结构如下:
每个可停靠窗口需封装为 LayoutAnchorable,并设置 Title、Icon、CanFloat、CanAutoHide 等属性:
注意:LayoutAnchorable 必须放在 LayoutAnchorablePane 内,或由 DockManager 动态添加(例如通过菜单命令打开)。
调用 DockManager.Save() 可序列化当前布局为 XML 字符串;DockManager.Load(xml) 可还原。建议在应用退出前保存到本地文件,启动时尝试加载:
AppData 目录下的 JSON/XML 文件LayoutContent 类型反序列化失败问题——确保所有自定义视图类型已注册或可通过默认构造函数实例化