PyQt-Fluent-Widgets 极速上手:从安装到第一个 Fluent 界面仅需 5 分钟
你是否还在为 PyQt 界面设计繁琐而烦恼?是否想快速开发出具有现代美感的桌面应用?本文将带你极速上手 PyQt-Fluent-Widgets,从环境搭建到实现第一个 Fluent 风格界面,全程只需 5 分钟。读完本文,你将掌握库的安装方法、核心窗口组件使用,以及如何快速构建符合微软 Fluent Design 设计规范的界面。
环境准备与安装
PyQt-Fluent-Widgets 支持 Python 3.7 及以上版本,兼容 PyQt5 和 PySide2/PySide6。推荐使用 pip 工具进行安装,确保网络环境良好,执行以下命令:
pip install PyQt-Fluent-Widgets -i https://pypi.tuna.tsinghua.edu.cn/simple
若需指定版本,可添加版本号,如 PyQt-Fluent-Widgets==1.0.0。安装完成后,可通过 import qfluentwidgets 验证是否成功。项目详细安装说明可参考 README.md。
核心窗口组件解析
PyQt-Fluent-Widgets 提供了多种预置窗口类型,其中 FluentWindow 是构建应用的基础。该类封装了导航栏、标题栏和内容区域,支持多种显示模式切换。核心实现位于 qfluentwidgets/window/fluent_window.py,关键特性包括:
- 内置云母效果(Windows 11 支持),提供半透明磨砂质感
- 自适应明暗主题切换
- 可折叠导航栏,支持多种显示模式
- 内置页面切换动画
以下是 FluentWindow 类的简化结构:
class FluentWindow(FluentWindowBase):
def __init__(self, parent=None):
super().__init__(parent)
self.setTitleBar(FluentTitleBar(self))
self.navigationInterface = NavigationInterface(self, showReturnButton=True)
# 布局初始化代码...
def addSubInterface(self, interface, icon, text, position=NavigationItemPosition.TOP):
# 添加子界面实现...
五分钟实现第一个界面
以下是一个完整的 Fluent 风格界面示例,实现了包含两个子界面的应用窗口。创建 demo.py 文件,输入以下代码:
import sys
from PyQt5.QtWidgets import QApplication, QWidget, QLabel, QVBoxLayout
from qfluentwidgets import FluentWindow, NavigationItemPosition, FluentIcon
class HomeInterface(QWidget):
def __init__(self, parent=None):
super().__init__(parent)
self.setObjectName("homeInterface")
layout = QVBoxLayout(self)
layout.addWidget(QLabel("欢迎使用 Fluent 风格应用", self))
class SettingsInterface(QWidget):
def __init__(self, parent=None):
super().__init__(parent)
self.setObjectName("settingsInterface")
layout = QVBoxLayout(self)
layout.addWidget(QLabel("应用设置界面", self))
if __name__ == "__main__":
app = QApplication(sys.argv)
# 创建主窗口
window = FluentWindow()
window.setWindowTitle("我的第一个 Fluent 应用")
window.resize(800, 600)
# 添加子界面
window.addSubInterface(HomeInterface(), FluentIcon.HOME, "首页")
window.addSubInterface(SettingsInterface(), FluentIcon.SETTING, "设置", NavigationItemPosition.BOTTOM)
window.show()
sys.exit(app.exec_())
运行上述代码,将看到一个具有现代美感的应用窗口,包含侧边导航栏和内容区域。导航项支持点击切换,界面具有平滑过渡动画。更复杂的示例可参考 examples/gallery/demo.py。
界面美化与交互增强
PyQt-Fluent-Widgets 内置多种主题样式,默认支持明暗两种模式。可通过以下代码切换主题:
from qfluentwidgets import setTheme, Theme
# 设置为深色主题
setTheme(Theme.DARK)
窗口支持云母效果(Windows 11 特有),可通过 setMicaEffectEnabled(True) 启用,使界面具有半透明磨砂效果。下图展示了不同显示模式的导航界面:
导航栏支持自动隐藏和展开,可通过鼠标拖拽边界调整宽度。这些交互特性极大提升了应用的用户体验。
快速开发技巧与资源
为加速开发,推荐使用以下资源:
- 示例代码库:examples/ 目录包含丰富的组件示例,涵盖按钮、对话框、布局等
- 图标资源:内置 Fluent 风格图标库,可通过 qfluentwidgets/common/icon.py 查看所有可用图标
- 官方文档:完整的 API 文档和使用指南位于 docs/ 目录
开发时,建议先参考示例代码,再根据需求修改定制。对于常见问题,可查阅项目 issue 列表 或提交新问题。
总结与展望
本文介绍了 PyQt-Fluent-Widgets 的快速上手方法,包括环境安装、核心窗口使用和界面美化技巧。通过简单的代码示例,你可以快速构建出符合 Fluent Design 规范的现代界面。PyQt-Fluent-Widgets 持续更新迭代,未来将支持更多组件和特性。
现在,你已经掌握了 PyQt-Fluent-Widgets 的基本使用方法,赶快动手实践,将你的 PyQt 应用升级为现代化界面吧!如果觉得本文对你有帮助,请点赞、收藏,并关注项目获取最新更新。
GLM-5智谱 AI 正式发布 GLM-5,旨在应对复杂系统工程和长时域智能体任务。Jinja00
GLM-5.1GLM-5.1是智谱迄今最智能的旗舰模型,也是目前全球最强的开源模型。GLM-5.1大大提高了代码能力,在完成长程任务方面提升尤为显著。和此前分钟级交互的模型不同,它能够在一次任务中独立、持续工作超过8小时,期间自主规划、执行、自我进化,最终交付完整的工程级成果。Jinja00
MiniMax-M2.7MiniMax-M2.7 是我们首个深度参与自身进化过程的模型。M2.7 具备构建复杂智能体应用框架的能力,能够借助智能体团队、复杂技能以及动态工具搜索,完成高度精细的生产力任务。Python00- QQwen3.5-397B-A17BQwen3.5 实现了重大飞跃,整合了多模态学习、架构效率、强化学习规模以及全球可访问性等方面的突破性进展,旨在为开发者和企业赋予前所未有的能力与效率。Jinja00
HY-Embodied-0.5这是一套专为现实世界具身智能打造的基础模型。该系列模型采用创新的混合Transformer(Mixture-of-Transformers, MoT) 架构,通过潜在令牌实现模态特异性计算,显著提升了细粒度感知能力。Jinja00
LongCat-AudioDiT-1BLongCat-AudioDiT 是一款基于扩散模型的文本转语音(TTS)模型,代表了当前该领域的最高水平(SOTA),它直接在波形潜空间中进行操作。00

