我有一个矩形,上面有几个标签和图像,我有它,这样当用户将鼠标悬停在矩形上时,背景会变为渐变:
<Rectangle Height="88" HorizontalAlignment="Left" Margin="54,28,0,0" Name="rectangle2" VerticalAlignment="Top"
Width="327" Cursor="Hand">
<Rectangle.Style>
<Style TargetType="{x:Type Rectangle}">
<Setter Property="Fill" Value="Transparent" />
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Fill">
<Setter.Value>
<LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
<GradientStop Color="White" Offset="0.0" />
<GradientStop Color="#eee" Offset="1" />
</LinearGradientBrush>
</Setter.Value>
</Setter>
</Trigger>
</Style.Triggers>
</Style>
</Rectangle.Style>
</Rectangle>
但是,当我将鼠标悬停在矩形上方的其中一个标签上时,背景渐变不显示。
我想这样做,以便在悬停在标签和矩形上时显示渐变。
这可能吗?
答案 0 :(得分:1)
如果用“over”表示覆盖而不是高于你可以将内容包装在Grid中(对于上面你也可以这样做我猜,但你应该定义行和列)并使用{{3}如果鼠标位于包裹网格上而不仅仅是矩形本身,则会触发,例如:
<Grid HorizontalAlignment="Center" VerticalAlignment="Center">
<Rectangle Width="100" Height="100" StrokeThickness="1" Stroke="Black">
<Rectangle.Style>
<Style TargetType="{x:Type Rectangle}">
<Setter Property="Fill" Value="Transparent" />
<Style.Triggers>
<DataTrigger Binding="{Binding IsMouseOver, RelativeSource={RelativeSource AncestorType=Grid}}" Value="True">
<Setter Property="Fill">
<Setter.Value>
<!-- Brush here -->
</Setter.Value>
</Setter>
</DataTrigger>
</Style.Triggers>
</Style>
</Rectangle.Style>
</Rectangle>
<Label Name="label" Content="This is a Label" />
</Grid>
或者,如果标签被覆盖,您可以通过将IsHitTestVisible
设置为false
来使鼠标事件通过标签。
答案 1 :(得分:0)
因为其他元素位于矩形的顶部,我认为您需要挂钩矩形的PreviewMouseMove事件。
UIELement.PreviewMouseMove:http://msdn.microsoft.com/en-us/library/system.windows.uielement.previewmousemove.aspx