WPF IsMouseOver触发器,触发器的hitbox未超过按钮

时间:2017-06-19 21:01:03

标签: c# wpf templates triggers

我为包含边框和文本块的按钮定义了自定义模板,如下所示:

<Style x:Key="WindowControlButtons" BasedOn="{StaticResource WindowControlButtonsFont}" TargetType="{x:Type Button}">
    <Setter Property="Template">
        <Setter.Value>
            <ControlTemplate TargetType="{x:Type Button}">
                <Border Padding="{TemplateBinding Padding}" Height="100" Background="Yellow">
                    <TextBlock Text="{TemplateBinding Content}" />
                </Border>
            </ControlTemplate>
        </Setter.Value>
    </Setter>

    <Style.Triggers>
        <Trigger Property="IsMouseOver" Value="True">
            <Setter Property="Foreground" Value="{StaticResource FgOrangeBrush}" />
        </Trigger>

    </Style.Triggers>
</Style>

当我悬停时,我试图将其更改为橙色前景,并且它有效(有点)。当我的鼠标位于实际标签下方约5-30个像素之间时,它只会注册我的“鼠标悬停”。边框上的黄色背景让我可以看到按钮,但它通常是透明的。 以下是该按钮的两个实例的屏幕截图:

Snip of the relevant part of the app

我已经在hover触发IsMouseOver触发器的大概位置包含了一个蓝色轮廓。

基本上,我想知道为什么触发器没有触发大部分按钮。如果它有帮助,这里是按钮的声明:

<Button HorizontalAlignment="Right" Margin="10 0" Grid.Column="2" Content="X" Style="{StaticResource WindowControlButtons}" />
                <Button HorizontalAlignment="Right" Margin="35 0" Grid.Column="2" Content="_" Style="{StaticResource WindowControlButtons}" />

非常感谢!

1 个答案:

答案 0 :(得分:0)

由于我使用的是窗口镀铬,因此有些奇怪的事情发生在&#34; hitboxes&#34;如果你没有在风格中添加:

<Setter Property="WindowChrome.IsHitTestVisibleInChrome" Value="True" />