ratframe : egui widget + ratatui backend (WASM)
See bevy and macroquad folders for game engine examples
RataguiBackend is the name of the backend/widget in code
cargo add ratframe
git clone https://github.com/gold-silver-copper/ratatui_egui_wasm.git
This repo provides the Ratagui Backend, which is also a Widget for egui. So you can have a whole ratatui terminal inside of egui. Also since egui is so WASM compatible, this means we can use this to compile ratatui to WASM ! Look at examples, you can run the basic ones by doing
cargo run --example hello_world_minimum
To run a web version, enter an example directory such as demo_web or colors_web , then simply execute in the directory
cd examples/demo_web
trunk serve
or to build
trunk build --release
The goal is for this to be the simplest way to write a TUI app for WASM in Rust. You can compile your app natively or for the web, and share it using Github Pages.
You can remove the eframe dependency and use another backend such as bevy or macroquad by setting default-features = false for ratframe
Here is the simplest hello world
use ;
use ;
use RataguiBackend;
REST IS FROM ETEMPLATE DOCS
Getting started
Start by clicking "Use this template" at https://github.com/emilk/eframe_template/ or follow these instructions.
Change the name of the crate: Chose a good name for your project, and change the name to it in:
Cargo.toml- Change the
package.namefromeframe_templatetoyour_crate. - Change the
package.authors
- Change the
main.rs- Change
eframe_template::TemplateApptoyour_crate::TemplateApp
- Change
index.html- Change the
<title>eframe template</title>to<title>your_crate</title>. optional.
- Change the
assets/sw.js- Change the
'./eframe_template.js'to./your_crate.js(infilesToCachearray) - Change the
'./eframe_template_bg.wasm'to./your_crate_bg.wasm(infilesToCachearray)
- Change the
Learning about egui
src/app.rs contains a simple example app. This is just to give some inspiration - most of it can be removed if you like.
The official egui docs are at https://docs.rs/egui. If you prefer watching a video introduction, check out https://www.youtube.com/watch?v=NtUkr_z7l84. For inspiration, check out the the egui web demo and follow the links in it to its source code.
Testing locally
Make sure you are using the latest version of stable rust by running rustup update.
cargo run --release
On Linux you need to first run:
sudo apt-get install libxcb-render0-dev libxcb-shape0-dev libxcb-xfixes0-dev libxkbcommon-dev libssl-dev
On Fedora Rawhide you need to run:
dnf install clang clang-devel clang-tools-extra libxkbcommon-devel pkg-config openssl-devel libxcb-devel gtk3-devel atk fontconfig-devel
Web Locally
You can compile your app to WASM and publish it as a web page.
We use Trunk to build for web target.
- Install the required target with
rustup target add wasm32-unknown-unknown. - Install Trunk with
cargo install --locked trunk. - Run
trunk serveto build and serve onhttp://127.0.0.1:8080. Trunk will rebuild automatically if you edit the project. - Open
http://127.0.0.1:8080/index.html#devin a browser. See the warning below.
assets/sw.jsscript will try to cache our app, and loads the cached version when it cannot connect to server allowing your app to work offline (like PWA). appending#devtoindex.htmlwill skip this caching, allowing us to load the latest builds during development.
Web Deploy
- Just run
trunk build --release. - It will generate a
distdirectory as a "static html" website - Upload the
distdirectory to any of the numerous free hosting websites including GitHub Pages. - we already provide a workflow that auto-deploys our app to GitHub pages if you enable it.
To enable Github Pages, you need to go to Repository -> Settings -> Pages -> Source -> set to
gh-pagesbranch and/(root).If
gh-pagesis not available inSource, just create and push a branch calledgh-pagesand it should be available.If you renamed the
mainbranch to something else (say you re-initialized the repository withmasteras the initial branch), be sure to edit the github workflows.github/workflows/pages.ymlfile to reflect the changeon: push: branches: - <branch name>
You can test the template app at https://emilk.github.io/eframe_template/.
Updating egui
As of 2023, egui is in active development with frequent releases with breaking changes. eframe_template will be updated in lock-step to always use the latest version of egui.
When updating egui and eframe it is recommended you do so one version at the time, and read about the changes in the egui changelog and eframe changelog.