update dear imgui from 1.91.8 to 1.91.9b and switch to docking branch
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
@REM Build for MINGW64 or 32 from MSYS2.
|
||||
@REM Build for MINGW64 or 32 from MSYS2.
|
||||
@set OUT_DIR=Debug
|
||||
@set OUT_EXE=example_win32_opengl3
|
||||
@set INCLUDES=-I../.. -I../../backends
|
||||
|
||||
@@ -33,6 +33,42 @@ void CleanupDeviceWGL(HWND hWnd, WGL_WindowData* data);
|
||||
void ResetDeviceWGL();
|
||||
LRESULT WINAPI WndProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam);
|
||||
|
||||
// Support function for multi-viewports
|
||||
// Unlike most other backend combination, we need specific hooks to combine Win32+OpenGL.
|
||||
// We could in theory decide to support Win32-specific code in OpenGL backend via e.g. an hypothetical ImGui_ImplOpenGL3_InitForRawWin32().
|
||||
static void Hook_Renderer_CreateWindow(ImGuiViewport* viewport)
|
||||
{
|
||||
assert(viewport->RendererUserData == NULL);
|
||||
|
||||
WGL_WindowData* data = IM_NEW(WGL_WindowData);
|
||||
CreateDeviceWGL((HWND)viewport->PlatformHandle, data);
|
||||
viewport->RendererUserData = data;
|
||||
}
|
||||
|
||||
static void Hook_Renderer_DestroyWindow(ImGuiViewport* viewport)
|
||||
{
|
||||
if (viewport->RendererUserData != NULL)
|
||||
{
|
||||
WGL_WindowData* data = (WGL_WindowData*)viewport->RendererUserData;
|
||||
CleanupDeviceWGL((HWND)viewport->PlatformHandle, data);
|
||||
IM_DELETE(data);
|
||||
viewport->RendererUserData = NULL;
|
||||
}
|
||||
}
|
||||
|
||||
static void Hook_Platform_RenderWindow(ImGuiViewport* viewport, void*)
|
||||
{
|
||||
// Activate the platform window DC in the OpenGL rendering context
|
||||
if (WGL_WindowData* data = (WGL_WindowData*)viewport->RendererUserData)
|
||||
wglMakeCurrent(data->hDC, g_hRC);
|
||||
}
|
||||
|
||||
static void Hook_Renderer_SwapBuffers(ImGuiViewport* viewport, void*)
|
||||
{
|
||||
if (WGL_WindowData* data = (WGL_WindowData*)viewport->RendererUserData)
|
||||
::SwapBuffers(data->hDC);
|
||||
}
|
||||
|
||||
// Main code
|
||||
int main(int, char**)
|
||||
{
|
||||
@@ -62,15 +98,39 @@ int main(int, char**)
|
||||
ImGuiIO& io = ImGui::GetIO(); (void)io;
|
||||
io.ConfigFlags |= ImGuiConfigFlags_NavEnableKeyboard; // Enable Keyboard Controls
|
||||
io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad; // Enable Gamepad Controls
|
||||
io.ConfigFlags |= ImGuiConfigFlags_DockingEnable; // Enable Docking
|
||||
io.ConfigFlags |= ImGuiConfigFlags_ViewportsEnable; // Enable Multi-Viewport / Platform Windows
|
||||
|
||||
// Setup Dear ImGui style
|
||||
ImGui::StyleColorsDark();
|
||||
//ImGui::StyleColorsClassic();
|
||||
|
||||
// When viewports are enabled we tweak WindowRounding/WindowBg so platform windows can look identical to regular ones.
|
||||
ImGuiStyle& style = ImGui::GetStyle();
|
||||
if (io.ConfigFlags & ImGuiConfigFlags_ViewportsEnable)
|
||||
{
|
||||
style.WindowRounding = 0.0f;
|
||||
style.Colors[ImGuiCol_WindowBg].w = 1.0f;
|
||||
}
|
||||
|
||||
// Setup Platform/Renderer backends
|
||||
ImGui_ImplWin32_InitForOpenGL(hwnd);
|
||||
ImGui_ImplOpenGL3_Init();
|
||||
|
||||
// Win32+GL needs specific hooks for viewport, as there are specific things needed to tie Win32 and GL api.
|
||||
if (io.ConfigFlags & ImGuiConfigFlags_ViewportsEnable)
|
||||
{
|
||||
ImGuiPlatformIO& platform_io = ImGui::GetPlatformIO();
|
||||
IM_ASSERT(platform_io.Renderer_CreateWindow == NULL);
|
||||
IM_ASSERT(platform_io.Renderer_DestroyWindow == NULL);
|
||||
IM_ASSERT(platform_io.Renderer_SwapBuffers == NULL);
|
||||
IM_ASSERT(platform_io.Platform_RenderWindow == NULL);
|
||||
platform_io.Renderer_CreateWindow = Hook_Renderer_CreateWindow;
|
||||
platform_io.Renderer_DestroyWindow = Hook_Renderer_DestroyWindow;
|
||||
platform_io.Renderer_SwapBuffers = Hook_Renderer_SwapBuffers;
|
||||
platform_io.Platform_RenderWindow = Hook_Platform_RenderWindow;
|
||||
}
|
||||
|
||||
// Load Fonts
|
||||
// - If no fonts are loaded, dear imgui will use the default font. You can also load multiple fonts and use ImGui::PushFont()/PopFont() to select them.
|
||||
// - AddFontFromFileTTF() will return the ImFont* so you can store it if you need to select the font among multiple.
|
||||
@@ -163,6 +223,16 @@ int main(int, char**)
|
||||
glClear(GL_COLOR_BUFFER_BIT);
|
||||
ImGui_ImplOpenGL3_RenderDrawData(ImGui::GetDrawData());
|
||||
|
||||
// Update and Render additional Platform Windows
|
||||
if (io.ConfigFlags & ImGuiConfigFlags_ViewportsEnable)
|
||||
{
|
||||
ImGui::UpdatePlatformWindows();
|
||||
ImGui::RenderPlatformWindowsDefault();
|
||||
|
||||
// Restore the OpenGL rendering context to the main window DC, since platform windows might have changed it.
|
||||
wglMakeCurrent(g_MainWindow.hDC, g_hRC);
|
||||
}
|
||||
|
||||
// Present
|
||||
::SwapBuffers(g_MainWindow.hDC);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user