Вот что я использую сейчас;мое приложение имеет пару закрепляемых панелей, каждая из которых имеет свою собственную модель просмотра.Эти модели представления представлены в виде свойств из модели представления главного окна, которая также является DataContext главного окна.Хитрость заключается в обращении к этому текстовому тексту с использованием статического Main.indow.DataContext экземпляра Application.Current.
Например:
class MainWindowViewModel
{
public WindowAViewModel {get; set;}
public WindowBViewModel {get; set;}
}
//this goes in App.xaml.cs, because my MainWindowViewModel has a constructor
//with arguments, else you could just set the Window.DataContext in xaml
var window = new MainWindow();
window.DataContext = new MainWindowViewModel( ... );
xaml MainWindow:
<ad:DockingManager>
<ad:ResizingPanel Orientation="Horizontal" >
<ad:DockablePane>
<ad:DockableContent>
<l:WindowA DataContext="{Binding Path=MainWindow.DataContext.WindowAViewModel,
Source={x:Static app:App.Current}}"/>
</ad:DockableContent>
<ad:DockableContent>
<l:WindowB DataContext="{Binding Path=MainWindow.DataContext.WindowBViewModel,
Source={x:Static app:App.Current}}"/>
</ad:DockableContent>
</ad:DockablePane>
</ad:ResizingPanel>
</ad:DockingManager>
Notхотя я уверен, что это работает для больших модульных приложений, но я видел пример приложения в Prism, который используется с Sofa (оболочкой AvalonDock), так что вы можете проверить, как они это сделали.