如何使用AvalonDock 2.0在不自动隐藏的情况下创建底部面板
本文关键字:情况下 隐藏 创建 底部 AvalonDock 何使用 | 更新日期: 2023-09-27 18:25:35
我正在使用AvalonDock 2.0
我觉得这应该是非常基本的,但文档上什么都没说,我已经玩了两个小时试图弄清楚。所以,如果这太简单,我很抱歉。
我想要的正是标题所说的。文档中提到了如何制作底部面板,但只是一个自动隐藏的面板,这不是我想要的。
我试图在代码后面切换它的自动隐藏,但高度没有受到影响,所以每次启动应用程序时,用户都必须将其向上拖动才能看到面板的内容。
有点古怪,但这对我有效:
<xcad:DockingManager x:Name="DockingManager" Grid.Row="1" DocumentsSource="{Binding Documents}" Loaded="DockingManager_OnLoaded">
<xcad:LayoutRoot>
<xcad:LayoutPanel Orientation="Horizontal">
<xcad:LayoutDocumentPane></xcad:LayoutDocumentPane>
<xcad:LayoutAnchorablePane DockWidth="Auto" SelectedContentIndex="0">
<xcad:LayoutAnchorable Title="Right">
<Label>Right</Label>
</xcad:LayoutAnchorable>
</xcad:LayoutAnchorablePane>
</xcad:LayoutPanel>
<xcad:LayoutRoot.BottomSide>
<xcad:LayoutAnchorSide>
<xcad:LayoutAnchorGroup>
<xcad:LayoutAnchorable x:Name="OutputAnchorable" Title="Output">
<Label>Bottom</Label>
</xcad:LayoutAnchorable>
</xcad:LayoutAnchorGroup>
</xcad:LayoutAnchorSide>
</xcad:LayoutRoot.BottomSide>
</xcad:LayoutRoot>
</xcad:DockingManager>
然后在后面的代码中:
private void DockingManager_OnLoaded(object sender, RoutedEventArgs e)
{
OutputAnchorable.ToggleAutoHide();
// You might want to do this to get a reasonable height
var root = (LayoutAnchorablePane)OutputAnchorable.Parent;
root.DockHeight = new GridLength(100);
}
您需要这样的
<xcad:LayoutPanel Orientation="Vertical">
<xcad:LayoutPanel Orientation="Horizontal" >
</xcad:LayoutPanel>
</xcad:LayoutPanel>
第二个布局将创建所有混合面板,第一个布局将以垂直方式创建顶部或底部