我需要根据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>
答案 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;
}
}