One canvas API, multiple backends
Project description

rendercanvas
One canvas API, multiple backends 🚀
This project is part of pygfx.org
Introduction
See how the two windows above look the same? That's the idea; they also look the same to the code that renders to them. Yet, the GUI systems are very different (Qt vs glfw in this case). Now that's a powerful abstraction!
Purpose
Providing a generic API for:
- managing a canvas window (
BaseRenderCanvas). - presenting rendered results with
wgpu(WgpuContext). - presenting rendered results as a bitmap (
BitmapContext). - working with events that have standardized behavior.
Implement that on top of a variety of backends:
- Running on desktop with a light backend (glfw).
- Running in the browser (with Pyodide or PyScript).
- Running from a (Jupyter) notebook.
- Embedding as a widget in a GUI library.
- Qt
- wx
- In addition to the GUI libraries mentioned above, the following event loops are supported:
- asyncio
- trio
- raw
Installation
pip install rendercanvas
To have at least one backend, we recommend:
pip install rendercanvas glfw
Usage
Also see the online documentation and the examples.
A minimal example that renders noise:
import numpy as np
from rendercanvas.auto import RenderCanvas, loop
canvas = RenderCanvas(update_mode="continuous")
context = canvas.get_bitmap_context()
@canvas.request_draw
def animate():
w, h = canvas.get_logical_size()
bitmap = np.random.uniform(0, 255, (h, w)).astype(np.uint8)
context.set_bitmap(bitmap)
loop.run()
Run wgpu visualizations:
from rendercanvas.auto import RenderCanvas, loop
from rendercanvas.utils.cube import setup_drawing_sync
canvas = RenderCanvas(
title="The wgpu cube example on $backend", update_mode="continuous"
)
draw_frame = setup_drawing_sync(canvas)
canvas.request_draw(draw_frame)
loop.run()
Embed in a Qt application:
from PySide6 import QtWidgets
from rendercanvas.qt import QRenderWidget
class Main(QtWidgets.QWidget):
def __init__(self):
super().__init__()
splitter = QtWidgets.QSplitter()
self.canvas = QRenderWidget(splitter)
...
app = QtWidgets.QApplication([])
main = Main()
app.exec()
Async or not async
We support both; a render canvas can be used in a fully async setting using e.g. Asyncio or Trio, or in an event-driven framework like Qt.
If you like callbacks, loop.call_later() always works. If you like async, use loop.add_task().
See the docs on async for details.
License
This code is distributed under the 2-clause BSD license.
Developers
- Clone the repo.
- Install
rendercanvasand developer deps usingpip install -e .[dev]. - Use
ruff formatto apply autoformatting. - Use
ruff checkto check for linting errors. - Optionally, if you install pre-commit hooks with
pre-commit install, lint fixes and formatting will be automatically applied ongit commit. - Use
pytest teststo run the tests. - Use
pytest examplesto run a subset of the examples.
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 Distribution
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 rendercanvas-2.4.2.tar.gz.
File metadata
- Download URL: rendercanvas-2.4.2.tar.gz
- Upload date:
- Size: 76.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
21bdc6fdfc36de207a29497ac580ba4cd64de920bc46ecdafd29a8b689ad8601
|
|
| MD5 |
2b8f32ea1d02bb53835b60dd558de024
|
|
| BLAKE2b-256 |
4e44e938d7d178c69159f88944c0d22a3dd1c68388e335e0033a3af94c2d3f2c
|
Provenance
The following attestation bundles were made for rendercanvas-2.4.2.tar.gz:
Publisher:
ci.yml on pygfx/rendercanvas
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
rendercanvas-2.4.2.tar.gz -
Subject digest:
21bdc6fdfc36de207a29497ac580ba4cd64de920bc46ecdafd29a8b689ad8601 - Sigstore transparency entry: 708663648
- Sigstore integration time:
-
Permalink:
pygfx/rendercanvas@d8b2c57b4c3edcbe73d0ff617417f1533a87b137 -
Branch / Tag:
refs/tags/v2.4.2 - Owner: https://github.com/pygfx
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
ci.yml@d8b2c57b4c3edcbe73d0ff617417f1533a87b137 -
Trigger Event:
push
-
Statement type:
File details
Details for the file rendercanvas-2.4.2-py3-none-any.whl.
File metadata
- Download URL: rendercanvas-2.4.2-py3-none-any.whl
- Upload date:
- Size: 90.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
c7af9ae8ac86c79f8b773f19e9127fa2a5c901f605b07cf0fdfc460eaf6813df
|
|
| MD5 |
40accc1013cdd9c94b77526c145a9f0a
|
|
| BLAKE2b-256 |
5f49559e40b25b35c02c81bb9deb46914d8d1ba0012e1ab6100bbb63dac3b66e
|
Provenance
The following attestation bundles were made for rendercanvas-2.4.2-py3-none-any.whl:
Publisher:
ci.yml on pygfx/rendercanvas
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
rendercanvas-2.4.2-py3-none-any.whl -
Subject digest:
c7af9ae8ac86c79f8b773f19e9127fa2a5c901f605b07cf0fdfc460eaf6813df - Sigstore transparency entry: 708663663
- Sigstore integration time:
-
Permalink:
pygfx/rendercanvas@d8b2c57b4c3edcbe73d0ff617417f1533a87b137 -
Branch / Tag:
refs/tags/v2.4.2 - Owner: https://github.com/pygfx
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
ci.yml@d8b2c57b4c3edcbe73d0ff617417f1533a87b137 -
Trigger Event:
push
-
Statement type: