dear-imgui-winit 0.1.0

Winit backend for Dear ImGui
docs.rs failed to build dear-imgui-winit-0.1.0
Please check the build logs for more information.
See Builds for ideas on how to fix a failed build, or Metadata for how to configure docs.rs builds.
If you believe this is docs.rs' fault, open an issue.
Visit the last successful build: dear-imgui-winit-0.13.0

Winit platform backend for Dear ImGui

This crate provides a platform backend for Dear ImGui that integrates with the winit windowing library. It handles window events, input processing, and platform-specific functionality including multi-viewport support.

Features

  • Basic Platform Support: Window events, input handling, cursor management
  • Multi-Viewport Support: Create and manage multiple OS windows (requires multi-viewport feature)
  • DPI Awareness: Proper handling of high-DPI displays

Example - Basic Usage

use dear_imgui::Context;
use dear_imgui_winit::WinitPlatform;
use winit::event_loop::EventLoop;

let event_loop = EventLoop::new().unwrap();
let mut imgui_ctx = Context::create_or_panic();
let mut platform = WinitPlatform::new(&mut imgui_ctx);

// Use in your event loop...

Example - Multi-Viewport Support

# #[cfg(feature = "multi-viewport")]
# {
use dear_imgui::Context;
use dear_imgui_winit::{WinitPlatform, multi_viewport};
use winit::event_loop::EventLoop;

let event_loop = EventLoop::new().unwrap();
let mut imgui_ctx = Context::create_or_panic();
imgui_ctx.enable_multi_viewport();

let mut platform = WinitPlatform::new(&mut imgui_ctx);

// In your event loop:
// multi_viewport::set_event_loop(&event_loop);
// multi_viewport::init_multi_viewport_support(&mut imgui_ctx, &window);
# }