我在UserControl资源中有两个不同的DataTemplates。一个DataTemplate包含一个图像控件,另一个DataTemplate包含一个媒体元素控件。每个DataTemplate的DataType分别代表一个ImageViewModel和一个VideoViewModel。在我的用户控件中,有一个包含ContentControl的网格。内容控件的content属性绑定到一个属性,该属性表示应使用的当前视图模型。
想法是根据当前视图模型更改网格的内容
<UserControl.Resources>
<DataTemplate DataType="{x:Type vm:ImageScreensaverViewModel}">
<Image Source="{Binding Image}" Stretch="Uniform"/>
</DataTemplate>
<DataTemplate DataType="{x:Type vm:VideoScreensaverViewModel}">
<MediaElement x:Name="Player" Source="{Binding Video}" LoadedBehavior="Play" />
</DataTemplate>
</UserControl.Resources>
<UserControl.CommandBindings>
<CommandBinding Command="MediaCommands.Pause" Executed="PausePlayer" CanExecute="CanExecute"/>
<CommandBinding Command="MediaCommands.Play" Executed="PlayPlayer" CanExecute="CanExecute"/>
</UserControl.CommandBindings>
<Grid>
<ContentControl x:Name="ScreanSaverContent" Content="{Binding CurrentVm}"/>
</Grid>
这很好用,但是我需要在后面的代码中访问MediaElement,以便可以控制媒体播放器(播放,停止,暂停)
我已经尝试过将解决方案发布在hier上,但没有成功。我只能通过content属性访问选定的视图模型。
尝试这段代码到达ContentPresenter内部的控件:
public static FrameworkElement GetControlByName(DependencyObject parent, string name)
{
int count = VisualTreeHelper.GetChildrenCount(parent);
for (var i = 0; i < count; ++i)
{
var child = VisualTreeHelper.GetChild(parent, i) as FrameworkElement;
if (child != null)
{
if (child.Name == name)
{
return child;
}
var descendantFromName = GetControlByName(child, name);
if (descendantFromName != null)
{
return descendantFromName;
}
}
}
return null;
}
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句