繁体   English   中英

在WPF图像中显示鼠标上的不同图像

[英]Showing different image on mouse over in WPF Image

我有一个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>  

这种绑定是否会产生问题?
怎么解决?

您的问题是图像的初始源直接在图像实例的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>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM