Проблема WPF с кнопкой Visibiliy, когда предок Ismouseover
-
29-09-2019 - |
Вопрос
У меня есть сетка WPF, которая, помимо прочего, содержит кнопку.
Кнопка скрыта по умолчанию и должна стать видимой только тогда, когда мышь находится над сеткой. (Функционально сетка является заголовком вкладки, а кнопка «Исчезает» - это кнопка закрытия). Я также переписал шаблон кнопки, чтобы иметь индивидуальное чувство.
Теперь кнопка становится видимой, когда моя мышь входит в сетку, но исчезает, как только мышь входит в кнопку. Моя интуиция заключается в том, что Ismouseover сетки становится ложным, когда мышь переходит к кнопке. Есть ли способ обойти это?
<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>
Спасибо!
Решение
Я не вижу здесь проблем. Я проверил это с простого окна с сеткой:
<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
. Анкет Когда я удаляю его, он не покажет кнопку.
Возможно, добавить немного больше кода?