У меня есть простой стиль с ControlTemplate OrangeButton, и я создал другой стиль OrangeButton2 BasedOn OrangeButton. Я пытаюсь изменить свойства границы, но WPF не отображает новый стиль границы, определенный в OrangeButton2. Я также попробовал обратное, где OrangeButton основан на OrangeButton2, без изменений. Любая идея, что на самом деле происходит здесь, и как сделать ее правильной.Как изменить настройки базового стиля из производных настроек с использованием свойства BasedOn
<Style x:Key="OrangeButton" TargetType="Button" >
<Setter Property="OverridesDefaultStyle" Value="True"/>
<Setter Property="Margin" Value="2"/>
<Setter Property="FontFamily" Value="Verdana"/>
<Setter Property="FontSize" Value="11px"/>
<Setter Property="FontWeight" Value="Bold"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border Name="border"
BorderThickness="1"
Padding="4,2"
BorderBrush="DarkGray"
CornerRadius="3"
Background="{TemplateBinding Background}">
<Grid >
<ContentPresenter HorizontalAlignment="Center"
VerticalAlignment="Center" Name="contentShadow" Style="{StaticResource ShadowStyle}">
</ContentPresenter>
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" Name="content"/>
</Grid>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<Style x:Key="OrangeButton2" TargetType="Button" BasedOn="{StaticResource OrangeButton}">
<Setter Property="BorderBrush" Value="Red"></Setter>
<Setter Property="BorderThickness" Value="1"></Setter>
</Style>
</Window.Resources>
<StackPanel HorizontalAlignment="Center">
<Button Style="{StaticResource OrangeButton2}">Hello</Button>
</StackPanel>
Вы можете уменьшить XAML до двух важных стилей, чтобы улучшить читаемость. – MatthiasG