如何在LayoutAnchorable AvalonDock 2中放置窗口实例

时间:2012-12-11 18:54:39

标签: c# wpf xaml avalondock

我正在将WPF C#应用程序(不是MVVM)中的AvalonDock从1.3升级到2.0。在1.3中,只要使用了DockableContent,我就可以放置自定义窗口: XAML:

<!--<Window-->
<ad:DockableContent   x:Class="Test.JournalWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:ad="clr-namespace:AvalonDock;assembly=AvalonDock" 
        xmlns:local="clr-namespace:Test"
        xmlns:sys="clr-namespace:System;assembly=mscorlib"

        Loaded="Journal_Loaded" StateChanged="Journal_StateChanged"
        Title="Journal" Icon = "Resources/journalLog.ico" HideOnClose="True" Height="300" Width="Auto">

    <ad:DockableContent.Resources>
      </ad:DockableContent.Resources>

                <Grid>  </Grid>
</ad:DockableContent>
<!--</Window>-->

代码背后:

public partial class JournalWindow : DockableContent
    {
        public JournalWindow()
        {
            InitializeComponent();
        }

MainWindow中的代码显示即时元素:

JournalWindow journalWindow;
 journalWindow = new JournalWindow()
            {
                Name = nameJournalWindow,
                Title = "Journal"
            };

            journalWindow.IsCloseable = true;
            journalWindow.HideOnClose = true;
            journalWindow.Show(dockManager);

如何使用AvalonDock 2在LayoutAnchorable或其他布局元素(以前称为DockableContent)中放置和显示JournalWindow的实例?

1 个答案:

答案 0 :(得分:4)

AvalonDock在新版本中发生了很大变化。在AD 2.0中,您有两个选择: 1)最简单的方法是创建一个标准的UserControl(在你的情况下,JournalWindow派生自UserControl而不是DockableContent)并将控件放在LayoutAnchorable(作为其内容)中。 示例代码:

<UserControl x:Class="Test.JournalWindow" ...>
...
</UserControl>

<LayoutAnchorable Title="My Journal Window">
   <testNamespace:JournalWindow/>
</LayoutAnchorable>

2)推荐的方法是使用MVVM方法,为此,我将指向附加到AvalonDock库的示例项目MVVMTestApp: http://avalondock.codeplex.com/downloads/get/558780

腺苷