| Crates.io | egui_material |
| lib.rs | egui_material |
| version | 0.1.1 |
| created_at | 2025-07-07 12:11:52.122882+00 |
| updated_at | 2025-07-10 09:31:33.294083+00 |
| description | Material Design components for egui |
| homepage | |
| repository | https://codeberg.org/Codestar/egui_material |
| max_upload_size | |
| id | 1741147 |
| size | 977,796 |
Material Design components for egui/eframe.
This project is a work in progress. Currently implemented components:
See the Live demo for details.

cargo add egui_material
in your code:
use egui_material::{button, ButtonVariant, ButtonColor};
...
if button("My Button")
.variant(Some(ButtonVariant::Contained))
.color(Some(ButtonColor::Primary))
.ui(ui)
.clicked()
{
// handle click
}
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
You can compile your app to WASM and publish it as a web page.
We use Trunk to build for web target.
rustup target add wasm32-unknown-unknown.cargo install --locked trunk.trunk serve to build and serve on http://127.0.0.1:8080/index.html#dev. Trunk will rebuild automatically if you edit the project.http://127.0.0.1:8080/index.html#dev in 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.
trunk build --release.dist directory as a "static html" websitedist directory to any of the numerous free hosting websites including GitHub Pages.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/.
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.
Currently this is a manual step.
dist from .gitignore./deploy_pages.sh