Переопределение определенного свойства в стиле
У меня есть приложение с кнопками переключения, которое должно изменить фон в зависимости от проверенного состояния. Это приложение также имеет несколько обычных кнопок, которые имеют тот же фон, что и кнопки переключения. Кроме того, все они имеют закругленные углы.
Итак, я придумал эти стили:
<Style TargetType="Button" BasedOn="{StaticResource {x:Type Control}}" x:Key="OnButton">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border CornerRadius="15" Background="{StaticResource GradientBrushOn}" BorderThickness="1" Padding="2">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<Style TargetType="Button" BasedOn="{StaticResource OnButton}" x:Key="OffButton">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border CornerRadius="15" Background="{StaticResource GradientBrushOff}" BorderThickness="1" Padding="2" x:Name="TheBorder">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
Короче говоря, я ищу способ сократить OffButton
стиль, так что он только изменяет свойство фона OnButton
стиль от GradientBrushOn
в GradientBruthOff
,
Я впервые работаю с WPF, поэтому я предполагаю, что это должно быть довольно простой вещью, однако я просто не мог найти способ сделать это, даже после того, как провел 2 часа в Google.
1 ответ
Использование Button.Background
собственность и в ControlTemplate
использование TemplateBinding
<Style TargetType="Button" BasedOn="{StaticResource {x:Type Control}}" x:Key="OnButton">
<Setter Property="Background" Value="{StaticResource GradientBrushOn}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border CornerRadius="15" Background="{TemplateBinding Background}" BorderThickness="1" Padding="2">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<Style TargetType="Button" BasedOn="{StaticResource OnButton}" x:Key="OffButton">
<Setter Property="Background" Value="{StaticResource GradientBrushOff}"/>
</Style>
это также будет работать, если вы делаете
<Button Style="..." Background="Green"/>
РЕДАКТИРОВАТЬ
Так как вы должны изменить весь шаблон, как правило, в вашем ControlTemplate
вы будете использовать столько встроенных свойств вашего элемента управления, как Background
, BorderBrush
, BorderThickness
, Padding
, HorizontalContentAlignment
, VerticalContentAlignment
и так далее, так что вы можете поделиться шаблоном и настроить вещи, например, из стиля
<Style TargetType="Button" BasedOn="{StaticResource {x:Type Control}}" x:Key="OnButton">
<Setter Property="Background" Value="{StaticResource GradientBrushOn}"/>
<Setter Property="BorderThickness" Value="1"/>
<Setter Property="Padding" Value="2"/>
<Setter Property="HorizontalContentAlignment" Value="Center"/>
<Setter Property="VerticalContentAlignment" Value="Center"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border CornerRadius="15" Background="{TemplateBinding Background}" BorderThickness="{TemplateBinding BorderThickness}" BorderBrush="{TemplateBinding BorderBrush}" Padding="{TemplateBinding Padding}">
<ContentPresenter HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>