2020-10-12 18:34:22 +03:00
// dear imgui: Platform Backend for GLFW
2021-01-28 14:11:26 +03:00
// This needs to be used along with a Renderer (e.g. OpenGL3, Vulkan, WebGPU..)
2018-02-22 01:05:17 +03:00
// (Info: GLFW is a cross-platform general purpose library for handling windows, inputs, OpenGL/Vulkan graphics context creation, etc.)
2022-01-10 17:24:21 +03:00
// (Requires: GLFW 3.1+. Prefer GLFW 3.3+ for full feature support.)
2016-03-24 13:00:47 +03:00
2018-02-05 22:34:11 +03:00
// Implemented features:
2018-06-11 13:33:51 +03:00
// [X] Platform: Clipboard support.
2023-04-04 20:43:51 +03:00
// [X] Platform: Mouse support. Can discriminate Mouse/TouchScreen/Pen (Windows only).
2021-12-12 14:00:31 +03: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 GLFW_KEY_* values will also be supported unless IMGUI_DISABLE_OBSOLETE_KEYIO is set]
2018-09-20 11:37:55 +03:00
// [X] Platform: Gamepad support. Enable with 'io.ConfigFlags |= ImGuiConfigFlags_NavEnableGamepad'.
2024-02-28 13:03:44 +03:00
// [X] Platform: Mouse cursor shape and visibility. Disable with 'io.ConfigFlags |= ImGuiConfigFlags_NoMouseCursorChange' (note: the resizing cursors requires GLFW 3.4+).
2018-06-12 17:24:24 +03:00
// [X] Platform: Multi-viewport support (multiple windows). Enable with 'io.ConfigFlags |= ImGuiConfigFlags_ViewportsEnable'.
2020-07-17 16:57:50 +03:00
// Issues:
2024-02-28 13:03:44 +03:00
// [ ] Platform: Multi-viewport: ParentViewportID not honored, and so io.ConfigViewportsNoDefaultParent has no effect (minor).
2020-07-17 16:57:50 +03:00
2021-07-29 19:59:45 +03:00
// You can use unmodified imgui_impl_* files in your project. See examples/ folder for examples of using this.
2021-05-27 14:59:35 +03: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 14:47:08 +03: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
2015-03-09 14:59:23 +03:00
2018-11-01 22:56:36 +03:00
# pragma once
2020-04-07 12:02:29 +03:00
# include "imgui.h" // IMGUI_IMPL_API
2023-07-13 12:27:52 +03:00
# ifndef IMGUI_DISABLE
2018-11-01 22:56:36 +03:00
2015-03-09 14:59:23 +03:00
struct GLFWwindow ;
2020-02-09 19:31:18 +03:00
struct GLFWmonitor ;
2015-03-09 14:59:23 +03:00
2024-07-25 17:59:34 +03:00
// Follow "Getting Started" link and check examples/ folder to learn about using backends!
2018-06-21 13:04:00 +03:00
IMGUI_IMPL_API bool ImGui_ImplGlfw_InitForOpenGL ( GLFWwindow * window , bool install_callbacks ) ;
IMGUI_IMPL_API bool ImGui_ImplGlfw_InitForVulkan ( GLFWwindow * window , bool install_callbacks ) ;
2021-02-10 19:27:33 +03:00
IMGUI_IMPL_API bool ImGui_ImplGlfw_InitForOther ( GLFWwindow * window , bool install_callbacks ) ;
2018-06-21 13:04:00 +03:00
IMGUI_IMPL_API void ImGui_ImplGlfw_Shutdown ( ) ;
IMGUI_IMPL_API void ImGui_ImplGlfw_NewFrame ( ) ;
2015-03-09 18:02:22 +03:00
2024-07-08 16:53:23 +03:00
// Emscripten related initialization phase methods (call after ImGui_ImplGlfw_InitForOpenGL)
2023-12-19 17:52:44 +03:00
# ifdef __EMSCRIPTEN__
2024-07-08 16:53:23 +03:00
IMGUI_IMPL_API void ImGui_ImplGlfw_InstallEmscriptenCallbacks ( GLFWwindow * window , const char * canvas_selector ) ;
//static inline void ImGui_ImplGlfw_InstallEmscriptenCanvasResizeCallback(const char* canvas_selector) { ImGui_ImplGlfw_InstallEmscriptenCallbacks(nullptr, canvas_selector); } } // Renamed in 1.91.0
2023-12-19 17:52:44 +03:00
# endif
2023-02-03 19:53:53 +03:00
// GLFW callbacks install
2022-02-07 18:00:13 +03:00
// - When calling Init with 'install_callbacks=true': ImGui_ImplGlfw_InstallCallbacks() is called. GLFW callbacks will be installed for you. They will chain-call user's previously installed callbacks, if any.
// - When calling Init with 'install_callbacks=false': GLFW callbacks won't be installed. You will need to call individual function yourself from your own GLFW callbacks.
IMGUI_IMPL_API void ImGui_ImplGlfw_InstallCallbacks ( GLFWwindow * window ) ;
IMGUI_IMPL_API void ImGui_ImplGlfw_RestoreCallbacks ( GLFWwindow * window ) ;
2023-02-03 19:53:53 +03:00
// GFLW callbacks options:
// - Set 'chain_for_all_windows=true' to enable chaining callbacks for all windows (including secondary viewports created by backends or by user)
IMGUI_IMPL_API void ImGui_ImplGlfw_SetCallbacksChainForAllWindows ( bool chain_for_all_windows ) ;
// GLFW callbacks (individual callbacks to call yourself if you didn't install callbacks)
2022-01-12 19:08:37 +03:00
IMGUI_IMPL_API void ImGui_ImplGlfw_WindowFocusCallback ( GLFWwindow * window , int focused ) ; // Since 1.84
IMGUI_IMPL_API void ImGui_ImplGlfw_CursorEnterCallback ( GLFWwindow * window , int entered ) ; // Since 1.84
IMGUI_IMPL_API void ImGui_ImplGlfw_CursorPosCallback ( GLFWwindow * window , double x , double y ) ; // Since 1.87
2018-06-21 13:04:00 +03:00
IMGUI_IMPL_API void ImGui_ImplGlfw_MouseButtonCallback ( GLFWwindow * window , int button , int action , int mods ) ;
IMGUI_IMPL_API void ImGui_ImplGlfw_ScrollCallback ( GLFWwindow * window , double xoffset , double yoffset ) ;
IMGUI_IMPL_API void ImGui_ImplGlfw_KeyCallback ( GLFWwindow * window , int key , int scancode , int action , int mods ) ;
IMGUI_IMPL_API void ImGui_ImplGlfw_CharCallback ( GLFWwindow * window , unsigned int c ) ;
2020-02-09 19:31:18 +03:00
IMGUI_IMPL_API void ImGui_ImplGlfw_MonitorCallback ( GLFWmonitor * monitor , int event ) ;
2023-07-13 12:27:52 +03:00
2024-07-31 18:33:24 +03:00
// GLFW helpers
IMGUI_IMPL_API void ImGui_ImplGlfw_Sleep ( int milliseconds ) ;
2023-07-13 12:27:52 +03:00
# endif // #ifndef IMGUI_DISABLE