[3b7d497] | 1 | #ifndef _SDL_GAME_H
|
---|
| 2 | #define _SDL_GAME_H
|
---|
| 3 |
|
---|
| 4 | #include <vector>
|
---|
| 5 | #include <vulkan/vulkan.h>
|
---|
| 6 |
|
---|
| 7 | #include <SDL2/SDL.h>
|
---|
[c6f0793] | 8 |
|
---|
[6493e43] | 9 | #include "IMGUI/imgui_impl_vulkan.h"
|
---|
| 10 |
|
---|
[3b7d497] | 11 | #include "consts.hpp"
|
---|
[ce9dc9f] | 12 | #include "vulkan-utils.hpp"
|
---|
[3b7d497] | 13 |
|
---|
| 14 | #include "game-gui-sdl.hpp"
|
---|
| 15 |
|
---|
| 16 | using namespace std;
|
---|
| 17 |
|
---|
| 18 | #define VulkanGame NewVulkanGame
|
---|
| 19 |
|
---|
| 20 | #ifdef NDEBUG
|
---|
| 21 | const bool ENABLE_VALIDATION_LAYERS = false;
|
---|
| 22 | #else
|
---|
| 23 | const bool ENABLE_VALIDATION_LAYERS = true;
|
---|
| 24 | #endif
|
---|
| 25 |
|
---|
| 26 | class VulkanGame {
|
---|
| 27 | public:
|
---|
[ce9dc9f] | 28 | VulkanGame();
|
---|
[3b7d497] | 29 | ~VulkanGame();
|
---|
| 30 |
|
---|
[ce9dc9f] | 31 | void run(int width, int height, unsigned char guiFlags);
|
---|
[3b7d497] | 32 |
|
---|
| 33 | private:
|
---|
| 34 | static VKAPI_ATTR VkBool32 VKAPI_CALL debugCallback(
|
---|
| 35 | VkDebugUtilsMessageSeverityFlagBitsEXT messageSeverity,
|
---|
| 36 | VkDebugUtilsMessageTypeFlagsEXT messageType,
|
---|
| 37 | const VkDebugUtilsMessengerCallbackDataEXT* pCallbackData,
|
---|
| 38 | void* pUserData);
|
---|
| 39 |
|
---|
[c6f0793] | 40 | bool done;
|
---|
| 41 |
|
---|
[3b7d497] | 42 | // TODO: Good place to start using smart pointers
|
---|
| 43 | GameGui* gui;
|
---|
| 44 |
|
---|
| 45 | SDL_version sdlVersion;
|
---|
| 46 | SDL_Window* window;
|
---|
| 47 |
|
---|
[ce9dc9f] | 48 | VkInstance instance;
|
---|
[3b7d497] | 49 | VkDebugUtilsMessengerEXT debugMessenger = VK_NULL_HANDLE;
|
---|
| 50 | VkSurfaceKHR surface; // TODO: Change the variable name to vulkanSurface
|
---|
[ce9dc9f] | 51 | VkPhysicalDevice physicalDevice = VK_NULL_HANDLE;
|
---|
| 52 | VkDevice device;
|
---|
[6493e43] | 53 |
|
---|
| 54 | VkQueue graphicsQueue;
|
---|
| 55 | VkQueue presentQueue;
|
---|
[ce9dc9f] | 56 |
|
---|
| 57 | // TODO: Maybe make a swapchain struct for convenience
|
---|
| 58 | VkSurfaceFormatKHR swapChainSurfaceFormat;
|
---|
| 59 | VkPresentModeKHR swapChainPresentMode;
|
---|
| 60 | VkExtent2D swapChainExtent;
|
---|
| 61 | uint32_t swapChainMinImageCount;
|
---|
| 62 | uint32_t swapChainImageCount;
|
---|
| 63 |
|
---|
| 64 | VkSwapchainKHR swapChain;
|
---|
| 65 | vector<VkImage> swapChainImages;
|
---|
| 66 | vector<VkImageView> swapChainImageViews;
|
---|
| 67 | vector<VkFramebuffer> swapChainFramebuffers;
|
---|
| 68 |
|
---|
| 69 | VkRenderPass renderPass;
|
---|
| 70 |
|
---|
| 71 | VkCommandPool resourceCommandPool;
|
---|
| 72 |
|
---|
| 73 | vector<VkCommandPool> commandPools;
|
---|
| 74 | vector<VkCommandBuffer> commandBuffers;
|
---|
| 75 |
|
---|
| 76 | VulkanImage depthImage;
|
---|
| 77 |
|
---|
| 78 | // These are per frame
|
---|
| 79 | vector<VkSemaphore> imageAcquiredSemaphores;
|
---|
| 80 | vector<VkSemaphore> renderCompleteSemaphores;
|
---|
| 81 |
|
---|
| 82 | // These are per swap chain image
|
---|
| 83 | vector<VkFence> inFlightFences;
|
---|
| 84 |
|
---|
| 85 | uint32_t imageIndex;
|
---|
| 86 | uint32_t currentFrame;
|
---|
| 87 |
|
---|
[3b7d497] | 88 | // My code, but not complete. Skips creating the SDL renderer, probably because it doesn't use hardware acceleration.
|
---|
| 89 | // I should try to get uncapped framerate and compare performance w/ and w/out an SDL renderer
|
---|
| 90 | bool initUI(int width, int height, unsigned char guiFlags);
|
---|
| 91 | void initVulkan(); // Mostly example code
|
---|
| 92 | void cleanup(); // Mostly example
|
---|
| 93 |
|
---|
| 94 | void createVulkanInstance(const vector<const char*>& validationLayers);
|
---|
| 95 | void setupDebugMessenger();
|
---|
| 96 | void populateDebugMessengerCreateInfo(VkDebugUtilsMessengerCreateInfoEXT& createInfo);
|
---|
| 97 | void createVulkanSurface();
|
---|
[ce9dc9f] | 98 | void pickPhysicalDevice(const vector<const char*>& deviceExtensions);
|
---|
[3b7d497] | 99 | bool isDeviceSuitable(VkPhysicalDevice physicalDevice, const vector<const char*>& deviceExtensions);
|
---|
| 100 | void createLogicalDevice(const vector<const char*>& validationLayers,
|
---|
[ce9dc9f] | 101 | const vector<const char*>& deviceExtensions);
|
---|
| 102 | void chooseSwapChainProperties();
|
---|
| 103 | void createSwapChain();
|
---|
| 104 | void createImageViews();
|
---|
| 105 | void createRenderPass();
|
---|
| 106 | VkFormat findDepthFormat(); // TODO: Declare/define (in the cpp file) this function in some util functions section
|
---|
| 107 | void createResourceCommandPool();
|
---|
| 108 | void createCommandPools();
|
---|
| 109 | void createFramebuffers();
|
---|
| 110 | void createCommandBuffers();
|
---|
| 111 | void createSyncObjects();
|
---|
| 112 |
|
---|
| 113 | void recreateSwapChain();
|
---|
| 114 |
|
---|
| 115 | void cleanupSwapChain();
|
---|
[6493e43] | 116 |
|
---|
| 117 | // Pipeline variables. Hopefully, I can eventually use the GraphicsPipeline_Vulkan class for the imgui pipeline
|
---|
| 118 | VkDescriptorPool descriptorPool;
|
---|
| 119 |
|
---|
[ce9dc9f] | 120 | // Helper methods from imgui_impl_vulkan that were moved into VulkanGame to give them access to class instance variables
|
---|
| 121 | public:
|
---|
| 122 | void FrameRender(ImDrawData* draw_data);
|
---|
| 123 | void FramePresent();
|
---|
[6493e43] | 124 |
|
---|
[ce9dc9f] | 125 | };
|
---|
[6493e43] | 126 |
|
---|
[3b7d497] | 127 | #endif // _SDL_GAME_H
|
---|