From 684ff5d74d2ccd612b236608845dbf9a6dff611b Mon Sep 17 00:00:00 2001 From: Jeremy Nuttall Date: Mon, 4 Mar 2024 11:54:01 -0600 Subject: [PATCH 1/2] expose useDynamicRendering --- src/DearImGui/Vulkan.hs | 33 +++++++++++++++++++-------------- 1 file changed, 19 insertions(+), 14 deletions(-) diff --git a/src/DearImGui/Vulkan.hs b/src/DearImGui/Vulkan.hs index 3c63cb6..d76601e 100644 --- a/src/DearImGui/Vulkan.hs +++ b/src/DearImGui/Vulkan.hs @@ -31,6 +31,8 @@ import Data.Word ( Word32 ) import Foreign.Marshal.Alloc ( alloca ) +import Foreign.Marshal.Utils + ( fromBool ) import Foreign.Ptr ( FunPtr, Ptr, freeHaskellFunPtr, nullPtr ) import Foreign.Storable @@ -70,19 +72,20 @@ Cpp.using "namespace ImGui" data InitInfo = InitInfo - { instance' :: !Vulkan.Instance - , physicalDevice :: !Vulkan.PhysicalDevice - , device :: !Vulkan.Device - , queueFamily :: !Word32 - , queue :: !Vulkan.Queue - , pipelineCache :: !Vulkan.PipelineCache - , descriptorPool :: !Vulkan.DescriptorPool - , subpass :: !Word32 - , minImageCount :: !Word32 - , imageCount :: !Word32 - , msaaSamples :: !Vulkan.SampleCountFlagBits - , mbAllocator :: Maybe Vulkan.AllocationCallbacks - , checkResult :: Vulkan.Result -> IO () + { instance' :: !Vulkan.Instance + , physicalDevice :: !Vulkan.PhysicalDevice + , device :: !Vulkan.Device + , queueFamily :: !Word32 + , queue :: !Vulkan.Queue + , pipelineCache :: !Vulkan.PipelineCache + , descriptorPool :: !Vulkan.DescriptorPool + , subpass :: !Word32 + , minImageCount :: !Word32 + , imageCount :: !Word32 + , msaaSamples :: !Vulkan.SampleCountFlagBits + , useDynamicRendering :: !Bool + , mbAllocator :: Maybe Vulkan.AllocationCallbacks + , checkResult :: Vulkan.Result -> IO () } -- | Wraps @ImGui_ImplVulkan_Init@ and @ImGui_ImplVulkan_Shutdown@. @@ -112,6 +115,8 @@ vulkanInit ( InitInfo {..} ) renderPass = do withCallbacks f = case mbAllocator of Nothing -> f nullPtr Just callbacks -> alloca ( \ ptr -> poke ptr callbacks *> f ptr ) + useDynamicRenderingCBool :: Cpp.CBool + useDynamicRenderingCBool = fromBool useDynamicRendering liftIO do checkResultFunPtr <- $( C.mkFunPtr [t| Vulkan.Result -> IO () |] ) checkResult initResult <- withCallbacks \ callbacksPtr -> @@ -134,7 +139,7 @@ vulkanInit ( InitInfo {..} ) renderPass = do initInfo.MSAASamples = $(VkSampleCountFlagBits msaaSamples); initInfo.Allocator = $(VkAllocationCallbacks* callbacksPtr); initInfo.CheckVkResultFn = $( void (*checkResultFunPtr)(VkResult) ); - initInfo.UseDynamicRendering = false; + initInfo.UseDynamicRendering = $(bool useDynamicRenderingCBool); // TODO: initInfo.ColorAttachmentFormat return ImGui_ImplVulkan_Init(&initInfo, $(VkRenderPass renderPass) ); }|] From de2fc849fddd7bdc68b52a468c3bf6048009a856 Mon Sep 17 00:00:00 2001 From: Jeremy Nuttall Date: Tue, 5 Mar 2024 01:56:59 -0600 Subject: [PATCH 2/2] add color attachment format --- examples/vulkan/Main.hs | 14 +++++++------ src/DearImGui/Vulkan.hs | 39 +++++++++++++++++++---------------- src/DearImGui/Vulkan/Types.hs | 1 + 3 files changed, 30 insertions(+), 24 deletions(-) diff --git a/examples/vulkan/Main.hs b/examples/vulkan/Main.hs index 6c0ffd6..47e3a8f 100644 --- a/examples/vulkan/Main.hs +++ b/examples/vulkan/Main.hs @@ -387,14 +387,16 @@ app = do , device , queueFamily , queue - , pipelineCache = Vulkan.NULL_HANDLE - , descriptorPool = imGuiDescriptorPool - , subpass = 0 + , pipelineCache = Vulkan.NULL_HANDLE + , descriptorPool = imGuiDescriptorPool + , subpass = 0 , minImageCount , imageCount - , msaaSamples = Vulkan.SAMPLE_COUNT_1_BIT - , mbAllocator = Nothing - , checkResult = \case { Vulkan.SUCCESS -> pure (); e -> throw $ Vulkan.VulkanException e } + , msaaSamples = Vulkan.SAMPLE_COUNT_1_BIT + , mbAllocator = Nothing + , useDynamicRendering = False + , colorAttachmentFormat = Nothing + , checkResult = \case { Vulkan.SUCCESS -> pure (); e -> throw $ Vulkan.VulkanException e } } logDebug "Initialising ImGui SDL2 for Vulkan" diff --git a/src/DearImGui/Vulkan.hs b/src/DearImGui/Vulkan.hs index d76601e..8a8b9f9 100644 --- a/src/DearImGui/Vulkan.hs +++ b/src/DearImGui/Vulkan.hs @@ -72,20 +72,21 @@ Cpp.using "namespace ImGui" data InitInfo = InitInfo - { instance' :: !Vulkan.Instance - , physicalDevice :: !Vulkan.PhysicalDevice - , device :: !Vulkan.Device - , queueFamily :: !Word32 - , queue :: !Vulkan.Queue - , pipelineCache :: !Vulkan.PipelineCache - , descriptorPool :: !Vulkan.DescriptorPool - , subpass :: !Word32 - , minImageCount :: !Word32 - , imageCount :: !Word32 - , msaaSamples :: !Vulkan.SampleCountFlagBits - , useDynamicRendering :: !Bool - , mbAllocator :: Maybe Vulkan.AllocationCallbacks - , checkResult :: Vulkan.Result -> IO () + { instance' :: !Vulkan.Instance + , physicalDevice :: !Vulkan.PhysicalDevice + , device :: !Vulkan.Device + , queueFamily :: !Word32 + , queue :: !Vulkan.Queue + , pipelineCache :: !Vulkan.PipelineCache + , descriptorPool :: !Vulkan.DescriptorPool + , subpass :: !Word32 + , minImageCount :: !Word32 + , imageCount :: !Word32 + , msaaSamples :: !Vulkan.SampleCountFlagBits + , colorAttachmentFormat :: !(Maybe Vulkan.Format) + , useDynamicRendering :: !Bool + , mbAllocator :: Maybe Vulkan.AllocationCallbacks + , checkResult :: Vulkan.Result -> IO () } -- | Wraps @ImGui_ImplVulkan_Init@ and @ImGui_ImplVulkan_Shutdown@. @@ -115,8 +116,10 @@ vulkanInit ( InitInfo {..} ) renderPass = do withCallbacks f = case mbAllocator of Nothing -> f nullPtr Just callbacks -> alloca ( \ ptr -> poke ptr callbacks *> f ptr ) - useDynamicRenderingCBool :: Cpp.CBool - useDynamicRenderingCBool = fromBool useDynamicRendering + useDynamicRendering' :: Cpp.CBool + useDynamicRendering' = fromBool useDynamicRendering + colorAttachmentFormat' :: Vulkan.Format + colorAttachmentFormat' = fromMaybe Vulkan.FORMAT_UNDEFINED colorAttachmentFormat liftIO do checkResultFunPtr <- $( C.mkFunPtr [t| Vulkan.Result -> IO () |] ) checkResult initResult <- withCallbacks \ callbacksPtr -> @@ -139,8 +142,8 @@ vulkanInit ( InitInfo {..} ) renderPass = do initInfo.MSAASamples = $(VkSampleCountFlagBits msaaSamples); initInfo.Allocator = $(VkAllocationCallbacks* callbacksPtr); initInfo.CheckVkResultFn = $( void (*checkResultFunPtr)(VkResult) ); - initInfo.UseDynamicRendering = $(bool useDynamicRenderingCBool); - // TODO: initInfo.ColorAttachmentFormat + initInfo.UseDynamicRendering = $(bool useDynamicRendering'); + initInfo.ColorAttachmentFormat = $(VkFormat colorAttachmentFormat'); return ImGui_ImplVulkan_Init(&initInfo, $(VkRenderPass renderPass) ); }|] pure ( checkResultFunPtr, initResult /= 0 ) diff --git a/src/DearImGui/Vulkan/Types.hs b/src/DearImGui/Vulkan/Types.hs index 3200d9d..930a1d9 100644 --- a/src/DearImGui/Vulkan/Types.hs +++ b/src/DearImGui/Vulkan/Types.hs @@ -35,6 +35,7 @@ vulkanTypesTable = Map.fromList , ( C.TypeName "VkImageView" , [t| Vulkan.ImageView |] ) , ( C.TypeName "VkImageLayout" , [t| Vulkan.ImageLayout |] ) , ( C.TypeName "VkDescriptorSet" , [t| Vulkan.DescriptorSet |] ) + , ( C.TypeName "VkFormat" , [t| Vulkan.Format |]) ] vulkanCtx :: C.Context