# bevy-inspector-egui
<div align="center">
<a href="https://crates.io/crates/bevy-inspector-egui">
<img src="https://img.shields.io/crates/v/bevy-inspector-egui.svg?style=flat-square"
alt="Crates.io version" />
</a>
<a href="https://docs.rs/bevy-inspector-egui">
<img src="https://img.shields.io/badge/docs-latest-blue.svg?style=flat-square"
alt="docs.rs docs" />
</a>
<img src="https://img.shields.io/crates/l/bevy-inspector-egui?style=flat-square"
alt="Download" />
</div>
<br/>
This crate provides the ability to annotate structs with a `#[derive(Inspectable)]`,
which opens a debug interface using [egui](https://github.com/emilk/egui) where you can visually edit the values of your struct live.
Your struct will then be available to you as a bevy resource.
<img src="./docs/inspector.jpg" alt="demonstration with a running bevy app" width="500"/>
## Example
```rust
use bevy_inspector_egui::Inspectable;
#[derive(Inspectable, Default)]
struct Data {
should_render: bool,
text: String,
#[inspectable(min = 42.0, max = 100.0)]
size: f32,
}
```
Add the `InspectorPlugin` to your App.
```rust
use bevy_inspector_egui::InspectorPlugin;
fn main() {
App::build()
.add_plugins(DefaultPlugins)
.add_plugin(InspectorPlugin::<Data>::new())
.add_system(your_system.system())
.run();
}
// fn your_system(data: Res<Data>) { /* */ }
```
## Bevy support table
|0.4|0.1-0.2|