Date: 03.12.2018 9:28:49
Трудно сказать, что не так, ведь вы не описали детально желаемое поведение. Упрощенно говоря, вы не учитываете, что у стандартного шаблона есть свои триггеры, которые переопределяют ваши. Правильный путь, скорее всего - переопределять шаблон целиком, а не добавлять отдельный стиль.
Например, если нужно, чтобы кнопка меняла цвет между красным и голубым при нажатии, это будет как-то так:
<Window.Resources>
<ControlTemplate x:Key="ToggleButtonControlTemplate1" TargetType="{x:Type ToggleButton}">
<Border x:Name="border" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
<ContentPresenter x:Name="contentPresenter" ContentTemplate="{TemplateBinding ContentTemplate}" Content="{TemplateBinding Content}" ContentStringFormat="{TemplateBinding ContentStringFormat}" Focusable="False" HorizontalAlignment="{TemplateBinding HorizontalContentAlignment}" Margin="{TemplateBinding Padding}" RecognizesAccessKey="True" SnapsToDevicePixels="{TemplateBinding SnapsToDevicePixels}" VerticalAlignment="{TemplateBinding VerticalContentAlignment}"/>
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsChecked" Value="true">
<Setter Property="Background" TargetName="border" Value="Red"></Setter>
</Trigger>
<Trigger Property="IsChecked" Value="false">
<Setter Property="Background" TargetName="border" Value="LightBlue"></Setter>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Window.Resources>
<ToggleButton Content="but" Template="{DynamicResource ToggleButtonControlTemplate1}"/>
Автор: VadimTagil