penpot/render-wasm
Alejandro Alonso 8c6a80829f
Merge pull request #6671 from penpot/azazeln28-refactor-minor-perf-issues
♻️ Refactor some minor perf issues
2025-06-17 11:30:43 +02:00
..
docs 🔧 Add methods to render text as path (#6624) 2025-06-16 13:37:29 +02:00
src Merge pull request #6671 from penpot/azazeln28-refactor-minor-perf-issues 2025-06-17 11:30:43 +02:00
.gitignore
_build_env 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
build 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
Cargo.lock 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
Cargo.toml 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
lint 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
README.md
test 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
watch 🎉 Support for webp images (#6665) 2025-06-10 08:40:30 +02:00
watch_test Add support for WASM transforms 2025-02-11 12:36:44 +01:00

render-wasm

Canvas-based WebAssembly render engine for Penpot.

This is a Rust crate that targets Emscripten (wasm32-unknown-emscripten). Underneath, it uses Skia via custom binaries of the rust-skia crate.

How to build

With the Penpot Development Environment running, create a new tab in the tmux.

cd penpot/render-wasm
./build

The build script will compile the project and copy the .js and .wasm files to their correct location within the frontend app.

Edit your local frontend/resources/public/js/config.js to add the following flags:

  • enable-feature-render-wasm to enable this render engine.
  • enable-render-wasm-dpr (optional), to enable using the device pixel ratio.

Docs