将鼠标悬停在标签上更改矩形背景渐变

本文关键字:背景 渐变 鼠标 悬停 标签 | 更新日期: 2023-09-27 17:58:14

我有一个矩形,上面有几个标签和图像,这样当用户将鼠标悬停在矩形上时,背景会变为渐变:

<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>

但是,当我将鼠标悬停在矩形上的一个标签上时,背景渐变不会显示。

我想让它在悬停在标签和矩形上时显示渐变。

这可能吗?

将鼠标悬停在标签上更改矩形背景渐变

如果你所说的"over"是指覆盖而不是覆盖,你可以将内容包装在网格中(我想你也可以这样做,但你应该定义行和列),并使用DataTrigger,如果鼠标在包装网格上,而不仅仅是矩形本身,它就会触发,例如:

<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来使鼠标事件通过标签。

因为其他元素都在矩形的顶部,所以我认为您需要挂钩到矩形的PreviewMouseMove事件。

UIELement。预览鼠标移动:http://msdn.microsoft.com/en-us/library/system.windows.uielement.previewmousemove.aspx

预览事件:http://msdn.microsoft.com/en-us/library/ms752279.aspx