QML FluentUI
A fluent design component library for Qt QML, You need Pyside6 PySide6-FluentUI-QML。
![win-badge] ![ubuntu-badge] ![macos-badge] ![release-badge] ![download-badge] ![download-latest]
English | 简体中文
[win-link]: https://github.com/zhuzichu520/FluentUI/actions?query=workflow%3AWindows "WindowsAction"
[win-badge]: https://github.com/zhuzichu520/FluentUI/workflows/Windows/badge.svg "Windows"
[ubuntu-link]: https://github.com/zhuzichu520/FluentUI/actions?query=workflow%3AUbuntu "UbuntuAction"
[ubuntu-badge]: https://github.com/zhuzichu520/FluentUI/workflows/Ubuntu/badge.svg "Ubuntu"
[macos-link]: https://github.com/zhuzichu520/FluentUI/actions?query=workflow%3AMacOS "MacOSAction"
[macos-badge]: https://github.com/zhuzichu520/FluentUI/workflows/MacOS/badge.svg "MacOS"
[release-link]: https://github.com/zhuzichu520/FluentUI/releases "Release status"
[release-badge]: https://img.shields.io/github/release/zhuzichu520/FluentUI.svg?style=flat-square "Release status"
[download-link]: https://github.com/zhuzichu520/FluentUI/releases/latest "Download status"
[download-badge]: https://img.shields.io/github/downloads/zhuzichu520/FluentUI/total.svg "Download status"
[download-latest]: https://img.shields.io/github/downloads/zhuzichu520/FluentUI/latest/total.svg "latest status"
This is a beautiful FluentUI component library based on Qt QML. Currently the main branch supports Qt 6. If you want to use it in Qt 5, checkout the Qt 5 branch.
## Requirements
+ Qt Core, Qt Quick, Qt QML, Qt ShaderTool, Qt 5 Compatibility Module. (**Essential**)
+ Qt LinguistTool (optional,for translations)
+ Qt Svg (optional, however essential for Qt 5)
Use [Qt Online Installers](https://download.qt.io/archive/online_installers/) to acquire the modules (**Recommended**) or compile them first before using the library.
## ⚽ Get started
+ Download the [pre-built release](https://github.com/zhuzichu520/FluentUI/releases). (Please specify your platform and compilers.)
+ run `example` program.
or
+ Clone the repository.
```SHELL
git clone --recursive https://github.com/zhuzichu520/FluentUI.git
```
+ Build
```
git clone --recursive https://github.com/zhuzichu520/FluentUI.git
cd FluentUI
mkdir build
cd build
cmake -DCMAKE_PREFIX_PATH= -DCMAKE_BUILD_TYPE=Release -GNinja
cmake --build . --config Release --target all --parallel
```
+ Use your IDE (`Qt Creator` or `CLion`) to open the project. (only **CMake** supported).
+ Compile the project. Then try to execute the `example` demo program.
+ Great! Now you are ready to write your first QML FluentUI program! Check the documentations for more details.
## 📑 Documentations
(Work in progress...🚀)
## Supported components
|Catalog|Detail|Notes / Demos|
|:----:|:----:|:----:|
|FluApp|The initial entry of the program|Router supported(SPA)|
|FluWindow|Frameless Window|*This only works on windows|
|FluAppBar|Title bar on top of the window|Drag, minimize, maximize and close are supported.|
|FluText|Common text||
|FluButton|Common button|data:image/s3,"s3://crabby-images/996cd/996cd93be90d3971ba68bf7cd7629079f61da20d" alt="btn" |
|FluFilledButton|Filled button|data:image/s3,"s3://crabby-images/b569d/b569d811fb3daa0b0c35c72a1d18be1a70c71329" alt="filledbtn"|
|FluTextButton|Text button|data:image/s3,"s3://crabby-images/eb0f3/eb0f30e64d06a28f5bb45d44dc76e3e72ddc9cdb" alt="textbtn"|
|FluToggleButton|Toggle buttons|data:image/s3,"s3://crabby-images/77bba/77bba2d29290d041088bbf744c2dac357ca44ec2" alt="togglebtn"|
|FluIcon|Common icon|data:image/s3,"s3://crabby-images/438d0/438d059cbf206ada497dcaf979278f9beb0ff12e" alt="icons"|
|FluRadioButton|radio button|data:image/s3,"s3://crabby-images/117d7/117d7a0cb30385edeb5968d15305d1c8229ee62c" alt="radiobtn"|
|FluTextBox|Single-line input box|data:image/s3,"s3://crabby-images/33e69/33e690195789311ae0154d2fe7b67fdc41432c0d" alt="textbox"|
|FluMultiLineTextBox|Multi-lines input area|data:image/s3,"s3://crabby-images/961f4/961f4dc0b78367ffe6eabff5ac24cb0aad4b90d4" alt="textarea"|
|FluToggleSwitch|toggle switch|data:image/s3,"s3://crabby-images/be491/be491c2d07682416fa964b1a89d733c15d25208a" alt="toggleswitch"|
View more [`here`](doc/md/all_components.md)!
## Reference
+ [**Windows design**: Design guidelines and toolkits of Microsoft.](https://learn.microsoft.com/en-us/windows/apps/design/)
+ [**Microsoft/WinUI-Gallery**: Microsoft's demo](https://github.com/microsoft/WinUI-Gallery)
## License
This FluentUI library currently licensed under [MIT License](./License)
## Star History
[data:image/s3,"s3://crabby-images/91b21/91b2100b72d69ac1073d32d2b49a9a0f5e2fc4a6" alt="Star History Chart"](https://star-history.com/#zhuzichu520/FluentUI&Date)
## ⚡ Visitor count
data:image/s3,"s3://crabby-images/83688/8368845a3843db864c7c749ccc6a1d02a831c216" alt=""