如何在WPF中使用 Fluent 主题

Fluent 主题

.NET 9 开始,WPF 附带了一个新主题-Fluent主题,它为 WPF 应用提供全新的现代 Windows 11 美学。 它包括集成的浅色和深色模式,以及系统主题色支持。

Fluent主题是为 WPF 做的仿 Fluent 设计的皮肤。Fluent设计是微软的新式UI设计风格,WinUI3实现了这种风格。

Fluent设计

关于Fluent设计,可以参考以下链接

https://fluent2.microsoft.design/get-started/whatisnew

以下为WPF Fluent主题的官方示例截图,我的测试环境是Windows 10 1903

浅色模式

深色模式

Fluent主题实现

Fluent主题是WPF自带样式,这些样式定义在 PresentationFramework.Fluent中,所以在使用时不需要安装其它库。

代码结构

Fluent样式实现

如何在WPF中使用

1、新建一个WPF工程(.NET 9以上版本)

2、在App.Xaml中添加资源字典

复制代码
 1 <Application x:Class="WPF_FluentDemo.App"
 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:WPF_FluentDemo"
 5              StartupUri="MainWindow.xaml">
 6     <Application.Resources>
 7         <ResourceDictionary>
 8             <ResourceDictionary.MergedDictionaries>
 9                 <ResourceDictionary Source="pack://application:,,,/PresentationFramework.Fluent;component/Themes/Fluent.xaml" />
10             </ResourceDictionary.MergedDictionaries>
11         </ResourceDictionary>
12     </Application.Resources>
13 </Application>

3、正常使用即可

这里我们添加一个Slider控件

复制代码
1   <Grid>
2       <Slider Width="100" VerticalAlignment="Center"></Slider>
3   </Grid>

运行效果还是非常不错的,如下所示。

因为这是一套主题,所以我们直接使用WPF自带的控件即可,但是Fluent也增加了一些额外的组件,

可以访问 https://apps.microsoft.com/detail/9ndlx60wx4kq 下载官方Demo,来查看所有示例的源码。

4、设置主题模式

Fluent主题支持以下主题模式

  • Light--- 应用浅色 Fluent 主题。
  • Dark- 应用深色 Fluent 主题。
  • System- 根据用户的当前 Windows 设置应用浅色或深色 Fluent 主题。
  • None--- (默认值) 使用 Aero2 主题。

在XAML中设置主题模式

复制代码
1 <Application x:Class="WPF_FluentDemo.App"
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:WPF_FluentDemo"
5              StartupUri="MainWindow.xaml"
6              ThemeMode="Light">

在代码中设置主题模式

注意:此 API 是实验性的,可能会更改。如果要在代码中使用,需要抑制WPF0001错误

复制代码
1             // 设置整个应用程序的主题模式
2 #pragma warning disable WPF0001 // 类型仅用于评估,在将来的更新中可能会被更改或删除。取消此诊断以继续。
3             Application.Current.ThemeMode = ThemeMode.Light;
4 #pragma warning restore WPF0001 // 类型仅用于评估,在将来的更新中可能会被更改或删除。取消此诊断以继续。
5 
6             // 设置当前窗口的主题模式
7 #pragma warning disable WPF0001 // 类型仅用于评估,在将来的更新中可能会被更改或删除。取消此诊断以继续。
8             ThemeMode = ThemeMode.Light;
9 #pragma warning restore WPF0001 // 类型仅用于评估,在将来的更新中可能会被更改或删除。取消此诊断以继续。

使用Windows主题色

从Windows 10开始, 引入了用户选择的主题色,用于提供个人触摸或调用特定视觉元素。 Fluent 支持用户选择的主题色。

Fluent主题已经帮我们定义好了Brush,直接像使用动态资源那样使用它就可以了

复制代码
1   <Grid>
2       <Border Width="300" Height="300" HorizontalAlignment="Left" VerticalAlignment="Bottom" Background="{DynamicResource AccentFillColorDefaultBrush}"></Border>
3   </Grid>

运行效果

完整的Brush/Color定义,可以参考Demo里的Colors页面

参考链接:

https://learn.microsoft.com/zh-cn/dotnet/desktop/wpf/whats-new/net90#fluent-theme

示例代码(.NET 10)

https://github.com/zhaotianff/cnblog-demo-code/tree/main/WPF_FluentDemo

相关推荐
Chris _data7 天前
WPF 学习第三天 — Modbus RTU 串口通信
hadoop·学习·wpf
布吉岛的石头8 天前
Java 程序员第 43 阶段05:微服务整合大模型,跨服务调用架构设计实战,Seata分布式事务实战
wpf
步步为营DotNet8 天前
基于.NET Aspire 实现云原生应用的高效监控与可观测性
云原生·.net·wpf
芒鸽9 天前
HarmonyOS 分布式开发实战:设备协同、数据共享与跨设备迁移
分布式·wpf·harmonyos
Volunteer Technology9 天前
Flink状态管理与容错(二)
大数据·flink·wpf
happyprince9 天前
07_verl-Trainer模块详解
人工智能·架构·wpf·强化学习
bugcome_com10 天前
WPF + Prism 技术指南与实战项目(二、模板搭建)
wpf
小满Autumn10 天前
log4net 日志框架 — 从配置到实战速查手册
笔记·c#·.net·wpf·上位机·log4net
政沅同学10 天前
基于 C# WPF + HALCON 的工业视觉算法工具框架(开源)
开发语言·c#·wpf
happyprince10 天前
03_verl-设计理念与核心原理
wpf