条记:在WPF中OverridesDefaultStyle属性如何利用

打印 上一主题 下一主题

主题 1030|帖子 1030|积分 3090

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
一、目标:介绍下在WPF中OverridesDefaultStyle属性如何利用

        OverridesDefaultStyle 属性在 WPF 中用于控制控件是否利用默认的主题样式。将其设置为 True 时,控件将不会应用默认的主题样式,而是完全依赖于你在 Style 中界说的样式。以下是如何利用 OverridesDefaultStyle 属性的详细说明和示例。

二、利用场景



•    完全自界说控件样式:当你希望完全自界说控件的外貌,而不希望继续任何默认样式时,可以将 OverridesDefaultStyle 设置为 True。
•    避免样式冲突:在某些环境下,你大概希望控件不受全局样式或主题样式的影响,这时可以利用 OverridesDefaultStyle。

三、示例

以下是一个示例,展示了如何利用 OverridesDefaultStyle 属性:
完全自界说按钮样式 
  1. <Button Content="Button">
  2.      <Button.Style>
  3.          <Style TargetType="Button">
  4.              <!--  Set to true to not get any properties from the themes.  -->
  5.              <Setter Property="OverridesDefaultStyle" Value="True" />
  6.              <Setter Property="Template">
  7.                  <Setter.Value>
  8.                      <ControlTemplate TargetType="Button">
  9.                          <Grid>
  10.                              <Ellipse Fill="{TemplateBinding Background}" />
  11.                              <ContentPresenter HorizontalAlignment="Center"
  12.                                                VerticalAlignment="Center" />
  13.                          </Grid>
  14.                      </ControlTemplate>
  15.                  </Setter.Value>
  16.              </Setter>
  17.          </Style>
  18.      </Button.Style>
  19. </Button>
复制代码
可以看到对比结果

        从上面的例子可以看到,设置OverridesDefaultStyle=True的Button样式Background是null,没有从默认的Button样式中继续,这个就是OverridesDefaultStyle的主要作用,可以完全控制控件样式而不受默认样式的干扰。

 同DefaultStyleKeyProperty的区别

        在 WPF 中,OverridesDefaultStyle 和 DefaultStyleKeyProperty 是两个不同的属性,它们在自界说控件的样式和行为方面起着不同的作用。在自界说控件中我们会通过DefaultStyleKeyProperty去配置控件的默认样式,DefaultStyleKeyProperty 是一个依赖属性,用于指定控件的默认样式键。通过重写 DefaultStyleKeyProperty 的元数据,你可以为自界说控件指定一个默认样式。通常在自界说控件的静态构造函数中利用 DefaultStyleKeyProperty.OverrideMetadata 方法来设置。如:
  1.     public class CustomControl1 : Control
  2.     {
  3.         static CustomControl1()
  4.         {
  5.             DefaultStyleKeyProperty.OverrideMetadata(typeof(CustomControl1), new FrameworkPropertyMetadata(typeof(CustomControl1)));
  6.         }
  7.     }
复制代码
在 Generic.xaml 中界说样式
  1. <ResourceDictionary
  2.     xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  3.     xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  4.     xmlns:local="clr-namespace:WpfCustomControlLibrary1">
  5.    
  6.     <Style TargetType="{x:Type local:CustomControl1}">
  7.         <Setter Property="Template">
  8.             <Setter.Value>
  9.                 <ControlTemplate TargetType="{x:Type local:CustomControl1}">
  10.                     <Border Background="LightGray" BorderBrush="Black" BorderThickness="1">
  11.                         <ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center"/>
  12.                     </Border>
  13.                 </ControlTemplate>
  14.             </Setter.Value>
  15.         </Setter>
  16.     </Style>
  17. </ResourceDictionary>
复制代码

•    OverridesDefaultStyle:用于指示控件是否应忽略默认的主题样式。设置为 True 时,控件将完全依赖于你在 Style 中界说的样式。
•    DefaultStyleKeyProperty:用于指定控件的默认样式键。通过重写 DefaultStyleKeyProperty 的元数据,你可以为自界说控件指定一个默认样式。

        这两个属性在自界说控件的样式和行为方面起着不同的作用,通常在自界说控件的开发中会联合利用,以实现所需的样式和行为。 


必要了解的知识点

FrameworkElement.OverridesDefaultStyle 属性 (System.Windows) | Microsoft Learn
FrameworkElement.DefaultStyleKeyProperty Field (System.Windows) | Microsoft Learn
System.Windows.Controls 命名空间 | Microsoft Learn

控件自界说 - WPF .NET Framework | Microsoft Learn
控件库 - WPF .NET Framework | Microsoft Learn
源码地址

GitHub - HeBianGu/WPF-ControlDemo: 示例
GitHub - HeBianGu/WPF-ControlBase: Wpf封装的自界说控件资源库
GitHub - HeBianGu/WPF-Control: WPF轻量控件和皮肤库
了解更多

System.Windows.Controls 命名空间 | Microsoft Learn
https://github.com/HeBianGu
HeBianGu的个人空间-HeBianGu个人主页-哔哩哔哩视频


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

立聪堂德州十三局店

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表