我有一个datatemplate
用于datagridtemplatecolumn
我试图在Image
上显示鼠标上的不同图像
鼠标悬停时,光标正在变化,但图像没有变化。
<DataTemplate x:Key="MyDataTemplate" DataType="DataRowView">
<StackPanel Orientation="Horizontal" Background="Transparent">
<Image Margin="0,0,0,0" Width="50" Height="50" Source="{Binding Converter={StaticResource SetImgToDG}}" ToolTip="{Binding}" >
<Image.Resources>
<Style TargetType="{x:Type Image}">
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<!-- Hover image -->
<Setter Property="Cursor" Value="Hand"/>
<Setter Property="Source" Value="C:\Images\Coil3.png"/>
</Trigger>
</Style.Triggers>
</Style>
</Image.Resources>
</Image>
</StackPanel>
</DataTemplate>
这种约束是否会产生问题? 如何解决?
答案 0 :(得分:4)
您的问题是图像的初始源是直接在图像实例的Source
属性上定义的。
当有多个东西尝试设置依赖项属性的值时,框架必须决定使用哪个值。
在您的情况下,值直接在图像实例(本地)上设置,也由Trigger
设置。
在这种情况下,本地值总是会赢,所以当Trigger
被激活时没有任何反应。
如果您在样式中设置初始值,Trigger
会在尝试更改图像源时获胜,并且当鼠标悬停在图像源上时会使图像发生变化。
您可以详细了解MSDN如何解决Dependency Property
的价值。
<Image.Resources>
<Style TargetType="{x:Type Image}">
<!-- Set the initial source in the style so the trigger can change it -->
<Setter Property="Source" Value="{Binding Converter={StaticResource SetImgToDG}}" />
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<!-- Hover image -->
<Setter Property="Cursor" Value="Hand"/>
<Setter Property="Source" Value="C:\Images\Coil3.png"/>
</Trigger>
</Style.Triggers>
</Style>
</Image.Resources>