A pure QML multi-skin component engine (Fluent + Neobrutalism) with 120fps+ smooth animations
Project description
PrismQML
简体中文 | English
基于 PySide6 + QML 的 Fluent Design 组件库,提供 120fps+ 流畅动画体验。
✨ 特性
- 纯 QML 渲染:无帧率限制,120fps+ 流畅动画
- Fluent Design:微软 Fluent Design System 组件
- Python 集成:PySide6 无缝集成,Python 侧管理业务逻辑
- 配置系统:JSON 持久化 + 原子写入 + QML Property 桥接
- 响应式状态:细粒度 Store 状态管理,支持 watch / batch 模式
- 窗口管理:多种窗口布局 + 懒加载 + 云母效果 + 系统托盘
- 跨平台:Windows、macOS、Linux
📦 安装
pip install prismqml
注:PyPI 包名为
prismqml(prismqml已被占用),但导入名仍是prismqml(from prismqml import ...)。
开发模式安装:
git clone https://github.com/aki-riko/PrismQML.git
cd PrismQML
pip install -e ".[dev]"
🚀 快速开始
from prismqml import App, Window, WindowType
app = App()
window = app.create_window(WindowType.BAR)
window.setWindowTitle("我的应用")
window.resize(1200, 800)
# 添加导航页面
window.addPage(HomePage, "Home", "首页")
window.addPage(SettingsPage, "Settings", "设置")
window.show()
app.exec()
🏗️ 架构
prismqml/
├── PrismQML/ # QML 组件(模块名 PrismQML)
│ ├── controls/ # UI 控件
│ ├── _internal/ # 内部窗口实现
│ └── FluentEnums/ # 枚举与常量
└── python/ # Python 模块
├── config/ # 配置管理系统
├── core/ # 核心引擎(主题/日志/图标/阴影)
├── window/ # 窗口管理(懒加载/云母/托盘)
├── state/ # 响应式状态存储
├── providers/ # 功能提供者(SVG/二维码/取色器)
└── models/ # 数据模型(高性能表格)
📐 窗口类型
| 类型 | 枚举值 | 说明 |
|---|---|---|
WindowType.BAR |
1 | 紧凑侧边导航(默认) |
WindowType.SPLIT |
0 | 展开式侧边导航 |
WindowType.FILLED |
2 | 填充式分割窗口 |
from prismqml import App, Window, WindowType
app = App()
# 紧凑侧边导航(默认)
window = app.create_window(WindowType.BAR)
# 展开式侧边导航
window = app.create_window(WindowType.SPLIT)
🎨 主题系统
切换主题
from prismqml import setTheme, Theme
setTheme(Theme.LIGHT) # 浅色
setTheme(Theme.DARK) # 深色
setTheme(Theme.AUTO) # 跟随系统
自定义主题色
from prismqml import setAccentColor, getAccentColor
setAccentColor("#0078d4")
print(getAccentColor()) # "#0078d4"
QML 中使用
import PrismQML as Fluent
// Primary 按钮(style_primary 自动使用全局主题色)
Fluent.Button {
text: "确定"
style: Fluent.Enums.button.style_primary
}
// 访问 ThemeManager 属性
Rectangle {
color: ThemeManager.accentColor
}
说明:
ComboBox、Slider因与 QtQuick.Controls 原生类型同名,未在顶层PrismQML模块导出, 需按子模块目录导入后使用,例如import "../prismqml/PrismQML/controls/inputs"。
⚙️ 配置系统
配置系统采用五层架构:Validator → SettingEntry → SettingsBase → AppConfig → ConfigManager
- JSON 持久化:默认存储于
~/.prismqml/app.json - 原子写入:先写临时文件再替换,防止断电数据丢失
- QML 桥接:通过
ConfigManager单例暴露为 QML Property
from prismqml.python.config import AppConfig, getConfigManager
# 获取配置值
config = getConfigManager()
print(config.lazyLoading) # True
print(config.dpiScale) # 0(跟随系统)
# 修改配置(自动保存到 JSON)
config.setDpiScale(150)
自定义配置项
from typing import ClassVar
from prismqml.python.config import (
SettingsBase, SettingEntry, EnumEntry,
Validator,
)
class MyAppConfig(SettingsBase):
auto_save: ClassVar[SettingEntry] = SettingEntry(
group="Editor", name="AutoSave",
default=True, validator=Validator.boolean(),
)
font_size: ClassVar[EnumEntry] = EnumEntry(
group="Editor", name="FontSize",
default=14,
validator=Validator.choice([12, 14, 16, 18, 20, 24]),
)
📊 状态管理
Store 提供响应式状态存储,支持细粒度 watch 和批量更新:
from prismqml import Store
class AppStore(Store):
def __init__(self):
super().__init__("app")
self.define("user", None)
self.define("count", 0)
store = AppStore()
# 监听变化
store.watch("count", lambda new, old: print(f"{old} → {new}"))
# 设置值
store.set("count", 1) # 输出: 0 → 1
# 批量更新(合并通知)
with store.batch():
store.set("count", 10)
store.set("user", "Alice")
# 退出 with 时统一通知
# 字典语法
store["count"] = 20
print(store["count"]) # 20
🔔 系统托盘
from prismqml import SystemTrayIcon, Icon
tray = SystemTrayIcon(icon="AppIcon.png", toolTip="我的应用")
tray.addAction(text="显示", icon="Visibility", triggered=window.show)
tray.addSeparator()
tray.addAction(text="退出", icon="Power", triggered=app.quit)
tray.show()
🧩 UI 组件
控件
Button · Card · CheckBox · ToggleSwitch · LineEdit · ComboBox · Slider · ProgressBar · SpinBox · TableView · ListView · TreeView
导航
NavigationBar · NavigationView · Pivot · Breadcrumb · Windows
特效
Shadow · ShadowedRectangle · ColorOverlay · GaussianBlur
完整组件清单见各
controls/子目录的qmldir。ComboBox、Slider等与 QtQuick 原生同名的组件需经子模块目录导入。
🧪 测试
python -m pytest tests/ -v
📄 License
PrismQML is licensed under the MIT License.
Copyright © 2026 aki-riko.
🙏 Credits
- Design inspired by the Microsoft Fluent Design System.
- Icons from Microsoft Fluent UI System Icons (MIT License).
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file prismqml-0.2.14.tar.gz.
File metadata
- Download URL: prismqml-0.2.14.tar.gz
- Upload date:
- Size: 1.8 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9ecd0723d6772e70acd77fec5c3cd0573aeda7d037cb6675305c9198397d2357
|
|
| MD5 |
48991c6bd63003b16e2a6cdaad72b5d5
|
|
| BLAKE2b-256 |
55645eb307f0fe994650a2775cff2849e21fe32c0000a3b46a636d5e9197ccae
|
Provenance
The following attestation bundles were made for prismqml-0.2.14.tar.gz:
Publisher:
release.yml on aki-riko/PrismQML
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prismqml-0.2.14.tar.gz -
Subject digest:
9ecd0723d6772e70acd77fec5c3cd0573aeda7d037cb6675305c9198397d2357 - Sigstore transparency entry: 1935296636
- Sigstore integration time:
-
Permalink:
aki-riko/PrismQML@d1844474cd669465ba89894566c8338751dbbf17 -
Branch / Tag:
refs/tags/v0.2.14 - Owner: https://github.com/aki-riko
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d1844474cd669465ba89894566c8338751dbbf17 -
Trigger Event:
push
-
Statement type:
File details
Details for the file prismqml-0.2.14-cp39-abi3-win_amd64.whl.
File metadata
- Download URL: prismqml-0.2.14-cp39-abi3-win_amd64.whl
- Upload date:
- Size: 4.1 MB
- Tags: CPython 3.9+, Windows x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
35b893da7edd4d8948446d8da68b95f0693718895f772b9ce8f9f227544c6d5e
|
|
| MD5 |
92548cdf76eb845d609f6ecebfdadf42
|
|
| BLAKE2b-256 |
3e974ef6534cb8160d104a6ea8c9e9dfe4a16a2dc2894ac156642e24a1dfc6b9
|
Provenance
The following attestation bundles were made for prismqml-0.2.14-cp39-abi3-win_amd64.whl:
Publisher:
release.yml on aki-riko/PrismQML
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prismqml-0.2.14-cp39-abi3-win_amd64.whl -
Subject digest:
35b893da7edd4d8948446d8da68b95f0693718895f772b9ce8f9f227544c6d5e - Sigstore transparency entry: 1935296662
- Sigstore integration time:
-
Permalink:
aki-riko/PrismQML@d1844474cd669465ba89894566c8338751dbbf17 -
Branch / Tag:
refs/tags/v0.2.14 - Owner: https://github.com/aki-riko
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d1844474cd669465ba89894566c8338751dbbf17 -
Trigger Event:
push
-
Statement type:
File details
Details for the file prismqml-0.2.14-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.
File metadata
- Download URL: prismqml-0.2.14-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
- Upload date:
- Size: 4.3 MB
- Tags: CPython 3.9+, manylinux: glibc 2.17+ x86-64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7aa20aead14827670ed43527dbd4da41f0fd63287255485173ea2f9b1c23fdc0
|
|
| MD5 |
e2e6ba084e5e4f6a2fdee6d8947e9b61
|
|
| BLAKE2b-256 |
5b888c216f8768e3d840b3b54ee450419147d543f6daae07cfb62000e38f0ad3
|
Provenance
The following attestation bundles were made for prismqml-0.2.14-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl:
Publisher:
release.yml on aki-riko/PrismQML
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prismqml-0.2.14-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl -
Subject digest:
7aa20aead14827670ed43527dbd4da41f0fd63287255485173ea2f9b1c23fdc0 - Sigstore transparency entry: 1935296690
- Sigstore integration time:
-
Permalink:
aki-riko/PrismQML@d1844474cd669465ba89894566c8338751dbbf17 -
Branch / Tag:
refs/tags/v0.2.14 - Owner: https://github.com/aki-riko
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d1844474cd669465ba89894566c8338751dbbf17 -
Trigger Event:
push
-
Statement type:
File details
Details for the file prismqml-0.2.14-cp39-abi3-macosx_11_0_arm64.whl.
File metadata
- Download URL: prismqml-0.2.14-cp39-abi3-macosx_11_0_arm64.whl
- Upload date:
- Size: 4.2 MB
- Tags: CPython 3.9+, macOS 11.0+ ARM64
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2b576eabf74ed201a633a7eaf8345bd90b6103ff7854e29e2218d6ee5af0da97
|
|
| MD5 |
0e5b69e72762e1ebf166b04ca4f4e0ee
|
|
| BLAKE2b-256 |
b2ae72c2e9154f1cd4fbbd851bdddb9154f7f0f64db76c4ea7c5ca995639a189
|
Provenance
The following attestation bundles were made for prismqml-0.2.14-cp39-abi3-macosx_11_0_arm64.whl:
Publisher:
release.yml on aki-riko/PrismQML
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
prismqml-0.2.14-cp39-abi3-macosx_11_0_arm64.whl -
Subject digest:
2b576eabf74ed201a633a7eaf8345bd90b6103ff7854e29e2218d6ee5af0da97 - Sigstore transparency entry: 1935296711
- Sigstore integration time:
-
Permalink:
aki-riko/PrismQML@d1844474cd669465ba89894566c8338751dbbf17 -
Branch / Tag:
refs/tags/v0.2.14 - Owner: https://github.com/aki-riko
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@d1844474cd669465ba89894566c8338751dbbf17 -
Trigger Event:
push
-
Statement type: