penpot/render-wasm
Elena Torró 4869373a43
🔧 Add methods to render text as path (#6624)
* 🔧 Refactor text strokes drawing

* 🔧 Add text to path methods for future usage

* 📚 Add text as paths internal documentation
2025-06-16 13:37:29 +02:00
..
docs 🔧 Add methods to render text as path (#6624) 2025-06-16 13:37:29 +02:00
src 🔧 Add methods to render text as path (#6624) 2025-06-16 13:37:29 +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

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