WPF проблема с Visibiliy of Button при предке IsMouseOver
У меня есть сетка WPF, которая содержит, помимо прочего, кнопку.
Кнопка скрыта по умолчанию и должна быть видна только когда мышь находится над сеткой. (Функционально сетка - это заголовок вкладки, а кнопка "исчезновения" - кнопка закрытия). Я также переписал шаблон кнопки, чтобы создать собственное ощущение.
Теперь кнопка становится видимой, когда моя мышь входит в сетку, но исчезает, как только мышь входит в кнопку. Моя интуиция заключается в том, что IsMouseOver в Grid становится False, когда мышь перемещается к кнопке. Это можно обойти?
<ControlTemplate x:Key="CloseTabButtonTemplate">
<Border Width="14" Height="14" Margin="3"
HorizontalAlignment="Right"
VerticalAlignment="Center"
BorderThickness="1"
CornerRadius="2,2,2,2">
<TextBlock Text="x" VerticalAlignment="Center" HorizontalAlignment="Center"
FontSize="11" Padding="0" Margin="0,-2,0,0" Foreground="White"/>
<Border.Style>
<Style TargetType="{x:Type Border}">
<Setter Property="Background" Value="#33DA3030"/>
<Setter Property="BorderBrush" Value="White"/>
<Setter Property="Visibility" Value="Hidden"/>
<Style.Triggers>
<DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor,AncestorType={x:Type Grid}},Path=IsMouseOver}" Value="True">
<Setter Property="Visibility" Value="Visible" />
</DataTrigger>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="#FFDA3030"/>
<Setter Property="Visibility" Value="Visible" />
</Trigger>
</Style.Triggers>
</Style>
</Border.Style>
</Border>
</ControlTemplate>
<Button Grid.Column="2" HorizontalAlignment="Right" Template="{StaticResource CloseTabButtonTemplate}">x</Button>
Спасибо!
1 ответ
Я не вижу здесь никаких проблем. Я проверил это с простым окном с сеткой:
<Window x:Class="WpfApplication1.Window1"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Window1" Height="300" Width="300"
>
<Window.Resources>
<ControlTemplate x:Key="CloseTabButtonTemplate">
.... Your template as in the question ....
</ControlTemplate>
</Window.Resources>
<Grid x:Name="MainGrid" Width="200" Height="200" Background="Transparent">
<Button Template="{StaticResource CloseTabButtonTemplate}" />
</Grid>
</Window>
Возможно, в родительской сетке отсутствует Background
цвет? Как вы видите, я сделал мой Grid
Transparent
, Когда я удаляю его, он не показывает кнопку.
Возможно добавить немного больше кода?