#macro-derive #egui #value #editing #ui #widgets #automatic

egui-probe

Trait and derive macro for exposing value editing in egui

13 releases (7 breaking)

0.7.0 Dec 19, 2024
0.6.0 Oct 14, 2024
0.5.1 Jul 9, 2024
0.2.0 Feb 7, 2024
0.0.0 Dec 22, 2023

#232 in Rust patterns

Download history 25/week @ 2024-09-22 7/week @ 2024-09-29 7/week @ 2024-10-06 202/week @ 2024-10-13 46/week @ 2024-10-20 26/week @ 2024-10-27 38/week @ 2024-11-03 28/week @ 2024-11-10 30/week @ 2024-11-17 8/week @ 2024-11-24 12/week @ 2024-12-01 54/week @ 2024-12-08 208/week @ 2024-12-15 49/week @ 2024-12-22 51/week @ 2024-12-29 143/week @ 2025-01-05

451 downloads per month
Used in 2 crates

MIT/Apache

64KB
1.5K SLoC

Egui Probe

docs.rs Crates.io Total Downloads Discord

Effortlessly create UI widgets to display and modify value types using a derive macro with rich customization via attributes. This library is exclusively for the egui UI framework.

Features

  • 🪄 Derive Macro: Automatically generate UI widgets for your types.
  • 🎨 Rich Customization: Customize the generated widgets using attributes.
  • 🚀 Seamless Integration: Designed to work seamlessly with egui.

Getting Started

Add egui_probe to your Cargo.toml:

[dependencies]
egui_probe = "0.5.2"

Usage

Derive EguiProbe for your types and use attributes to customize the UI:

use egui_probe::{EguiProbe, Probe, angle};
use eframe::App;

#[derive(EguiProbe)]
struct DemoValue {
    boolean: bool,

    #[egui_probe(toggle_switch)]
    boolean_toggle: bool,

    float: f32,

    #[egui_probe(range = 22..=55)]
    range: usize,

    #[egui_probe(as angle)]
    angle: f32,

    #[egui_probe(name = "renamed ^_^")]
    renamed: u8,

    inner: InnerValue,
}

#[derive(Default, EguiProbe)]
struct InnerValue {
    line: String,

    #[egui_probe(multiline)]
    multi_line: String,
}

struct EguiProbeDemoApp {
    value: DemoValue,
}

impl App for EguiProbeDemoApp {
    fn update(&mut self, ctx: &egui::Context, _frame: &mut eframe::Frame) {
        egui::CentralPanel::default().show(ctx, |ui| {
            Probe::new(&mut self.value).show(ui);
        });
    }
}

Attributes

  • #[egui_probe(toggle_switch)]: Render a boolean as a toggle switch.
  • #[egui_probe(range = 22..=55)]: Specify a range for numeric values.
  • #[egui_probe(as angle)]: Render a float as an angle.
  • #[egui_probe(name = "custom name")]: Rename the field in the UI.
  • #[egui_probe(multiline)]: Render a string as a multiline text box.

License

This project is licensed under either of

  • MIT License
  • Apache License, Version 2.0

at your option.

Contributing

Contributions are welcome! Please open an issue or submit a pull request.

Enjoy building your UI with Egui Probe! 🚀

Dependencies

~4–9.5MB
~89K SLoC