Skip to main content

Python bindings for Qlementine, a modern QStyle for desktop Qt6 applications

Project description

PyQt6/PySide6-Qlementine

PyQt6/PySide6 Bindings for (the amazing) Qlementine

Modern QStyle for desktop Qt6 applications... ready for Python!

Installation

pip install PyQt6-Qlementine
# or 
pip install PySide6-Qlementine

Usage

# or PySide6 & PySide6Qlementine
from PyQt6.QtWidgets import QApplication
from PyQt6.QtCore import QJsonDocument
from PyQt6Qlementine import QlementineStyle, Theme

app = QApplication([])

# Apply Qlementine as the application style
# (this alone will apply the default Qlementine theme, which is lovely)
style = QlementineStyle(app)
app.setStyle(style)

# Define a custom theme, for all keys, see:
# https://oclero.github.io/qlementine/theme/#full-example
theme_dict = {
    "meta": {"name": "Custom", "author": "Your Name", "version": "1.0"},
    "primaryColor": "#ff00ff",
    "backgroundColorMain1": "#1a1a2e",
    "backgroundColorMain2": "#1a1a2e",
}

theme = Theme.fromJsonDoc(QJsonDocument.fromVariant(theme_dict))
style.setTheme(theme)

See C++ documentation for more information.

See also examples in this repo.

The autogenerated type stubs are also useful for understanding the API.

Why QStyle over QSS?

If you're coming from the Python Qt ecosystem, you're likely used to theming via Qt Style Sheets (QSS) — every major Python theming library (QDarkStyleSheet, qt-material, BreezeStyleSheets, etc.) relies on them.

QSS is easy to author, but it comes with serious trade-offs: it breaks setPalette() and setFont(), ignores system dark/light mode changes, forces you to restyle all sub-controls when you customize one, and adds measurable startup and reparenting cost from CSS parsing.

A proper parametrized QStyle implementation (like Qlementine) avoids all of this — colors, spacing, animations, border-radii, and pixel metrics are computed natively in C++ with full QPainter access, zero parsing overhead, and complete respect for QPalette. The reason Python libraries haven't taken this approach is that subclassing QProxyStyle in Python incurs a C++/Python boundary crossing on every paint call, making it unperformant for anything beyond icon overrides.

Qlementine sidesteps that entirely: the style is implemented in C++ and simply exposed to Python (through these bindings), giving you the correctness and performance of a native QStyle implementation with the ease of use of a Python library (and parametrized geometry, colors, animations, and fonts through Qlementine's Theme API).

License

The code in this repository is licensed under the MIT License.

The packaged/distributed bindings are:

See the LICENSE file in each package for more details.

Developers & Contributing

Contributions are welcome! See CONTRIBUTING.md for dev tips.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-win_amd64.whl (2.3 MB view details)

Uploaded CPython 3.10+Windows x86-64

pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-manylinux_2_28_x86_64.whl (2.3 MB view details)

Uploaded CPython 3.10+manylinux: glibc 2.28+ x86-64

pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-macosx_11_0_arm64.whl (2.3 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

File details

Details for the file pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 ea1ae766bd6d3994b3184500583fb593b5320b2f7aa5e15cc0c3e1c8b978a8a6
MD5 1da7a8bfbc06921b8d32e842328fc997
BLAKE2b-256 bbe0d0be88e647f8ab77a506246db3bcf27f8f77ded77d8da10b9803c45935f6

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-win_amd64.whl:

Publisher: publish-pyqt6.yml on pyapp-kit/PyQlementine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-manylinux_2_28_x86_64.whl.

File metadata

File hashes

Hashes for pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 14a99e36e9bd7d56f9108a1dba3d2941836fe3887fe9199f9a39021d1e4718b0
MD5 fab21aeb2c1c1728aeeedd47de43fec2
BLAKE2b-256 60f34c57c9b5f2b50520fc8e290863180b0710f144ab9cbee97d0ec7ac8d7996

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-manylinux_2_28_x86_64.whl:

Publisher: publish-pyqt6.yml on pyapp-kit/PyQlementine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 d098706155224b70043b9677fbf6f1c6e740f10489a5d644ab8afa42d5cf4a1e
MD5 618faa73be5e43c2314c0e7878c36d51
BLAKE2b-256 e44b6509357bfafe616c7b57035f85425c5ea506055dabcf74cc6d6e0c44210b

See more details on using hashes here.

Provenance

The following attestation bundles were made for pyqt6_qlementine-1.4.3.0rc1-cp310-abi3-macosx_11_0_arm64.whl:

Publisher: publish-pyqt6.yml on pyapp-kit/PyQlementine

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page