Converted existing vulkan program without vkbootstrap to use SDL callbacks

This commit is contained in:
azraptor 2025-07-03 09:09:45 -04:00
parent 969a3285e9
commit 6d48ac251c
4 changed files with 52 additions and 43 deletions

View File

@ -4,7 +4,7 @@ project(vksdlproj VERSION 0.2.0 LANGUAGES C CXX)
SET(CMAKE_BUILD_RPATH_USE_ORIGIN TRUE) SET(CMAKE_BUILD_RPATH_USE_ORIGIN TRUE)
set(EXE_NAME project) set(EXE_NAME project)
set(PROGRAM_SOURCES )#${CMAKE_CURRENT_SOURCE_DIR}/src/vulkanapp.cc) set(PROGRAM_SOURCES ${CMAKE_CURRENT_SOURCE_DIR}/src/vulkanapp.cc)
option(SDL3_NONSYSTEM "Use SDL3 from folder in source tree" ON) option(SDL3_NONSYSTEM "Use SDL3 from folder in source tree" ON)

View File

@ -53,6 +53,9 @@ public:
void init(); void init();
void loop(); void loop();
void cleanup(); void cleanup();
inline bool minimized() { return mMinimized; }
inline void minimized(bool v) { mMinimized = v; }
inline void resized(bool v) { mResized = v; }
private: private:
// SDL2 // SDL2
SDL_Window *mWin; SDL_Window *mWin;
@ -61,7 +64,7 @@ private:
// Not tied to library // Not tied to library
uint32_t mWidth; uint32_t mWidth;
uint32_t mHeight; uint32_t mHeight;
bool mActive = false; // bool mActive = false;
bool mResized = false; bool mResized = false;
bool mMinimized = false; bool mMinimized = false;

View File

@ -3,11 +3,15 @@
#include <SDL3/SDL_init.h> #include <SDL3/SDL_init.h>
#include <SDL3/SDL.h> #include <SDL3/SDL.h>
#include "vulkanapp.hh"
#include <exception>
constexpr uint32_t winInitWidth = 512; constexpr uint32_t winInitWidth = 512;
constexpr uint32_t winInitHeight = 512; constexpr uint32_t winInitHeight = 512;
struct AppContext { struct AppContext {
SDL_Window *window; VulkanApp vkapp;
SDL_AppResult appQuit = SDL_APP_CONTINUE; SDL_AppResult appQuit = SDL_APP_CONTINUE;
}; };
@ -17,18 +21,21 @@ SDL_AppResult SDL_Fail() {
} }
SDL_AppResult SDL_AppInit(void **appstate, int argc, char **argv) { SDL_AppResult SDL_AppInit(void **appstate, int argc, char **argv) {
(void)argc;
(void)argv;
if(!SDL_Init(SDL_INIT_VIDEO)) if(!SDL_Init(SDL_INIT_VIDEO))
return SDL_Fail(); return SDL_Fail();
SDL_Window *win = SDL_CreateWindow("SDL3 Vulkan", winInitWidth, winInitHeight, SDL_WINDOW_RESIZABLE | SDL_WINDOW_VULKAN); try {
*appstate = new AppContext { .vkapp = VulkanApp(1024, 1024)};
if(!win) AppContext* app = static_cast<AppContext*>(*appstate);
return SDL_Fail(); app->vkapp.init();
} catch(const std::exception& except) {
*appstate = new AppContext { fprintf(stderr, "Error! %s\n", except.what());
.window = win,
};
return SDL_APP_FAILURE;
}
return SDL_APP_CONTINUE; return SDL_APP_CONTINUE;
} }
@ -38,6 +45,18 @@ SDL_AppResult SDL_AppEvent(void *appstate, SDL_Event *event) {
switch(event->type) { switch(event->type) {
case SDL_EVENT_QUIT: case SDL_EVENT_QUIT:
app->appQuit = SDL_APP_SUCCESS; app->appQuit = SDL_APP_SUCCESS;
break;
case SDL_EVENT_WINDOW_RESIZED:
app->vkapp.resized(true);
break;
case SDL_EVENT_WINDOW_MINIMIZED:
app->vkapp.minimized(true);
break;
case SDL_EVENT_WINDOW_RESTORED:
app->vkapp.minimized(false);
break;
default:
break;
} }
return SDL_APP_CONTINUE; return SDL_APP_CONTINUE;
@ -46,14 +65,28 @@ SDL_AppResult SDL_AppEvent(void *appstate, SDL_Event *event) {
SDL_AppResult SDL_AppIterate(void *appstate) { SDL_AppResult SDL_AppIterate(void *appstate) {
AppContext* app = static_cast<AppContext*>(appstate); AppContext* app = static_cast<AppContext*>(appstate);
try {
app->vkapp.loop();
} catch(const std::exception& except) {
fprintf(stderr, "Error! %s\n", except.what());
return SDL_APP_FAILURE;
}
return app->appQuit; return app->appQuit;
} }
void SDL_AppQuit(void *appstate, SDL_AppResult result) { void SDL_AppQuit(void *appstate, SDL_AppResult result) {
AppContext* app = static_cast<AppContext*>(appstate); AppContext* app = static_cast<AppContext*>(appstate);
if(result == SDL_APP_FAILURE) {
fputs("Program failure, shutting down\n", stderr);
} else {
puts("Program shutting down, no errors.");
}
if(app) { if(app) {
SDL_DestroyWindow(app->window); app->vkapp.cleanup();
delete app; delete app;
} }

View File

@ -862,31 +862,7 @@ void VulkanApp::loop() {
throw std::runtime_error(err); throw std::runtime_error(err);
} }
mActive = true;
// Main loop
while(mActive) {
while(SDL_PollEvent(&mEvent)) {
switch (mEvent.type) {
case SDL_EVENT_QUIT:
mActive = false;
break;
case SDL_EVENT_WINDOW_RESIZED:
mResized = true;
break;
case SDL_EVENT_WINDOW_MINIMIZED:
mMinimized = true;
break;
case SDL_EVENT_WINDOW_RESTORED:
mMinimized = false;
break;
default:
break;
}
}
if(!mMinimized) drawFrame(); if(!mMinimized) drawFrame();
}
vkDeviceWaitIdle(mLogicalDevice); vkDeviceWaitIdle(mLogicalDevice);
} }
@ -921,7 +897,4 @@ void VulkanApp::cleanup() {
SDL_DestroyWindow(mWin); SDL_DestroyWindow(mWin);
mWin = nullptr; mWin = nullptr;
} }
//SDL_Vulkan_UnloadLibrary();
SDL_Quit();
} }