C# radtreeview打开或关闭时,如何更改扩展器按钮?

C# radtreeview打开或关闭时,如何更改扩展器按钮?,c#,telerik,expander,togglebutton,radtreeview,C#,Telerik,Expander,Togglebutton,Radtreeview,我有两个图标,分别是a和b; 我需要我的RadtreeView项目在打开时显示带有图标a的扩展器按钮,在关闭时显示图标b。 FLOWING是两个图标 <Style x:Key="ExpanderStyleOpen" TargetType="ToggleButton"> <Setter Property="IsEnabled" Value="True" /> <Setter Property="IsTabStop" Va

我有两个图标,分别是a和b; 我需要我的RadtreeView项目在打开时显示带有图标a的扩展器按钮,在关闭时显示图标b。 FLOWING是两个图标

<Style x:Key="ExpanderStyleOpen" TargetType="ToggleButton">
            <Setter Property="IsEnabled" Value="True" />
            <Setter Property="IsTabStop" Value="False" />
            <Setter Property="ToggleButton.IsChecked" Value="True" />
            <Setter Property="Cursor" Value="Hand" />
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="ToggleButton">
                        ...
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>
        <Style x:Key="ExpanderStyleClose" TargetType="ToggleButton">
            <Setter Property="IsEnabled" Value="True" />
            <Setter Property="IsTabStop" Value="False" />
            <Setter Property="ToggleButton.IsChecked" Value="False" />
            <Setter Property="Cursor" Value="Hand" />
            <Setter Property="Template">
                <Setter.Value>
                    <ControlTemplate TargetType="ToggleButton">
                       ...
                    </ControlTemplate>
                </Setter.Value>
            </Setter>
        </Style>

...
...
然后我的radtreeview

<telerik:RadTreeView Name="radTreeView"
<!--static can't change...:(-->
                             ExpanderStyle="{StaticResource ExpanderStyleClose}"
                             FontSize="12"
                             IsLineEnabled="True"
                             IsRootLinesEnabled="False"
                             Visibility="{Binding IsVisible}">

通过使用
触发器
,您可以将两种样式组合为一种

这个想法是:

  • 将关闭的图像设置为样式的实际图像
  • 创建一个
    触发器
    以更改
    切换按钮
    已检查
    属性。“关闭”时为
    false
    ,打开时为
    true
  • 像这样的方法应该会奏效:

    <Style x:Key="ExpanderStyle" TargetType="{x:Type ToggleButton}">
        <Setter Property="IsEnabled" Value="True" />
        <Setter Property="IsTabStop" Value="False" />
        <Setter Property="Cursor" Value="Hand" />
        <Setter Property="Template">
            <Setter.Value>
                <ControlTemplate TargetType="{x:Type ToggleButton}">
                    <StackPanel Orientation="Horizontal">
                        <Grid SnapsToDevicePixels="False" Background="Transparent">
                            <Image x:Name="expanderImage" Source="..." />
                        </Grid>
                        <ContentPresenter />
                    </StackPanel>
                    <ControlTemplate.Triggers>
                        <Trigger Property="IsChecked" Value="false">
                            <Setter Property="Source" TargetName="expanderImage" Value="..." />
                        </Trigger>
                    </ControlTemplate.Triggers>
                </ControlTemplate>
            </Setter.Value>
        </Setter>
    </Style>