使用触发器更改xaml中的图像源无法正常工作

时间:2011-04-14 08:42:40

标签: wpf xaml binding triggers

我需要根据viewModel中的一些布尔属性更改工具栏中的图像。我正在使用触发器来更改图像源。这是正确的方法吗?我的代码运行不正常,有时可以正常运行,但有时图像保持不变。

<Image x:Key="startPauseResumeAnalysisToolbarImage" >
        <Image.Style>
            <Style TargetType="{x:Type Image}">
                <Setter Property="Source" Value="Resources/ToolbarIcons/play.png" />
                <Style.Triggers>
                    <DataTrigger Binding="{Binding IsAnalysisRunning}" Value="True" >
                        <Setter Property="Source" Value="Resources/ToolbarIcons/pause.png"/>
                    </DataTrigger>
                </Style.Triggers>
            </Style>
        </Image.Style>
</Image>

1 个答案:

答案 0 :(得分:4)

它应该工作。很难理解为什么没有剩下的代码。您是否在具有IsAnalysisRunning属性的任何类中实现INotifyPropertyChanged接口?

以下是我用来测试的一个小样本:

MainWindow.xaml

<Window x:Class="WpfApplication2.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:my="clr-namespace:WpfApplication2"
    Title="MainWindow" Height="350" Width="525">
    <Grid>
    <Image >
        <Image.Style>
            <Style TargetType="{x:Type Image}">
                <Setter Property="Source" Value="Desert.jpg" />
                <Style.Triggers>
                    <DataTrigger Binding="{Binding IsAnalysisRunning}" Value="True" >
                        <Setter Property="Source" Value="Koala.jpg"/>
                    </DataTrigger>
                </Style.Triggers>
            </Style>
        </Image.Style>
    </Image>
    <Button Content="Button" Height="23" HorizontalAlignment="Left" Margin="0,12,0,0" Name="button1" VerticalAlignment="Top" Width="75" Click="button1_Click" />
    </Grid>
</Window>

MainWindow.xaml.cs:

public partial class MainWindow : Window, INotifyPropertyChanged
{
    public MainWindow()
    {
        InitializeComponent();
        this.DataContext = this;
    }
    private bool _isAnalysisRunning = false;
    public bool IsAnalysisRunning
    {
        get { return _isAnalysisRunning; }
        set {
            _isAnalysisRunning = value;
            NotifyPropretyChanged("IsAnalysisRunning");
        }
    }
    private void NotifyPropretyChanged(string property)
    {
        if (PropertyChanged != null)
            PropertyChanged(this, new PropertyChangedEventArgs(property));
    }


    public event PropertyChangedEventHandler PropertyChanged;

    private void button1_Click(object sender, RoutedEventArgs e)
    {
        IsAnalysisRunning = !IsAnalysisRunning;
    }
}