Swo*_*per 8 wpf xaml image mouseover
标题基本概括了所有内容.有没有办法让XAML代码中的图像可见,而不是可点击(我试图使其后面的元素接收到点击)并同时响应鼠标悬停事件?该IsHitTestVisible属性禁用鼠标悬停.这是一个供参考的代码片段(它实际上使用了多个额外的MultiDataTriggers,但这里不相关).目前鼠标悬停工作,但点击它没有(添加IsHitTestVisible="True"使其相反)
<Image Name="AutoUpdateStatus"
Stretch="UniformToFill"
Grid.Column="2" Grid.Row="0"
Height="32" Width="32"
HorizontalAlignment="Center"
Margin="68,2,61,2"
VerticalAlignment="Center">
<Image.Style>
<Style>
<Setter Property="Image.Source">
<Setter.Value>
<Binding Source="{x:Static res:AppResources.ok}">
<Binding.Converter>
<Helpers:IconToImageSourceConverter />
</Binding.Converter>
</Binding>
</Setter.Value>
</Setter>
<Style.Triggers>
<MultiDataTrigger>
<MultiDataTrigger.Conditions>
<Condition Binding="{Binding RelativeSource={RelativeSource Self}, Path=IsMouseOver}" Value="True" />
<Condition Binding="{Binding Path=AutoUpdateStatusIcon}" Value="ok" />
</MultiDataTrigger.Conditions>
<Setter Property="Image.Source">
<Setter.Value>
<Binding Source="{x:Static res:AppResources.ok_glow}">
<Binding.Converter>
<Helpers:IconToImageSourceConverter />
</Binding.Converter>
</Binding>
</Setter.Value>
</Setter>
</MultiDataTrigger>
</Style.Triggers>
</Style>
</Image.Style>
</Image>
Run Code Online (Sandbox Code Playgroud)
一种简单的方法是根据 z 顺序正确对齐元素。如果您可以将图像移到后面,并将要单击的元素放在顶部,则可以轻松实现此操作。另外,让事情变得有点透明,你看到的图像比顶部的元素更多,这将使用户体验无缝。
当然,你需要使用像Grid这样可以在样本平面中添加多个元素的容器。
——法赫德
| 归档时间: |
|
| 查看次数: |
1317 次 |
| 最近记录: |