I have the following xaml for changing the image for WPF button when mouse is on the button. It give below error. Any help is appreciated…
‘System.Windows.Media.Animation.DoubleAnimation’ animation object cannot be used to animate property ‘Source’ because it is of incompatible type ‘System.Windows.Media.ImageSource’.
<Style TargetType="{x:Type local:ButtonControl}">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type local:ButtonControl}">
<Grid>
<VisualStateManager.VisualStateGroups>
<VisualStateGroup x:Name="CommonStates">
<VisualState x:Name="MouseOver">
<Storyboard>
<DoubleAnimation
Storyboard.TargetName="img"
Storyboard.TargetProperty="Source"
To="{Binding RelativeSource={RelativeSource TemplatedParent}, Path=MouseOverImage}"
/>
</Storyboard>
</VisualStateGroup>
</VisualStateManager.VisualStateGroups>
<Border>
<Image x:Name="img"
Source="pack://application:,,,/Recipe_06_13;component/Resources/normal.bmp"
/>
</Border>
</Grid>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
The DoubleAnimation is used to animate a dependency property of type double. Therefore, it cannot be used to ‘animate’ an image source. To accomplish what you are doing, I would go about it a little differently. I’d bind the image source to a property of the code behind, and capture the MouseEnter and MouseLeave events to change this property.
XAML
Code Behind: