我对在Prism中实现这一点感到困惑。我在一个班轮中的场景是如何在视图中实现棱镜导航(regionManager.RequestNavigate),该视图在主窗口上显示为单独的模态/非模态窗口。
从this article获取一些代码,我现在可以显示一个单独的窗口,但我对在所显示的窗口区域中导航非常困惑。我会尝试在下面提供一些代码来澄清我的情况。
RoomBandViewModel 中的此代码启动对话框
private void ManageRoomFacility() {
dialogService.ShowDialog<RoomFacilityMainWindowView>(this, container.Resolve<RoomFacilityMainWindowView>());
regionManager.RequestNavigate(RegionNames.Main_Region, new Uri("RoomFacilityMainView", UriKind.Relative));
可以看出,我启动了显示View的Dialog(代码如下所示),然后尝试在View的一个区域中导航
弹出窗口 RoomFacilityMainWindowView
<Window x:Class="HotelReservation.Main.View.RoomFacilities.RoomFacilityMainWindowView"
<view:RoomFacilityMainView
prism:RegionManager.RegionName="{x:Static const:RegionNames.Window_Main_Region}"/>
</Window>
窗口内的UserControl( RoomFacilityMainView )
<UserControl x:Class="HotelReservation.Main.View.RoomFacilities.RoomFacilityMainView"
<Grid VerticalAlignment="Stretch" >
...
<Border Grid.Column="0" Style="{StaticResource RegionBorderStyle}">
<StackPanel>
<TextBlock Text="Some Sample Text"/>
<ContentControl prism:RegionManager.RegionName="{x:Static const:RegionNames.Window_List_Region}"
/>
</StackPanel>
</Border>
<GridSplitter Width="5" Grid.Column="1" HorizontalAlignment="Stretch" />
<Border Grid.Column="2" Style="{StaticResource RegionBorderStyle}" >
<TabControl x:Name="Items" Margin="5" prism:RegionManager.RegionName="{x:Static const:RegionNames.Window_Edit_Region}" />
</Border>
</Grid>
</UserControl>
背后的代码( RoomFacilityMainView.xaml.cs )
public partial class RoomFacilityMainView : UserControl {
public RoomFacilityMainView() {
InitializeComponent();
RoomFacilityMainViewModel viewModel = this.DataContext as RoomFacilityMainViewModel;
if (viewModel == null) {
viewModel = ServiceLocator.Current.GetInstance<RoomFacilityMainViewModel>();
this.DataContext = viewModel;
}
}
}
RoomFacilityMainViewModel 公共类RoomFacilityMainViewModel:BindableBase {
IRegionManager regionManager;
IUnityContainer container;
public RoomFacilityMainViewModel(IRegionManager regionManager, IUnityContainer container) {
this.regionManager = regionManager;
this.container = container;
regionManager.RequestNavigate(RegionNames.Window_List_Region, new Uri("RoomFacilityListView", UriKind.Relative));
}
}
使用此代码不会发生导航,我只是得到一个空白窗口。应显示RoomFacilityListView.xaml的内容,但其空白。
如果代码令人困惑,那么请提供有关如何导航(使用RequestNavigate)和View的具有区域但通过Dialog Service显示为单独窗口而不是MainWindow(Shell)的建议。
答案 0 :(得分:0)
如果您正在使用通过IDialogService
方法显示新窗口的Window.ShowDialog()
实施,那么您的导航无法正常工作就不足为奇了。 ShowDialog()
方法仅在关闭窗口时返回,因此您的导航请求实际上将在关闭的窗口上处理,特别是在窗口关闭后。
模态窗口中没有任何特殊内容可以防止在其中使用棱镜区域和导航。一个限制是您不能创建多个窗口实例&#34;因为它们都具有相同名称的区域,并且使用一个区域管理器是不可能的。但是,有一个解决方案:范围内的区域经理。
假设您不打算创建多个实例,以下是一个示例,您如何解决问题。
首先,您必须确保您的模态对话框RegionManager
与您的主RegionManager
是同一个实例(我在这里使用MEF,但实际上并没有&#39} ;重要):
[Export]
public partial class Dialog : Window
{
private readonly IRegionManager rm;
[ImportingConstructor]
public Dialog(IRegionManager rm)
{
this.InitializeComponent();
this.rm = rm;
// Don't forget to set the attached property to the instance value
RegionManager.SetRegionManager(this, this.rm);
}
}
现在,使用接受导航回调的方法扩展对话框服务实现:
bool? ShowDialog<T>(object ownerViewModel, object viewModel, Action initialNavigationCallback = null) where T : Window
{
Window dialog = /* your instance creation code, e.g. using container */;
dialog.Owner = FindOwnerWindow(ownerViewModel);
dialog.DataContext = viewModel;
if (initialNavigationCallback != null)
{
dialog.Loaded += (s, e) => initialNavigationCallback();
}
return dialog.ShowDialog();
}
这将为您提供显示带有初始导航请求的对话框的可能性,您可以调用它,例如像这样:
void ManageRoomFacility() {
dialogService.ShowDialog<RoomFacilityMainWindowView>(
this,
container.Resolve<RoomFacilityMainWindowView>(),
() => regionManager.RequestNavigate(
RegionNames.Main_Region,
new Uri("RoomFacilityMainView", UriKind.Relative))
);
或者,您可以使用state based navigation执行任务。 State-Based Navigation QuickStart中有发送消息模式对话框的示例实现。
<prism:InteractionRequestTrigger SourceObject="{Binding SendMessageRequest}">
<prism:PopupWindowAction IsModal="True">
<prism:PopupWindowAction.WindowContent>
<vs:SendMessagePopupView />
</prism: PopupWindowAction.WindowContent>
</prism:PopupWindowAction>
</prism:InteractionRequestTrigger>