22 releases (13 breaking)
0.13.0 | Sep 30, 2024 |
---|---|
0.12.0 | May 5, 2024 |
0.11.0 | Apr 5, 2023 |
0.10.0 | Jan 16, 2023 |
0.0.22 | Feb 5, 2019 |
#702 in GUI
2,139 downloads per month
Used in fewer than 29 crates
29KB
399 lines
imgui-winit-support
This crate provides a winit-based backend platform for imgui-rs
.
A backend platform handles window/input device events and manages their state.
Using the library
There are five things you need to do to use this library correctly:
- Initialize a
WinitPlatform
instance. - Attach it to a winit
Window
withWinitPlatform::attach_window
. - Pass events to the platform (every frame) with
WinitPlatform::handle_event
. - Call the frame preparation callback
WinitPlatform::prepare_frame
(every frame) - Call the render preparation callback
WinitPlatform::prepare_render
(every frame)
Complete example (without a renderer)
use imgui::Context;
use imgui_winit_support::{HiDpiMode, WinitPlatform};
use std::time::Instant;
use winit::event::{Event, WindowEvent};
use winit::event_loop::EventLoop;
use winit::window::WindowAttributes;
let event_loop = EventLoop::new().expect("Failed to create EventLoop");
let window = event_loop
.create_window(WindowAttributes::default())
.expect("couldn't create window");
let mut imgui = Context::create();
// configure imgui-rs Context if necessary
let mut platform = WinitPlatform::new(&mut imgui); // step 1
platform.attach_window(imgui.io_mut(), &window, HiDpiMode::Default); // step 2
let mut last_frame = Instant::now();
event_loop
.run(move |event, window_target| {
match event {
Event::NewEvents(_) => {
// other application-specific logic
let now = Instant::now();
imgui.io_mut().update_delta_time(now - last_frame);
last_frame = now;
}
Event::AboutToWait => {
// other application-specific logic
platform
.prepare_frame(imgui.io_mut(), &window) // step 4
.expect("Failed to prepare frame");
window.request_redraw();
}
Event::WindowEvent {
event: WindowEvent::RedrawRequested,
..
} => {
let ui = imgui.frame();
// application-specific rendering *under the UI*
// construct the UI
platform.prepare_render(ui, &window); // step 5
// render the UI with a renderer
let draw_data = imgui.render();
// renderer.render(..., draw_data).expect("UI rendering failed");
// application-specific rendering *over the UI*
}
Event::WindowEvent {
event: WindowEvent::CloseRequested,
..
} => {
window_target.exit();
}
// other application-specific event handling
event => {
platform.handle_event(imgui.io_mut(), &window, &event); // step 3
// other application-specific event handling
}
}
})
.expect("EventLoop error");
License
Licensed under either of
- Apache License, Version 2.0, (LICENSE-APACHE or https://www.apache.org/licenses/LICENSE-2.0)
- MIT license (LICENSE-MIT or https://opensource.org/licenses/MIT)
at your option.
Dependencies
~15–28MB
~467K SLoC