diff options
author | ReinUsesLisp <reinuseslisp@airmail.cc> | 2020-01-21 20:40:53 +0100 |
---|---|---|
committer | ReinUsesLisp <reinuseslisp@airmail.cc> | 2020-01-29 21:53:11 +0100 |
commit | f92cbc55018b5a3d98dd2093354f20c62ace5fda (patch) | |
tree | 7ec9af0d8820b45de580c2d608fdb1853485db83 /src/yuzu_cmd/emu_window/emu_window_sdl2_vk.h | |
parent | web_service/telemetry_json: Report USER_CONFIG (diff) | |
download | yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.tar yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.tar.gz yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.tar.bz2 yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.tar.lz yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.tar.xz yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.tar.zst yuzu-f92cbc55018b5a3d98dd2093354f20c62ace5fda.zip |
Diffstat (limited to 'src/yuzu_cmd/emu_window/emu_window_sdl2_vk.h')
-rw-r--r-- | src/yuzu_cmd/emu_window/emu_window_sdl2_vk.h | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/src/yuzu_cmd/emu_window/emu_window_sdl2_vk.h b/src/yuzu_cmd/emu_window/emu_window_sdl2_vk.h new file mode 100644 index 000000000..f7234841b --- /dev/null +++ b/src/yuzu_cmd/emu_window/emu_window_sdl2_vk.h @@ -0,0 +1,39 @@ +// Copyright 2018 yuzu Emulator Project +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#pragma once + +#include <vulkan/vulkan.h> +#include "core/frontend/emu_window.h" +#include "yuzu_cmd/emu_window/emu_window_sdl2.h" + +class EmuWindow_SDL2_VK final : public EmuWindow_SDL2 { +public: + explicit EmuWindow_SDL2_VK(bool fullscreen); + ~EmuWindow_SDL2_VK(); + + /// Swap buffers to display the next frame + void SwapBuffers() override; + + /// Makes the graphics context current for the caller thread + void MakeCurrent() override; + + /// Releases the GL context from the caller thread + void DoneCurrent() override; + + /// Retrieves Vulkan specific handlers from the window + void RetrieveVulkanHandlers(void* get_instance_proc_addr, void* instance, + void* surface) const override; + + std::unique_ptr<Core::Frontend::GraphicsContext> CreateSharedContext() const override; + +private: + bool UseStandardLayers(PFN_vkGetInstanceProcAddr vkGetInstanceProcAddr) const; + + VkInstance instance{}; + VkSurfaceKHR surface{}; + + PFN_vkGetInstanceProcAddr vkGetInstanceProcAddr{}; + PFN_vkDestroyInstance vkDestroyInstance{}; +}; |