avalondock mvvm

#mvvm #datacontext #avalondock

#mvvm #datacontext #avalondock

Вопрос:

Использование avalondock кажется довольно сложным в среде MVVM. Как только я отсоединяю DocumentPane от shellview, я теряю соответствующий datacontext и мое представление становится пустым. При повторном подключении все возвращается в нормальное состояние.

Есть ли у кого-нибудь решение?

Комментарии:

1. Пожалуйста, взгляните сюда в документации AvalonDock.

2. Я написал статью, которая демонстрирует один из способов интеграции AvalonDock в приложение MVVM: codeproject.com/Articles/239342/AvalonDock-and-MVVM

Ответ №1:

Вот что я использую в настоящее время; в моем приложении есть пара закрепляемых панелей, каждая из которых имеет свою собственную viewmodel. Эти viewmodels отображаются как свойства из viewmodel главного окна, которое также является DataContext главного окна. Хитрость заключается в том, чтобы ссылаться на этот datacontext с помощью статического приложения.Главное окно текущего экземпляра.DataContext.

Например:

 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>
  

Не уверен, как это работает для больших модульных приложений, но я видел пример приложения в Prism, используемого с Sofa (оболочкой AvalonDock), поэтому вы, возможно, захотите проверить, как они это сделали.