Skip to content

Commit e808643

Browse files
authored
Merge pull request #17 from PMarcL/sdl3gpu-backend
Add support for the SDL3+GPU API backend.
2 parents 8175dde + 86e90f8 commit e808643

File tree

10 files changed

+2384
-2
lines changed

10 files changed

+2384
-2
lines changed

build.zig

Lines changed: 13 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@ pub const Backend = enum {
1010
glfw,
1111
sdl2_opengl3,
1212
osx_metal,
13+
sdl3_gpu,
1314
};
1415

1516
pub fn build(b: *std.Build) void {
@@ -385,6 +386,18 @@ pub fn build(b: *std.Build) void {
385386
.flags = objcflags,
386387
});
387388
},
389+
.sdl3_gpu => {
390+
if (b.lazyDependency("zsdl", .{})) |zsdl| {
391+
imgui.addIncludePath(zsdl.path("libs/sdl3/include"));
392+
}
393+
imgui.addCSourceFiles(.{
394+
.files = &.{
395+
"libs/imgui/backends/imgui_impl_sdl3.cpp",
396+
"libs/imgui/backends/imgui_impl_sdlgpu3.cpp",
397+
},
398+
.flags = cflags,
399+
});
400+
},
388401
.no_backend => {},
389402
}
390403

build.zig.zon

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -26,8 +26,8 @@
2626
.lazy = true,
2727
},
2828
.zsdl = .{
29-
.url = "https://github.com/zig-gamedev/zsdl/archive/360a5033010c71445ba42d1de3973abd50c6b128.tar.gz",
30-
.hash = "1220b661c47496008c7b2717c06b7bc1f79b1cfc430c885222d5d49c91d3fc57cbde",
29+
.url = "https://github.com/zig-gamedev/zsdl/archive/d03b4d4e7cb7a74e01d9dad30d0f1692286f58f8.tar.gz",
30+
.hash = "12205dcdb071febd9d3412a65e6235b832205cc49c1e20c88a71f62ada4e27dfb878",
3131
.lazy = true,
3232
},
3333
.freetype = .{

libs/imgui/backends/imgui_impl_sdl3.cpp

Lines changed: 1161 additions & 0 deletions
Large diffs are not rendered by default.

libs/imgui/backends/imgui_impl_sdl3.h

Lines changed: 55 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,55 @@
1+
// dear imgui: Platform Backend for SDL3
2+
// This needs to be used along with a Renderer (e.g. SDL_GPU, DirectX11, OpenGL3, Vulkan..)
3+
// (Info: SDL3 is a cross-platform general purpose library for handling windows, inputs, graphics context creation, etc.)
4+
5+
// Implemented features:
6+
// [X] Platform: Clipboard support.
7+
// [X] Platform: Mouse support. Can discriminate Mouse/TouchScreen.
8+
// [X] Platform: Keyboard support. Since 1.87 we are using the io.AddKeyEvent() function. Pass ImGuiKey values to all key functions e.g. ImGui::IsKeyPressed(ImGuiKey_Space). [Legacy SDL_SCANCODE_* values are obsolete since 1.87 and not supported since 1.91.5]
9+
// [X] Platform: Gamepad support. Enabled with 'io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad'.
10+
// [X] Platform: Mouse cursor shape and visibility (ImGuiBackendFlags_HasMouseCursors). Disable with 'io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange'.
11+
// [x] Platform: Multi-viewport support (multiple windows). Enable with 'io.ConfigFlags |= ImGuiConfigFlags_ViewportsEnable' -> the OS animation effect when window gets created/destroyed is problematic. SDL2 backend doesn't have issue.
12+
// Missing features or Issues:
13+
// [ ] Platform: Multi-viewport: Minimized windows seems to break mouse wheel events (at least under Windows).
14+
// [x] Platform: IME support. Position somehow broken in SDL3 + app needs to call 'SDL_SetHint(SDL_HINT_IME_SHOW_UI, "1");' before SDL_CreateWindow()!.
15+
16+
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
17+
// Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
18+
// Learn about Dear ImGui:
19+
// - FAQ https://dearimgui.com/faq
20+
// - Getting Started https://dearimgui.com/getting-started
21+
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
22+
// - Introduction, links and more at the top of imgui.cpp
23+
24+
#pragma once
25+
#include "imgui.h" // IMGUI_IMPL_API
26+
#ifndef IMGUI_DISABLE
27+
28+
struct SDL_Window;
29+
struct SDL_Renderer;
30+
struct SDL_Gamepad;
31+
typedef union SDL_Event SDL_Event;
32+
33+
// FIX (zig-gamedev):
34+
extern "C" {
35+
36+
// Follow "Getting Started" link and check examples/ folder to learn about using backends!
37+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForOpenGL(SDL_Window* window, void* sdl_gl_context);
38+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForVulkan(SDL_Window* window);
39+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForD3D(SDL_Window* window);
40+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForMetal(SDL_Window* window);
41+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForSDLRenderer(SDL_Window* window, SDL_Renderer* renderer);
42+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForSDLGPU(SDL_Window* window);
43+
IMGUI_IMPL_API bool ImGui_ImplSDL3_InitForOther(SDL_Window* window);
44+
IMGUI_IMPL_API void ImGui_ImplSDL3_Shutdown();
45+
IMGUI_IMPL_API void ImGui_ImplSDL3_NewFrame();
46+
IMGUI_IMPL_API bool ImGui_ImplSDL3_ProcessEvent(const SDL_Event* event);
47+
48+
}
49+
50+
// Gamepad selection automatically starts in AutoFirst mode, picking first available SDL_Gamepad. You may override this.
51+
// When using manual mode, caller is responsible for opening/closing gamepad.
52+
enum ImGui_ImplSDL3_GamepadMode { ImGui_ImplSDL3_GamepadMode_AutoFirst, ImGui_ImplSDL3_GamepadMode_AutoAll, ImGui_ImplSDL3_GamepadMode_Manual };
53+
IMGUI_IMPL_API void ImGui_ImplSDL3_SetGamepadMode(ImGui_ImplSDL3_GamepadMode mode, SDL_Gamepad** manual_gamepads_array = nullptr, int manual_gamepads_count = -1);
54+
55+
#endif // #ifndef IMGUI_DISABLE

0 commit comments

Comments
 (0)