如何使用AvalonDock 2.0在不自动隐藏的情况下创建底部面板

本文关键字:情况下 隐藏 创建 底部 AvalonDock 何使用 | 更新日期: 2023-09-27 18:25:35

我正在使用AvalonDock 2.0

我觉得这应该是非常基本的,但文档上什么都没说,我已经玩了两个小时试图弄清楚。所以,如果这太简单,我很抱歉。

我想要的正是标题所说的。文档中提到了如何制作底部面板,但只是一个自动隐藏的面板,这不是我想要的。

我试图在代码后面切换它的自动隐藏,但高度没有受到影响,所以每次启动应用程序时,用户都必须将其向上拖动才能看到面板的内容。

如何使用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>

第二个布局将创建所有混合面板,第一个布局将以垂直方式创建顶部或底部