当鼠标悬停在按钮本身上时,我试图更改按钮内容内的border属性。
这对我不起作用,我想知道为什么,请帮忙吗?
<Style x:Key="AddButtonStyle" BasedOn="{StaticResource ButtonGenericStyle}" TargetType="{x:Type Button}">
<Setter Property="Content">
<Setter.Value>
<Grid HorizontalAlignment="Stretch" VerticalAlignment="Stretch">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="auto"></ColumnDefinition>
<ColumnDefinition Width="*"></ColumnDefinition>
<ColumnDefinition Width="Auto"></ColumnDefinition>
</Grid.ColumnDefinitions>
<Image Width="24" Margin="5,0,0,0" Source="/Images/AddNew.png"></Image>
<TextBlock Grid.Column="1" VerticalAlignment="Center" HorizontalAlignment="Center" Text="{x:Static local:GenericGridResources.AddButtonText}"></TextBlock>
<Border x:Name="borderAdorner" Grid.Column="2" Width="5" Background="#00C176">
<Border.Style>
<Style TargetType="{x:Type Border}">
<Style.Triggers>
<DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type Image}}, Path=IsMouseOver}" Value="True">
<Setter Property="Background" Value="Red"></Setter>
</DataTrigger>
</Style.Triggers>
</Style>
</Border.Style>
</Border>
</Grid>
</Setter.Value>
</Setter>
</Style>
感谢
如果您希望将鼠标悬停在按钮上,则祖先类型应为按钮:
<DataTrigger Binding="{Binding RelativeSource={RelativeSource Mode=FindAncestor, AncestorType={x:Type Button}}, Path=IsMouseOver}" Value="True">
<Setter Property="Background" Value="Red"></Setter>
</DataTrigger>
按原样,您的边框中有一个兄弟姐妹,它是一幅图像。 Findancestor将查找视觉树,并且边框不是图像的子元素。
当用户将鼠标悬停在按钮上时,您还需要确保在内部或背景中有可测试的命中项目。我之所以这样说是因为还不清楚您的ButtonGenericStyle的用途。