WPF自定义样式与模板
程序员文章站
2022-06-07 14:26:27
...
开发过程中,我们有时候用WPF原生的控件就能实现自己的需求,但是样式、风格并不
能满足我们的需求,那么我们该怎么办呢?----自定义样式与模板。
一、样式
在WPF中我们可以使用Style来设置控件的某些属性值,并使该设置影响到指定范围内的
所有该类控件或影响指定的某一控件,比如说我们想将窗口中的所有按钮都保持某一种
风格,那么我们可以设置一个Style,而不必分别设置每个按钮的风格。Style是作为一种
资源被保存下来的. 看下面的例子:
如果我们希望是动态样式,可以添加trigger:
<Style.Triggers>
</Style.Triggers>
二、模板
ControlTemplate 指定控件的可视结构和可视行为。可以通过为控件指定
新 ControlTemplate 自定义该控件的外观。创建 ControlTemplate 后,可以在不更改现
有控件的功能的情况下更改其外观。例如,您可以将应用程序中的按钮设置为圆形,而
不是默认的方形,但该按钮仍将引发 Click 事件。 注意: 在重定义模板前,你应该充分了
解该空间的模板类型
定义模板的方法有三种:
1.内联定义:
<
Button Content="Button1">
<Button.Template>
<ControlTemplate TargetType="Button">
<!--在这里定义ControlTemplate.-->
</ControlTemplate>
</Button.Template>
</Button>
</Style.Triggers>
2.定义为资源:
<StackPanel>
<StackPanel.Resources>
<ControlTemplate TargetType="Button" x:Key="newTemplate">
<!--在这里定义ControlTemplate.-->
</ControlTemplate>
</StackPanel.Resources>
<Button Template="{StaticResource newTemplate}" Content="Button1"/>
</StackPanel>
3.通过Style定义:
<StackPanel>
<StackPanel.Resources>
<Style TargetType="Button" x:Key="newTemplate">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<!--在这里定义ControlTemplate.-->
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
</StackPanel.Resources>
<Button Style="{StaticResource newTemplate}" Content="Button1"/>
</StackPanel>
上一篇: 影驰HOF PRO PCIe 4.0 SSD上架预售:2TB 4999元
下一篇: c++指针全攻略