2018-02-22 01:05:17 +03:00
// ImGui Renderer for: Vulkan
// This needs to be used along with a Platform Binding (e.g. GLFW, SDL, Win32, custom..)
2018-02-17 00:50:19 +03:00
// Missing features:
// [ ] User texture binding. Changes of ImTextureID aren't supported by this binding! See https://github.com/ocornut/imgui/pull/914
2018-03-19 17:20:47 +03:00
// [ ] Multi-viewport rendering (when ImGuiConfigFlags_EnableViewports is enabled). WORK-IN-PROGRESS.
2018-02-17 00:50:19 +03:00
// You can copy and use unmodified imgui_impl_* files in your project. See main.cpp for an example of using this.
// If you use this binding you'll need to call 5 functions: ImGui_ImplXXXX_Init(), ImGui_ImplXXX_CreateFontsTexture(), ImGui_ImplXXXX_NewFrame(), ImGui_ImplXXXX_Render() and ImGui_ImplXXXX_Shutdown().
// If you are new to ImGui, see examples/README.txt and documentation at the top of imgui.cpp.
// https://github.com/ocornut/imgui
# include <vulkan/vulkan.h>
# define IMGUI_VK_QUEUED_FRAMES 2
2018-03-01 23:11:22 +03:00
struct ImGui_ImplVulkan_InitInfo
2018-02-17 00:50:19 +03:00
{
2018-03-03 01:59:21 +03:00
VkInstance Instance ;
2018-03-01 23:11:22 +03:00
VkPhysicalDevice PhysicalDevice ;
VkDevice Device ;
2018-03-12 19:37:28 +03:00
uint32_t QueueFamily ;
VkQueue Queue ;
2018-03-01 23:11:22 +03:00
VkPipelineCache PipelineCache ;
VkDescriptorPool DescriptorPool ;
2018-03-03 01:59:21 +03:00
const VkAllocationCallbacks * Allocator ;
2018-03-01 23:11:22 +03:00
void ( * CheckVkResultFn ) ( VkResult err ) ;
2018-02-17 00:50:19 +03:00
} ;
2018-03-03 01:59:21 +03:00
IMGUI_API bool ImGui_ImplVulkan_Init ( ImGui_ImplVulkan_InitInfo * info , VkRenderPass render_pass ) ;
2018-02-17 00:50:19 +03:00
IMGUI_API void ImGui_ImplVulkan_Shutdown ( ) ;
IMGUI_API void ImGui_ImplVulkan_NewFrame ( ) ;
2018-03-02 18:34:47 +03:00
IMGUI_API void ImGui_ImplVulkan_RenderDrawData ( VkCommandBuffer command_buffer , ImDrawData * draw_data ) ;
2018-02-17 00:50:19 +03:00
// Called by Init/NewFrame/Shutdown
IMGUI_API void ImGui_ImplVulkan_InvalidateFontUploadObjects ( ) ;
IMGUI_API void ImGui_ImplVulkan_InvalidateDeviceObjects ( ) ;
IMGUI_API bool ImGui_ImplVulkan_CreateFontsTexture ( VkCommandBuffer command_buffer ) ;
IMGUI_API bool ImGui_ImplVulkan_CreateDeviceObjects ( ) ;
2018-03-02 00:16:51 +03:00
2018-03-03 01:04:56 +03:00
//-------------------------------------------------------------------------
2018-03-02 00:16:51 +03:00
// Miscellaneous Vulkan Helpers
2018-03-03 01:04:56 +03:00
// Generally we try to NOT provide any kind of superfluous high-level helpers in the examples.
// But for the purpose of allowing multi-windows, we need those internally anyway. The code being not trivial are exposing it for the benefit of the example code.
// If your application/engine already has code to create all that data (swap chain, render pass, frame buffers, etc.) you can ignore all of this.
//-------------------------------------------------------------------------
2018-03-03 01:59:21 +03:00
// NB: Those functions do NOT use any of the state used/affected by the regular ImGui_ImplVulkan_XXX functions.
//-------------------------------------------------------------------------
2018-03-03 01:04:56 +03:00
2018-03-03 01:59:21 +03:00
struct ImGui_ImplVulkan_FrameData ;
struct ImGui_ImplVulkan_WindowData ;
2018-03-03 02:29:17 +03:00
IMGUI_API void ImGui_ImplVulkanH_CreateWindowDataCommandBuffers ( VkPhysicalDevice physical_device , VkDevice device , uint32_t queue_family , ImGui_ImplVulkan_WindowData * wd , const VkAllocationCallbacks * allocator ) ;
IMGUI_API void ImGui_ImplVulkanH_CreateWindowDataSwapChainAndFramebuffer ( VkPhysicalDevice physical_device , VkDevice device , ImGui_ImplVulkan_WindowData * wd , const VkAllocationCallbacks * allocator , int w , int h ) ;
IMGUI_API void ImGui_ImplVulkanH_DestroyWindowData ( VkInstance instance , VkDevice device , ImGui_ImplVulkan_WindowData * wd , const VkAllocationCallbacks * allocator ) ;
2018-03-03 01:59:21 +03:00
IMGUI_API VkSurfaceFormatKHR ImGui_ImplVulkanH_SelectSurfaceFormat ( VkPhysicalDevice physical_device , VkSurfaceKHR surface , const VkFormat * request_formats , int request_formats_count , VkColorSpaceKHR request_color_space ) ;
IMGUI_API VkPresentModeKHR ImGui_ImplVulkanH_SelectPresentMode ( VkPhysicalDevice physical_device , VkSurfaceKHR surface , const VkPresentModeKHR * request_modes , int request_modes_count ) ;
2018-03-12 20:43:25 +03:00
IMGUI_API int ImGui_ImplVulkanH_GetMinImageCountFromPresentMode ( VkPresentModeKHR present_mode ) ;
2018-03-03 01:04:56 +03:00
struct ImGui_ImplVulkan_FrameData
{
uint32_t BackbufferIndex ; // keep track of recently rendered swapchain frame indices
VkCommandPool CommandPool ;
VkCommandBuffer CommandBuffer ;
VkFence Fence ;
2018-03-12 20:43:25 +03:00
VkSemaphore ImageAcquiredSemaphore ;
2018-03-03 01:04:56 +03:00
VkSemaphore RenderCompleteSemaphore ;
IMGUI_API ImGui_ImplVulkan_FrameData ( ) ;
} ;
struct ImGui_ImplVulkan_WindowData
{
2018-03-03 02:29:17 +03:00
int Width ;
int Height ;
2018-03-03 01:04:56 +03:00
VkSwapchainKHR Swapchain ;
VkSurfaceKHR Surface ;
VkSurfaceFormatKHR SurfaceFormat ;
VkPresentModeKHR PresentMode ;
VkRenderPass RenderPass ;
2018-03-15 19:52:53 +03:00
bool ClearEnable ;
2018-03-03 01:04:56 +03:00
VkClearValue ClearValue ;
uint32_t BackBufferCount ;
VkImage BackBuffer [ 16 ] ;
VkImageView BackBufferView [ 16 ] ;
VkFramebuffer Framebuffer [ 16 ] ;
uint32_t FrameIndex ;
ImGui_ImplVulkan_FrameData Frames [ IMGUI_VK_QUEUED_FRAMES ] ;
IMGUI_API ImGui_ImplVulkan_WindowData ( ) ;
} ;
2018-03-03 01:59:21 +03:00