The easy way to make a Rust app with a GUI
Go to file
Emil Ernerfeldt 26e1bb121f
Merge pull request #3 from woelper/master
Fix small typo
2021-02-03 20:05:15 +01:00
.github/workflows Attempt to fix the CI 2021-01-20 17:13:35 +01:00
docs Update to eframe / egui 0.8.0 2021-01-17 15:36:33 +01:00
src Update to eframe / egui 0.8.0 2021-01-17 15:36:33 +01:00
.gitignore Initial commit 2020-12-19 21:52:39 +01:00
build_web.sh Update to egui 0.7.0 with switch to eframe as the only dependency 2021-01-04 16:11:47 +01:00
Cargo.lock Update to eframe / egui 0.8.0 2021-01-17 15:36:33 +01:00
Cargo.toml Disable test suite due to weird build issue 2021-01-17 22:17:24 +01:00
check.sh Update to egui 0.7.0 with switch to eframe as the only dependency 2021-01-04 16:11:47 +01:00
README.md Fix small typo 2021-02-03 09:46:08 +01:00
setup_web.sh Initial commit 2020-12-19 21:52:39 +01:00
start_server.sh Initial commit 2020-12-19 21:52:39 +01:00

egui template

dependency status Build Status

This is a template repo for egui.

The goal is for this to be the simplest way to get started writing a GUI app in Rust.

You can compile your app natively or for the web, and share it using Github Pages.

Getting started

Start by clicking "Use this template" at https://github.com/emilk/egui_template/ or follow these instructions.

src/app.rs contains a simple example app. This is just to give some inspiration - most of it can be removed if you like.

Testing locally

cargo run --release

On Linux you need to first run sudo apt-get install libxcb-render0-dev libxcb-shape0-dev libxcb-xfixes0-dev.

Compiling for the web

You can compile your app to WASM and publish it as a web page. For this you need to set up some tools. There are a few simple scripts that help you with this:

./setup_web.sh
./build_web.sh
./start_server.sh
open http://127.0.0.1:8080/
  • setup_web.sh installs the tools required to build for web
  • build_web.sh compiles your code to wasm and puts it in the docs/ folder (see below)
  • start_server.sh starts a local HTTP server so you can test before you publish
  • Open http://127.0.0.1:8080/ in a web browser to view

The finished web app is found in the docs/ folder (this is so that you can easily share it with GitHub Pages). It consists of three files:

  • index.html: A few lines of HTML, CSS and JS that loads your app. You need to edit this (once) to replace egui_template with the name of your crate!
  • your_crate_bg.wasm: What the Rust code compiles to.
  • your_crate.js: Auto-generated binding between Rust and JS.

You can test the template app at https://emilk.github.io/egui_template/.

Updating egui

As of 2021, egui is in active development with frequent releases with breaking changes. egui_template will be updated in lock-step to always use the latest version of egui.