论坛
潜水/灌水快乐,沉淀知识,认识更多同行。
ToB圈子
加入IT圈,遇到更多同好之人。
朋友圈
看朋友圈动态,了解ToB世界。
ToB门户
了解全球最新的ToB事件
博客
Blog
排行榜
Ranklist
文库
业界最专业的IT文库,上传资料也可以赚钱
下载
分享
Share
导读
Guide
相册
Album
记录
Doing
搜索
本版
文章
帖子
ToB圈子
用户
免费入驻
产品入驻
解决方案入驻
公司入驻
案例入驻
登录
·
注册
只需一步,快速开始
账号登录
立即注册
找回密码
用户名
Email
自动登录
找回密码
密码
登录
立即注册
首页
找靠谱产品
找解决方案
找靠谱公司
找案例
找对的人
专家智库
悬赏任务
圈子
SAAS
ToB企服应用市场:ToB评测及商务社交产业平台
»
论坛
›
大数据
›
数据仓库与分析
›
C# WPF入门学习主线篇(二十二)—— 样式(Styles)的 ...
C# WPF入门学习主线篇(二十二)—— 样式(Styles)的定义和应用 ...
用户国营
金牌会员
|
2024-8-25 16:19:30
|
显示全部楼层
|
阅读模式
楼主
主题
654
|
帖子
654
|
积分
1962
C# WPF入门学习主线篇(二十二)—— 样式(Styles)的定义和应用
欢迎来到C# WPF入门学习系列的第二十二篇。本篇文章将详细介绍WPF中的样式(Styles)的定义和应用。样式在WPF中起到重要作用,通过样式可以轻松地定义和复用控件的外观和行为,从而提高开辟效率和代码的可维护性。
什么是样式?
样式(Style)是用于定义控件外观和行为的集合。样式通常定义在XAML文件中,可以在多个控件中共享使用。样式可以包括各种属性的设置,如颜色、字体、边距等,以及触发器(Trigger),用于响应特定的事件或状态。
样式的定义
在WPF中,样式通常定义在XAML文件的资源字典中。以下是一个简单的样式定义示例:
<Window x:Class="WpfApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Styles Demo" Height="300" Width="400">
<Window.Resources>
<!-- 定义一个按钮的样式 -->
<Style x:Key="PrimaryButtonStyle" TargetType="Button">
<Setter Property="Background" Value="Blue"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="Padding" Value="10"/>
<Setter Property="FontSize" Value="16"/>
</Style>
</Window.Resources>
<Grid>
<Button Content="Primary Button" Style="{StaticResource PrimaryButtonStyle}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
</Window>
复制代码
在上面的代码中,我们在 Window.Resources 中定义了一个名为 PrimaryButtonStyle 的样式,并应用于一个按钮控件。
Setter的使用
Setter 用于设置控件的属性。每个 Setter 包含两个属性:
Property:要设置的属性。
Value:属性的值。
应用样式
要应用样式,可以使用 StaticResource 标志扩展引用样式:
<Button Content="Primary Button" Style="{StaticResource PrimaryButtonStyle}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
复制代码
默认样式
如果盼望将样式应用于同一类型的全部控件,可以省略 x:Key,使样式成为默认样式:
<Window x:Class="WpfApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Styles Demo" Height="300" Width="400">
<Window.Resources>
<!-- 定义一个按钮的默认样式 -->
<Style TargetType="Button">
<Setter Property="Background" Value="Blue"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="Padding" Value="10"/>
<Setter Property="FontSize" Value="16"/>
</Style>
</Window.Resources>
<Grid>
<Button Content="Default Style Button" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
</Window>
复制代码
在这个示例中,全部按钮控件将自动应用此样式。
基于现有样式创建新样式
WPF允许通过 BasedOn 属性基于现有样式创建新样式,从而实现样式的继承和扩展。比方:
<Window x:Class="WpfApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Styles Demo" Height="300" Width="400">
<Window.Resources>
<!-- 定义基础按钮样式 -->
<Style x:Key="BaseButtonStyle" TargetType="Button">
<Setter Property="FontSize" Value="16"/>
<Setter Property="Padding" Value="10"/>
</Style>
<!-- 定义继承基础样式的主按钮样式 -->
<Style x:Key="PrimaryButtonStyle" TargetType="Button" BasedOn="{StaticResource BaseButtonStyle}">
<Setter Property="Background" Value="Blue"/>
<Setter Property="Foreground" Value="White"/>
</Style>
<!-- 定义继承基础样式的次按钮样式 -->
<Style x:Key="SecondaryButtonStyle" TargetType="Button" BasedOn="{StaticResource BaseButtonStyle}">
<Setter Property="Background" Value="Gray"/>
<Setter Property="Foreground" Value="Black"/>
</Style>
</Window.Resources>
<Grid>
<StackPanel HorizontalAlignment="Center" VerticalAlignment="Center" Spacing="10">
<Button Content="Primary Button" Style="{StaticResource PrimaryButtonStyle}"/>
<Button Content="Secondary Button" Style="{StaticResource SecondaryButtonStyle}"/>
</StackPanel>
</Grid>
</Window>
复制代码
在这个例子中,我们定义了一个基础按钮样式 BaseButtonStyle,并基于它创建了两个新样式 PrimaryButtonStyle 和 SecondaryButtonStyle,实现了样式的继承和扩展。
使用触发器(Triggers)
触发器(Trigger)是样式的重要构成部分,用于响应控件状态的变革。常见的触发器有 PropertyTrigger 和 EventTrigger。
属性触发器(PropertyTrigger)
属性触发器用于在控件属性值发生变革时,执行某些操作。以下是一个简单的属性触发器示例:
<Window x:Class="WpfApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Styles Demo" Height="300" Width="400">
<Window.Resources>
<!-- 定义带触发器的按钮样式 -->
<Style x:Key="HoverButtonStyle" TargetType="Button">
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="Button">
<Border Background="{TemplateBinding Background}" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="1" CornerRadius="5">
<ContentPresenter HorizontalAlignment="Center" VerticalAlignment="Center" />
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="Red"/>
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
<Setter Property="Background" Value="Blue"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="Padding" Value="10"/>
<Setter Property="FontSize" Value="16"/>
</Style>
</Window.Resources>
<Grid>
<Button Content="Hover Me" Style="{StaticResource HoverButtonStyle}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
</Window>
复制代码
在这个例子中,当按钮被鼠标悬停时,触发器会改变按钮的配景颜色。
事件触发器(EventTrigger)
事件触发器用于响应控件的事件。以下是一个简单的事件触发器示例:
<Window x:Class="WpfApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Styles Demo" Height="300" Width="400">
<Window.Resources>
<!-- 定义带事件触发器的按钮样式 -->
<Style x:Key="ClickButtonStyle" TargetType="Button">
<Setter Property="Background" Value="Blue"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="Padding" Value="10"/>
<Setter Property="FontSize" Value="16"/>
<Style.Triggers>
<EventTrigger RoutedEvent="Button.Click">
<BeginStoryboard>
<Storyboard>
<ColorAnimation Storyboard.TargetProperty="(Button.Background).(SolidColorBrush.Color)"
To="Green" Duration="0:0:0.5" />
</Storyboard>
</BeginStoryboard>
</EventTrigger>
</Style.Triggers>
</Style>
</Window.Resources>
<Grid>
<Button Content="Click Me" Style="{StaticResource ClickButtonStyle}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
</Window>
复制代码
在这个示例中,当按钮被点击时,事件触发器会启动一个 Storyboard,通过 ColorAnimation 将按钮的配景颜色在0.5秒内渐变为绿色。
多个触发器
WPF样式还支持多个触发器的组合使用。以下是一个同时使用属性触发器和事件触发器的示例:
<Window x:Class="WpfApp.MainWindow"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="Styles Demo" Height="300" Width="400">
<Window.Resources>
<!-- 定义带多个触发器的按钮样式 -->
<Style x:Key="AdvancedButtonStyle" TargetType="Button">
<Setter Property="Background" Value="Blue"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="Padding" Value="10"/>
<Setter Property="FontSize" Value="16"/>
<Style.Triggers>
<!-- 属性触发器:鼠标悬停时改变背景颜色 -->
<Trigger Property="IsMouseOver" Value="True">
<Setter Property="Background" Value="Red"/>
</Trigger>
<!-- 事件触发器:点击时启动颜色动画 -->
<EventTrigger RoutedEvent="Button.Click">
<BeginStoryboard>
<Storyboard>
<ColorAnimation Storyboard.TargetProperty="(Button.Background).(SolidColorBrush.Color)"
To="Green" Duration="0:0:0.5" />
</Storyboard>
</BeginStoryboard>
</EventTrigger>
</Style.Triggers>
</Style>
</Window.Resources>
<Grid>
<Button Content="Advanced Button" Style="{StaticResource AdvancedButtonStyle}" HorizontalAlignment="Center" VerticalAlignment="Center"/>
</Grid>
</Window>
复制代码
在这个例子中,当按钮被鼠标悬停时,配景颜色会变成赤色;当按钮被点击时,配景颜色会在0.5秒内渐变为绿色。
总结
通过本文的学习,我们详细介绍了WPF中的样式(Styles)的定义和应用,包括静态样式、基于现有样式创建新样式、属性触发器和事件触发器的使用。样式是WPF中一个强大而机动的特性,可以帮助我们高效地管理和复用控件的外观和行为,提高开辟效率和代码的可维护性。
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
本帖子中包含更多资源
您需要
登录
才可以下载或查看,没有账号?
立即注册
x
回复
使用道具
举报
0 个回复
倒序浏览
返回列表
快速回复
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
or
立即注册
本版积分规则
发表回复
回帖并转播
回帖后跳转到最后一页
发新帖
回复
用户国营
金牌会员
这个人很懒什么都没写!
楼主热帖
Beta 阶段事后分析
一键设置 Docker 环境:具体指南与最佳 ...
iOS全埋点解决方案-APP和H5打通 ...
分布式锁
复杂「场景」数据导入导出
mysql主从搭建
mysql精确查年龄
和必应对话之mysql分区分表
ET介绍——事件机制EventSystem ...
【云原生】-如何搭建配置Docker私有仓 ...
标签云
挺好的
服务器
快速回复
返回顶部
返回列表