WPF Grid IsMouseOver属性

时间:2011-03-22 17:27:17

标签: wpf

WPF Grid有一个“IsMouseOver”属性,您可以在Grid的Style触发器中使用它。

我的问题是,只有当鼠标位于网格本身内的某个控件(即Button或ComboBox)上时,“IsMouseOver”属性才会更改。

例如:

<Grid>
  <Grid.ColumnDefinitions>
    <ColumnDefinition Width="25" />
    <ColumnDefinition />
  </Grid.ColumnDefinitions>

  <Button Grid.Column="1">A Button</Button>

  <Grid.Style>
    <Style TargetType="{x:Type Grid}">
      <Style.Triggers>
        <Trigger Property="IsMouseOver" Value="False">
          <Setter Property="Opacity" Value="0.5"></Setter>
        </Trigger>
        <Trigger Property="IsMouseOver" Value="True">
          <Setter Property="Opacity" Value="1"></Setter>
        </Trigger>
      </Style.Triggers>
    </Style>
  </Grid.Style>
</Grid>

上面的Grid及其内容将以半透明度显示,以便您可以看到控件。

如果将鼠标悬停在第一列(不包含任何内容)上,您会注意到不透明度将设置为完整。

但是,如果将鼠标悬停在第二列中的按钮上,则不透明度设置为完整。

在我的应用程序中,我正在设置触发器的网格显示在图像控件的顶部。我不希望在鼠标悬停在图像上之前显示网格...换句话说,由于网格位于图像的顶部,我不希望显示网格,直到鼠标悬停在图像上方网格(网格中的任何位置),因为网格位于图像的顶部。

有谁知道如何做到这一点?

谢谢!

-Frinny

2 个答案:

答案 0 :(得分:28)

你的问题是网格本身不是可测试的,因为它没有背景。试试这个:

<Grid Background="Transparent">

答案 1 :(得分:9)

将网格背景设置为透明,然后它应该工作

详情请注明look here