| Crates.io | egui-widget-texicon |
| lib.rs | egui-widget-texicon |
| version | 0.1.0 |
| created_at | 2024-11-10 08:01:27.405425+00 |
| updated_at | 2024-11-10 08:01:27.405425+00 |
| description | An egui widget that combines an icon and text, often found in modern UIs. |
| homepage | |
| repository | https://github.com/resonanz/egui-widget-texicon |
| max_upload_size | |
| id | 1442709 |
| size | 8,903 |
egui-widget-texicon is an egui widget that combines an icon and text, often found in modern UIs.
Please submit an issue on Github if you have suggestions or improvements.
In Cargo.toml add the following dependency:
[dependencies]
egui-widget-texicon = 0.1.0 <--- The latest version number can be found on Crates.io.
Or you could use the following if developing locally:
[dependencies]
egui-widget-texicon = { path = "/Github/egui-widget-texicon/" }
In app.rs import the crate using:
use egui_themes::{StateMachine, MOCHA};
Using the TemplateApp struct, define a run_once boolean and a StateMachine variable to hold the current theme:
pub struct TemplateApp {
run_once: bool,
my_theme: StateMachine,
}
impl Default for TemplateApp {
fn default() -> Self {
Self {
run_once: false,
my_theme: egui_themes::StateMachine::new(),
}
}
}
Inside fn update... set the startup theme state using the run_once boolean:
fn update(&mut self, ctx: &Context, _frame: &mut eframe::Frame) {
if self.run_once == false {
self.run_once = true;
self.my_theme.set_theme(ctx, &MOCHA);
}
Then in the main loop:
// Theme cycle button
let b = ui.add(egui::Button::new("☀🌙").sense(Sense::click()));
if b.clicked() {
self.my_theme.rotate_theme(&ctx);
} else if b.hovered() {
b.on_hover_text("Click for next theme...");
}
https://github.com/user-attachments/assets/ddcfce39-8377-440f-bce6-b98e7945c441