| Crates.io | imgui-sdl3 |
| lib.rs | imgui-sdl3 |
| version | 0.5.2 |
| created_at | 2025-07-25 09:59:18.639909+00 |
| updated_at | 2026-01-02 17:57:48.154027+00 |
| description | Integration of ImGui with SDL3 |
| homepage | |
| repository | https://github.com/florianvazelle/imgui-sdl3 |
| max_upload_size | |
| id | 1767361 |
| size | 127,600 |
This crate provides an SDL3 backend platform and renderer for imgui-rs.
For a canvas rendering backend, check out masonjmj/imgui-rs-sdl3-renderer.
use imgui_sdl3::ImGuiSdl3;
use sdl3::{event::Event, gpu::*, pixels::Color};
fn main() -> Result<(), Box<dyn std::error::Error>> {
// initialize SDL and its video subsystem
let mut sdl = sdl3::init()?;
let video_subsystem = sdl.video()?;
// create a new window
let window = video_subsystem
.window("Hello imgui-rs!", 1280, 720)
.position_centered()
.resizable()
.build()?;
let device = Device::new(ShaderFormat::SPIRV, true)?.with_window(&window)?;
// create platform and renderer
let mut imgui = ImGuiSdl3::new(&device, &window, |ctx| {
// disable creation of files on disc
ctx.set_ini_filename(None);
ctx.set_log_filename(None);
// setup platform and renderer, and fonts to imgui
ctx.fonts()
.add_font(&[imgui::FontSource::DefaultFontData { config: None }]);
});
// start main loop
let mut event_pump = sdl.event_pump()?;
'main: loop {
for event in event_pump.poll_iter() {
// pass all events to imgui platform
imgui.handle_event(&event);
if let Event::Quit { .. } = event {
break 'main;
}
}
let mut command_buffer = device.acquire_command_buffer()?;
if let Ok(swapchain) = command_buffer.wait_and_acquire_swapchain_texture(&window) {
let color_targets = [ColorTargetInfo::default()
.with_texture(&swapchain)
.with_load_op(LoadOp::CLEAR)
.with_store_op(StoreOp::STORE)
.with_clear_color(Color::RGB(128, 128, 128))];
imgui.render(
&mut sdl,
&device,
&window,
&event_pump,
&mut command_buffer,
&color_targets,
|ui| {
// create imgui UI here
ui.show_demo_window(&mut true);
},
);
command_buffer.submit()?;
} else {
println!("Swapchain unavailable, cancel work");
command_buffer.cancel();
}
}
Ok(())
}
The project use just as command runner.
To check all available recipes, run:
just
To run formatters:
just fmt