2025-05-07 19:21:51 +02:00
|
|
|
/*
|
|
|
|
|
Crafter®.Graphics
|
|
|
|
|
Copyright (C) 2025 Catcrafts®
|
|
|
|
|
Catcrafts.net
|
|
|
|
|
|
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
|
|
|
modify it under the terms of the GNU Lesser General Public
|
|
|
|
|
License as published by the Free Software Foundation; either
|
|
|
|
|
version 3.0 of the License, or (at your option) any later version.
|
|
|
|
|
|
|
|
|
|
This library is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
|
Lesser General Public License for more details.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
|
|
|
License along with this library; if not, write to the Free Software
|
|
|
|
|
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
*/
|
|
|
|
|
|
2025-04-19 15:46:26 +02:00
|
|
|
module;
|
|
|
|
|
|
|
|
|
|
#include <vulkan/vulkan.h>
|
|
|
|
|
#include <vulkan/vulkan_wayland.h>
|
|
|
|
|
|
|
|
|
|
export module Crafter.Graphics:WindowWaylandVulkan;
|
2025-11-16 15:32:11 +01:00
|
|
|
import std;
|
2025-04-19 15:46:26 +02:00
|
|
|
import Crafter.Event;
|
|
|
|
|
import :WindowWayland;
|
|
|
|
|
|
|
|
|
|
namespace Crafter {
|
2025-04-19 23:59:27 +02:00
|
|
|
struct DepthStencil {
|
2025-04-19 15:46:26 +02:00
|
|
|
VkImage image;
|
2025-04-19 23:59:27 +02:00
|
|
|
VkDeviceMemory memory;
|
|
|
|
|
VkImageView view;
|
2025-04-19 15:46:26 +02:00
|
|
|
};
|
|
|
|
|
|
2025-04-19 23:59:27 +02:00
|
|
|
struct Semaphores {
|
|
|
|
|
// Swap chain image presentation
|
|
|
|
|
VkSemaphore presentComplete;
|
|
|
|
|
// Command buffer submission and execution
|
|
|
|
|
VkSemaphore renderComplete;
|
|
|
|
|
};
|
|
|
|
|
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @class WindowWaylandVulkan
|
|
|
|
|
* @brief A Wayland window specialized for Vulkan rendering.
|
|
|
|
|
*
|
|
|
|
|
* This class extends the WindowWayland base class to support Vulkan graphics
|
|
|
|
|
* integration within a Wayland environment. It provides methods for initializing
|
|
|
|
|
* Vulkan command buffers and managing drawing operations either synchronously or asynchronously.
|
|
|
|
|
*
|
|
|
|
|
* The class exposes an event `onDraw` which is called for every frame.
|
|
|
|
|
* @pre VulkanDevice::CreateDevice() must be called before creating or using this class.
|
|
|
|
|
*/
|
2025-04-19 15:46:26 +02:00
|
|
|
export class WindowWaylandVulkan : public WindowWayland {
|
|
|
|
|
public:
|
2025-04-27 23:20:52 +02:00
|
|
|
Event<VkCommandBuffer> onDraw;
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @brief Constructs a WindowWaylandVulkan instance.
|
|
|
|
|
*
|
|
|
|
|
* @param name The title of the window.
|
|
|
|
|
* @param width The width of the window in pixels.
|
|
|
|
|
* @param height The height of the window in pixels.
|
|
|
|
|
*/
|
2025-04-19 15:46:26 +02:00
|
|
|
WindowWaylandVulkan(std::string name, std::uint32_t width, std::uint32_t height);
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @brief Destructor for the WindowWaylandVulkan.
|
|
|
|
|
*
|
|
|
|
|
* Cleans up Vulkan and Wayland resources associated with this window.
|
|
|
|
|
*/
|
2025-04-19 23:59:27 +02:00
|
|
|
~WindowWaylandVulkan();
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @brief Starts Vulkan initialization and returns a command buffer.
|
|
|
|
|
*
|
|
|
|
|
* This command buffer can be used to record Vulkan setup commands.
|
|
|
|
|
*
|
|
|
|
|
* @return VkCommandBuffer A Vulkan command buffer for recording initialization commands.
|
|
|
|
|
*/
|
2025-05-03 06:51:33 +02:00
|
|
|
VkCommandBuffer StartInit();
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @brief Completes Vulkan initialization.
|
|
|
|
|
*
|
|
|
|
|
* Finalizes any remaining setup required after recording commands returned by StartInit().
|
|
|
|
|
*/
|
2025-05-03 06:51:33 +02:00
|
|
|
void FinishInit();
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @brief Starts the event loop asynchronously.
|
|
|
|
|
*
|
|
|
|
|
* This method triggers rendering without blocking the caller.
|
|
|
|
|
*/
|
2025-06-13 23:59:36 +02:00
|
|
|
void StartAsync();
|
2025-06-14 14:58:02 +02:00
|
|
|
/**
|
|
|
|
|
* @brief Starts the event loop synchronously.
|
|
|
|
|
*
|
|
|
|
|
* This method blocks the caller until the event loop stops.
|
|
|
|
|
*/
|
2025-06-13 23:59:36 +02:00
|
|
|
void StartSync();
|
2025-04-19 15:46:26 +02:00
|
|
|
private:
|
|
|
|
|
void CreateSwapchain();
|
|
|
|
|
VkSurfaceKHR vulkanSurface = VK_NULL_HANDLE;
|
2025-04-19 23:59:27 +02:00
|
|
|
VkSwapchainKHR swapChain = VK_NULL_HANDLE;
|
|
|
|
|
VkFormat colorFormat;
|
|
|
|
|
VkColorSpaceKHR colorSpace;
|
|
|
|
|
std::vector<VkImage> images;
|
|
|
|
|
std::vector<VkImageView> imageViews;
|
2025-04-19 15:46:26 +02:00
|
|
|
std::thread thread;
|
2025-04-19 23:59:27 +02:00
|
|
|
std::vector<VkCommandBuffer> drawCmdBuffers;
|
|
|
|
|
std::vector<VkFramebuffer> frameBuffers;
|
|
|
|
|
VkSubmitInfo submitInfo;
|
|
|
|
|
DepthStencil depthStencil;
|
|
|
|
|
Semaphores semaphores;
|
|
|
|
|
uint32_t currentBuffer = 0;
|
|
|
|
|
VkPipelineStageFlags submitPipelineStages = VK_PIPELINE_STAGE_COLOR_ATTACHMENT_OUTPUT_BIT;
|
|
|
|
|
VkRenderPass renderPass = VK_NULL_HANDLE;
|
2025-04-19 15:46:26 +02:00
|
|
|
};
|
|
|
|
|
}
|