2022-11-29 18:11:09 +01:00
// dear imgui: Platform Backend for Windows (standard windows API for 32-bits AND 64-bits applications)
2018-02-21 23:05:17 +01:00
// This needs to be used along with a Renderer (e.g. DirectX11, OpenGL3, Vulkan..)
2018-02-16 23:04:17 +01:00
2018-06-11 12:33:51 +02:00
// Implemented features:
2020-02-17 10:11:26 +01:00
// [X] Platform: Clipboard support (for Win32 this is actually part of core dear imgui)
2023-04-04 19:43:51 +02:00
// [X] Platform: Mouse support. Can discriminate Mouse/TouchScreen/Pen.
2018-05-02 20:42:37 +02:00
// [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 VK_* values will also be supported unless IMGUI_DISABLE_OBSOLETE_KEYIO is set]
2019-01-15 21:17:48 +01:00
// [X] Platform: Gamepad support. Enabled with 'io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad'.
2018-05-02 20:42:37 +02:00
// [X] Platform: Mouse cursor shape and visibility. Disable with 'io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange'.
2018-06-12 16:24:24 +02:00
// [X] Platform: Multi-viewport support (multiple windows). Enable with 'io.ConfigFlags |= ImGuiConfigFlags_ViewportsEnable'.
2018-06-11 12:33:51 +02:00
2018-05-02 20:42:37 +02:00
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
2021-05-27 13:59:35 +02:00
// Prefer including the entire imgui/ repository into your project (either as a copy or as a submodule), and only build the backends you need.
2023-09-11 13:47:08 +02:00
// Learn about Dear ImGui:
// - FAQ https://dearimgui.com/faq
// - Getting Started https://dearimgui.com/getting-started
// - Documentation https://dearimgui.com/docs (same as your local docs/ folder).
// - Introduction, links and more at the top of imgui.cpp
2020-10-14 12:22:53 +02:00
2018-11-01 20:56:36 +01:00
# pragma once
2020-04-07 11:02:29 +02:00
# include "imgui.h" // IMGUI_IMPL_API
2023-07-13 11:27:52 +02:00
# ifndef IMGUI_DISABLE
2018-11-01 20:56:36 +01:00
2024-07-25 16:59:34 +02:00
// Follow "Getting Started" link and check examples/ folder to learn about using backends!
2018-06-21 12:04:00 +02:00
IMGUI_IMPL_API bool ImGui_ImplWin32_Init ( void * hwnd ) ;
2020-05-09 15:03:10 +02:00
IMGUI_IMPL_API bool ImGui_ImplWin32_InitForOpenGL ( void * hwnd ) ;
2018-06-21 12:04:00 +02:00
IMGUI_IMPL_API void ImGui_ImplWin32_Shutdown ( ) ;
IMGUI_IMPL_API void ImGui_ImplWin32_NewFrame ( ) ;
2018-02-16 23:04:17 +01:00
2020-04-03 12:14:03 +02:00
// Win32 message handler your application need to call.
// - Intentionally commented out in a '#if 0' block to avoid dragging dependencies on <windows.h> from this helper.
// - You should COPY the line below into your .cpp code to forward declare the function and then you can call it.
2022-02-28 20:50:58 +01:00
// - Call from your application's message handler. Keep calling your message handler unless this function returns TRUE.
2020-01-14 14:58:32 +01:00
#if 0
2020-02-17 10:11:26 +01:00
extern IMGUI_IMPL_API LRESULT ImGui_ImplWin32_WndProcHandler ( HWND hWnd , UINT msg , WPARAM wParam , LPARAM lParam ) ;
2020-01-14 14:58:32 +01:00
# endif
2020-02-17 11:11:08 +01:00
// DPI-related helpers (optional)
// - Use to enable DPI awareness without having to create an application manifest.
// - Your own app may already do this via a manifest or explicit calls. This is mostly useful for our examples/ apps.
// - In theory we could call simple functions from Windows SDK such as SetProcessDPIAware(), SetProcessDpiAwareness(), etc.
// but most of the functions provided by Microsoft require Windows 8.1/10+ SDK at compile time and Windows 8/10+ at runtime,
// neither we want to require the user to have. So we dynamically select and load those functions to avoid dependencies.
2018-12-14 11:59:44 +01:00
IMGUI_IMPL_API void ImGui_ImplWin32_EnableDpiAwareness ( ) ;
IMGUI_IMPL_API float ImGui_ImplWin32_GetDpiScaleForHwnd ( void * hwnd ) ; // HWND hwnd
IMGUI_IMPL_API float ImGui_ImplWin32_GetDpiScaleForMonitor ( void * monitor ) ; // HMONITOR monitor
2021-02-18 15:51:07 +01:00
// Transparency related helpers (optional) [experimental]
// - Use to enable alpha compositing transparency with the desktop.
// - Use together with e.g. clearing your framebuffer with zero-alpha.
IMGUI_IMPL_API void ImGui_ImplWin32_EnableAlphaCompositing ( void * hwnd ) ; // HWND hwnd
2023-07-13 11:27:52 +02:00
# endif // #ifndef IMGUI_DISABLE