无法覆盖 WPF 中 app.xaml 的按钮样式
Not able to override button style from app.xaml in WPF
我遇到了一个非常奇怪的问题,找不到解决办法。我尝试了几乎所有可能的方法(甚至删除并重新创建解决方案)来解决这个问题。
问题
我正在尝试覆盖 WPF 应用程序中的默认控件样式。我在 App.xaml
中定义了所有资源和样式。问题是,按钮前景色没有被覆盖 运行 时间。令人惊讶的是,它在 VS 设计器中显示覆盖颜色(白色),但是当我 运行 应用程序时,它变成黑色(可能是默认设置)。
应用中没有其他更改按钮样式的代码。
附加信息:按钮位于用户控件中,并加载到 MainWindow 的 ContentControl 中。
<SolidColorBrush x:Key="WhiteBrush" Color="#FFFFFF"/>
<SolidColorBrush x:Key="BlackBrush" Color="#000000"/>
<SolidColorBrush x:Key="ActiveBrush" Color="#3A71C5"/>
<SolidColorBrush x:Key="HoverBrush" Color="#0071C5"/>
<SolidColorBrush x:Key="PressBrush" Color="#3A8BF4"/>
<SolidColorBrush x:Key="DefaultBrush" Color="#0071F9"/>
<SolidColorBrush x:Key="DisabledBrush" Color="#F4F4F4"/>
<Style TargetType="{x:Type Button}">
<Setter Property="Background" Value="{StaticResource ActiveBrush}"/>
<Setter Property="Foreground" Value="{StaticResource WhiteBrush}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<Border Background="{TemplateBinding Background}" BorderBrush="Transparent" BorderThickness="0">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="{StaticResource HoverBrush}"/>
</Trigger>
<Trigger Property="IsPressed" Value="True">
<Setter Property="Background" Value="{StaticResource PressBrush}"/>
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Background" Value="{StaticResource DisabledBrush}"/>
</Trigger>
</Style.Triggers>
</Style>
VS 设计器中的按钮
应用中的按钮运行时间
问题可能是您有一些其他样式应用于按钮的某些嵌套控件(例如 TextBlock
)。
我将您的代码段粘贴到示例 WPF 应用程序中,并将 Button
包装在自定义 UserControl
中。我测试了它并在设计视图和运行时正确显示。
然后我在App.xaml
中添加了如下样式:
<Style TargetType="{x:Type TextBlock}">
<Setter Property="Foreground" Value="Red"/>
</Style>
按钮显示红色文字。
所以问题可能是 other 控件的其他样式覆盖了 Button
模板的某些部分。
编辑
一种可能的解决方案是在控件本身中显式定义按钮内容:
<Button>
<TextBlock Foreground="{StaticResource WhiteBrush}">Test</TextBlock>
</Button>
可能有更优雅的方法来做到这一点,但我目前想不出任何其他方法。
我遇到了一个非常奇怪的问题,找不到解决办法。我尝试了几乎所有可能的方法(甚至删除并重新创建解决方案)来解决这个问题。
问题
我正在尝试覆盖 WPF 应用程序中的默认控件样式。我在 App.xaml
中定义了所有资源和样式。问题是,按钮前景色没有被覆盖 运行 时间。令人惊讶的是,它在 VS 设计器中显示覆盖颜色(白色),但是当我 运行 应用程序时,它变成黑色(可能是默认设置)。
应用中没有其他更改按钮样式的代码。
附加信息:按钮位于用户控件中,并加载到 MainWindow 的 ContentControl 中。
<SolidColorBrush x:Key="WhiteBrush" Color="#FFFFFF"/>
<SolidColorBrush x:Key="BlackBrush" Color="#000000"/>
<SolidColorBrush x:Key="ActiveBrush" Color="#3A71C5"/>
<SolidColorBrush x:Key="HoverBrush" Color="#0071C5"/>
<SolidColorBrush x:Key="PressBrush" Color="#3A8BF4"/>
<SolidColorBrush x:Key="DefaultBrush" Color="#0071F9"/>
<SolidColorBrush x:Key="DisabledBrush" Color="#F4F4F4"/>
<Style TargetType="{x:Type Button}">
<Setter Property="Background" Value="{StaticResource ActiveBrush}"/>
<Setter Property="Foreground" Value="{StaticResource WhiteBrush}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<Border Background="{TemplateBinding Background}" BorderBrush="Transparent" BorderThickness="0">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
<Style.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="{StaticResource HoverBrush}"/>
</Trigger>
<Trigger Property="IsPressed" Value="True">
<Setter Property="Background" Value="{StaticResource PressBrush}"/>
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Background" Value="{StaticResource DisabledBrush}"/>
</Trigger>
</Style.Triggers>
</Style>
VS 设计器中的按钮
应用中的按钮运行时间
问题可能是您有一些其他样式应用于按钮的某些嵌套控件(例如 TextBlock
)。
我将您的代码段粘贴到示例 WPF 应用程序中,并将 Button
包装在自定义 UserControl
中。我测试了它并在设计视图和运行时正确显示。
然后我在App.xaml
中添加了如下样式:
<Style TargetType="{x:Type TextBlock}">
<Setter Property="Foreground" Value="Red"/>
</Style>
按钮显示红色文字。
所以问题可能是 other 控件的其他样式覆盖了 Button
模板的某些部分。
编辑
一种可能的解决方案是在控件本身中显式定义按钮内容:
<Button>
<TextBlock Foreground="{StaticResource WhiteBrush}">Test</TextBlock>
</Button>
可能有更优雅的方法来做到这一点,但我目前想不出任何其他方法。