我为包含边框和文本块的按钮定义了自定义模板,如下所示:
<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个像素之间时,它只会注册我的“鼠标悬停”。边框上的黄色背景让我可以看到按钮,但它通常是透明的。 以下是该按钮的两个实例的屏幕截图:
我已经在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}" />
非常感谢!
答案 0 :(得分:0)
由于我使用的是窗口镀铬,因此有些奇怪的事情发生在&#34; hitboxes&#34;如果你没有在风格中添加:
<Setter Property="WindowChrome.IsHitTestVisibleInChrome" Value="True" />