嗨,我正在尝试使用触发器绑定可见性,当图像对象为空时,可见性应隐藏。
<Style TargetType="{x:Type local:DirectoryTreeView}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type local:DirectoryTreeView}">
<Border Background="{TemplateBinding Background}"
BorderBrush="{TemplateBinding BorderBrush}"
BorderThickness="{TemplateBinding BorderThickness}">
<TreeView Name="PART_DirectoryTree">
<TreeView.ItemContainerStyle>
<Style TargetType="TreeViewItem">
<Setter Property="IsExpanded" Value="{Binding StartExpanded}"></Setter>
<Style.Triggers>
<DataTrigger Binding="{Binding Path=Source, Source=Icon}">
<Setter Property="Visibility" Value="Hidden"></Setter>
</DataTrigger>
</Style.Triggers>
</Style>
</TreeView.ItemContainerStyle>
<TreeView.ItemTemplate>
<HierarchicalDataTemplate ItemsSource="{Binding Children}">
<StackPanel Orientation="Horizontal">
<Image Name="Icon" Width="16" Height="16" Source="{Binding Image}"/>
<TextBlock Text=" "></TextBlock>
<TextBlock Text="{Binding HeaderText}"></TextBlock>
</StackPanel>
</HierarchicalDataTemplate>
</TreeView.ItemTemplate>
</TreeView>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
到目前为止,我已经尝试了触发器和数据触发器,第一次尝试在数据触发器中的setter上使用targetname属性,但后来我遇到了编译器错误。
不工作==>
<datatrigger binding={binding Image}>
<setter targetname="Icon" property="Visibility" value="Hidden"/>
</datatrigger>
有人可以告诉我如何正确完成此绑定吗?
您可以
创建默认Image
并使用TargetNullValue
,如果源将为空:
<BitmapImage x:Key="ErrorImage" UriSource="Images/Error.png" />
<Image Source="{Binding Path=Image,
TargetNullValue={StaticResource ErrorImage}}" />
如果您接近它,它将比转换器更容易使用。
我使用完全不同的方法解决了这个问题,在图像上使用值转换器。
public class VisibilityConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, CultureInfo culture)
{
var hiddenType = parameter.ToString().ToLowerInvariant() == "collapsed"
? Visibility.Collapsed
: Visibility.Hidden;
return value == null ? hiddenType : Visibility.Visible;
}
public object ConvertBack(object value, Type targetType, object parameter, CultureInfo culture)
{
throw new Exception("Cannot convert back from visibility to object.");
}
}
由于我似乎没有找到一种可行的方法来按照我想要的方式进行绑定,(可能无论如何都不是为了那个),这是一个很好的解决方案。
<Image Visibility="{Binding Image,ConverterParameter=Collapsed, Converter={StaticResource VisibilityConverter}}" Width="16" Height="16" Source="{Binding Image}"/>