Crates.io | egui-widget-texicon |
lib.rs | egui-widget-texicon |
version | 0.1.0 |
source | src |
created_at | 2024-11-10 08:01:27.405425 |
updated_at | 2024-11-10 08:01:27.405425 |
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