0

我尝试使用另一个上下文绑定到 Hierarchical 模板中的 IsExpanded 属性。

 <HierarchicalDataTemplate  x:Key="TreeView1"  ItemsSource="{Binding Path=Folders}" >
    <StackPanel Margin="5,5,5,5" Orientation="Horizontal">
        <StackPanel Name="spinCont">
            <ModulesUpToDateChecker1:Spinner Width="20" x:Name="Spin" FolderContext="{Binding}"  StateContext="{Binding Path=State}"></ModulesUpToDateChecker1:Spinner>
            <Image x:Name="imgFolderIcon" Width="16" Visibility="Hidden" 
                               Source="/ModulesUpToDateChecker;component/Resources/FolderClosed16.png">
                <Image.Triggers>

                </Image.Triggers>
            </Image>
            <Image VerticalAlignment="Center" x:Name="imgFolderItem"
                                        Source="{Binding Path=State, Converter={StaticResource stateFolderConverter}}">
                <Image.Style>
                    <Style TargetType="{x:Type Image}">
                        <Style.Triggers>
                            <MultiDataTrigger>
                                <MultiDataTrigger.Conditions>
                                    <Condition Binding="{Binding Path=IsLast}" Value="true"></Condition>
                                </MultiDataTrigger.Conditions>
                                <Setter Property="Visibility" Value="Collapsed"></Setter>
                            </MultiDataTrigger>
                        </Style.Triggers>
                    </Style>
                </Image.Style>
            </Image>
        </StackPanel>
        <StackPanel DataContext="{Binding Path=Modules}">
            <ModulesUpToDateChecker1:Spinner Width="20">
                <ModulesUpToDateChecker1:Spinner.Style>
                    <Style TargetType="{x:Type ModulesUpToDateChecker1:Spinner}">
                        <Setter Property="Visibility" Value="Collapsed" />
                        <Style.Triggers>
                            <DataTrigger Binding="{Binding Path=Animation}" Value="True" >
                                <Setter Property="Visibility" Value="Visible" />
                            </DataTrigger>
                        </Style.Triggers>
                    </Style>
                </ModulesUpToDateChecker1:Spinner.Style>
            </ModulesUpToDateChecker1:Spinner>
            <Image VerticalAlignment="Center"
                                        Source="{Binding Path=State, Converter={StaticResource stateImageConverter}}">
                <Image.Style>
                    <Style TargetType="{x:Type Image}">
                        <Style.Triggers>
                            <DataTrigger Binding="{Binding Path=Animation}" Value="True" >
                                <Setter Property="Visibility" Value="Collapsed" />
                            </DataTrigger>
                        </Style.Triggers>
                    </Style>
                </Image.Style>
            </Image>
        </StackPanel>
        <TextBlock Text="{Binding Path=Name}" Margin="10,0,0,0"></TextBlock>
    </StackPanel>


    <HierarchicalDataTemplate.Triggers>
        <!--<Trigger Property="{Binding}" Value="true">
            <Setter TargetName="imgFolderIcon" Property="Source" Value="/ModulesUpToDateChecker;component/Resources/Error.png" />
        </Trigger>-->
        **<DataTrigger  Binding="{Binding Path=IsExpanded}" Value="true">
            <Setter TargetName="imgFolderIcon" Property="Source" Value="/ModulesUpToDateChecker;component/Resources/Error.png" />
        </DataTrigger>**

不工作

    </HierarchicalDataTemplate.Triggers>
</HierarchicalDataTemplate>

我有“文件夹”上下文(它的分层对象),但是如何绑定到 HierarchicalDataTemplate.Triggers 中的 TreeView 属性?当我启动它时,输出显示 Folder 对象中没有 IsExpanded 属性。所以,我有错误的上下文。

4

1 回答 1

1
 <DataTrigger Binding="{Binding RelativeSource={RelativeSource AncestorType=TreeViewItem}, Path=IsExpanded}" Value="true">
            <Setter  TargetName="imgFolderIcon"  Property="Source" Value="/Resources/FolderExpanded.png" />
        </DataTrigger>

简单的

于 2012-10-10T08:07:35.400 回答