开发过程中,我们有时候用WPF原生的控件就能实现自己的需求,但是样式、风格并不
能满足我们的需求,那么我们该怎么办呢?
----自定义样式与模板。
一、样式
在WPF中我们可以使用Style来设置控件的某些属性值,并使该设置影响到指定范围内的
所有该类控件或影响指定的某一控件,比如说我们想将窗口中的所有按钮都保持某一种
风格,那么我们可以设置一个Style,而不必分别设置每个按钮的风格。
Style是作为一种资源被保存下来的. 看下面的例子:
<Style x:Key="style1" TargetType="{x:Type Button}">
<Setter Property="Background" Value="Skyblue" />
<Setter Property="FontSize" Value="18" />
<Setter Property="FontFamily" Value="Verdena" />
<Setter Property="FontWeight" Value="Bold" />
</Style>
如果我们希望是动态样式,可以添加Trigger:
<Style.Triggers>
<Trigger Property="IsPressed" Value="True">
<Setter Property="Foreground" Value="Red"/>
</Trigger>
</Style.Triggers>
二、模板
在WPF中有三大模板ControlTemplate,ItemsPanelTemplate,DataTemplate。其中
ControlTemplate和ItemsPanelTemplate是控件模板,DataTemplate是数据模板,他们都
派生自FrameworkTemplate抽象类。
定义模板的方法有三种:
这里以ControlTemplate为例:
1.内联定义:
<Button Content="Button1">
<Button.Template>
<ControlTemplate TargetType="Button">
<!--在这里定义ControlTemplate.-->
</ControlTemplate>
</Button.Template>
</Button>
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>
能满足我们的需求,那么我们该怎么办呢?
----自定义样式与模板。
一、样式
在WPF中我们可以使用Style来设置控件的某些属性值,并使该设置影响到指定范围内的
所有该类控件或影响指定的某一控件,比如说我们想将窗口中的所有按钮都保持某一种
风格,那么我们可以设置一个Style,而不必分别设置每个按钮的风格。
Style是作为一种资源被保存下来的. 看下面的例子:
<Style x:Key="style1" TargetType="{x:Type Button}">
<Setter Property="Background" Value="Skyblue" />
<Setter Property="FontSize" Value="18" />
<Setter Property="FontFamily" Value="Verdena" />
<Setter Property="FontWeight" Value="Bold" />
</Style>
如果我们希望是动态样式,可以添加Trigger:
<Style.Triggers>
<Trigger Property="IsPressed" Value="True">
<Setter Property="Foreground" Value="Red"/>
</Trigger>
</Style.Triggers>
二、模板
在WPF中有三大模板ControlTemplate,ItemsPanelTemplate,DataTemplate。其中
ControlTemplate和ItemsPanelTemplate是控件模板,DataTemplate是数据模板,他们都
派生自FrameworkTemplate抽象类。
定义模板的方法有三种:
这里以ControlTemplate为例:
1.内联定义:
<Button Content="Button1">
<Button.Template>
<ControlTemplate TargetType="Button">
<!--在这里定义ControlTemplate.-->
</ControlTemplate>
</Button.Template>
</Button>
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>