mirror of
				https://github.com/yuzu-emu/yuzu-android
				synced 2025-10-25 04:12:25 -07:00 
			
		
		
		
	core: frontend: Refactor GraphicsContext to its own module.
This commit is contained in:
		| @@ -140,6 +140,7 @@ add_library(core STATIC | ||||
|     frontend/emu_window.h | ||||
|     frontend/framebuffer_layout.cpp | ||||
|     frontend/framebuffer_layout.h | ||||
|     frontend/graphics_context.h | ||||
|     hid/emulated_console.cpp | ||||
|     hid/emulated_console.h | ||||
|     hid/emulated_controller.cpp | ||||
|   | ||||
| @@ -6,8 +6,6 @@ | ||||
|  | ||||
| namespace Core::Frontend { | ||||
|  | ||||
| GraphicsContext::~GraphicsContext() = default; | ||||
|  | ||||
| EmuWindow::EmuWindow() { | ||||
|     // TODO: Find a better place to set this. | ||||
|     config.min_client_area_size = | ||||
|   | ||||
| @@ -5,11 +5,14 @@ | ||||
|  | ||||
| #include <memory> | ||||
| #include <utility> | ||||
|  | ||||
| #include "common/common_types.h" | ||||
| #include "core/frontend/framebuffer_layout.h" | ||||
|  | ||||
| namespace Core::Frontend { | ||||
|  | ||||
| class GraphicsContext; | ||||
|  | ||||
| /// Information for the Graphics Backends signifying what type of screen pointer is in | ||||
| /// WindowInformation | ||||
| enum class WindowSystemType { | ||||
| @@ -21,51 +24,6 @@ enum class WindowSystemType { | ||||
|     Android, | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Represents a drawing context that supports graphics operations. | ||||
|  */ | ||||
| class GraphicsContext { | ||||
| public: | ||||
|     virtual ~GraphicsContext(); | ||||
|  | ||||
|     /// Inform the driver to swap the front/back buffers and present the current image | ||||
|     virtual void SwapBuffers() {} | ||||
|  | ||||
|     /// Makes the graphics context current for the caller thread | ||||
|     virtual void MakeCurrent() {} | ||||
|  | ||||
|     /// Releases (dunno if this is the "right" word) the context from the caller thread | ||||
|     virtual void DoneCurrent() {} | ||||
|  | ||||
|     class Scoped { | ||||
|     public: | ||||
|         [[nodiscard]] explicit Scoped(GraphicsContext& context_) : context(context_) { | ||||
|             context.MakeCurrent(); | ||||
|         } | ||||
|         ~Scoped() { | ||||
|             if (active) { | ||||
|                 context.DoneCurrent(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /// In the event that context was destroyed before the Scoped is destroyed, this provides a | ||||
|         /// mechanism to prevent calling a destroyed object's method during the deconstructor | ||||
|         void Cancel() { | ||||
|             active = false; | ||||
|         } | ||||
|  | ||||
|     private: | ||||
|         GraphicsContext& context; | ||||
|         bool active{true}; | ||||
|     }; | ||||
|  | ||||
|     /// Calls MakeCurrent on the context and calls DoneCurrent when the scope for the returned value | ||||
|     /// ends | ||||
|     [[nodiscard]] Scoped Acquire() { | ||||
|         return Scoped{*this}; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| /** | ||||
|  * Abstraction class used to provide an interface between emulation code and the frontend | ||||
|  * (e.g. SDL, QGLWidget, GLFW, etc...). | ||||
|   | ||||
							
								
								
									
										69
									
								
								src/core/frontend/graphics_context.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								src/core/frontend/graphics_context.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,69 @@ | ||||
| // SPDX-FileCopyrightText: 2023 yuzu Emulator Project | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #include <optional> | ||||
| #include <string> | ||||
|  | ||||
| namespace Core::Frontend { | ||||
|  | ||||
| /** | ||||
|  * Represents a drawing context that supports graphics operations. | ||||
|  */ | ||||
| class GraphicsContext { | ||||
| public: | ||||
|     virtual ~GraphicsContext() = default; | ||||
|  | ||||
|     /// Inform the driver to swap the front/back buffers and present the current image | ||||
|     virtual void SwapBuffers() {} | ||||
|  | ||||
|     /// Makes the graphics context current for the caller thread | ||||
|     virtual void MakeCurrent() {} | ||||
|  | ||||
|     /// Releases (dunno if this is the "right" word) the context from the caller thread | ||||
|     virtual void DoneCurrent() {} | ||||
|  | ||||
|     /// Parameters used to configure custom drivers (used by Android only) | ||||
|     struct CustomDriverParameters { | ||||
|         std::string hook_lib_dir; | ||||
|         std::string custom_driver_dir; | ||||
|         std::string custom_driver_name; | ||||
|         std::string file_redirect_dir; | ||||
|     }; | ||||
|  | ||||
|     /// Gets custom driver parameters configured by the frontend (used by Android only) | ||||
|     virtual std::optional<CustomDriverParameters> GetCustomDriverParameters() { | ||||
|         return {}; | ||||
|     } | ||||
|  | ||||
|     class Scoped { | ||||
|     public: | ||||
|         [[nodiscard]] explicit Scoped(GraphicsContext& context_) : context(context_) { | ||||
|             context.MakeCurrent(); | ||||
|         } | ||||
|         ~Scoped() { | ||||
|             if (active) { | ||||
|                 context.DoneCurrent(); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         /// In the event that context was destroyed before the Scoped is destroyed, this provides a | ||||
|         /// mechanism to prevent calling a destroyed object's method during the deconstructor | ||||
|         void Cancel() { | ||||
|             active = false; | ||||
|         } | ||||
|  | ||||
|     private: | ||||
|         GraphicsContext& context; | ||||
|         bool active{true}; | ||||
|     }; | ||||
|  | ||||
|     /// Calls MakeCurrent on the context and calls DoneCurrent when the scope for the returned value | ||||
|     /// ends | ||||
|     [[nodiscard]] Scoped Acquire() { | ||||
|         return Scoped{*this}; | ||||
|     } | ||||
| }; | ||||
|  | ||||
| } // namespace Core::Frontend | ||||
| @@ -14,6 +14,7 @@ | ||||
| #include "core/core.h" | ||||
| #include "core/core_timing.h" | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "core/hle/service/nvdrv/nvdata.h" | ||||
| #include "core/perf_stats.h" | ||||
| #include "video_core/cdma_pusher.h" | ||||
|   | ||||
| @@ -7,7 +7,7 @@ | ||||
| #include "common/settings.h" | ||||
| #include "common/thread.h" | ||||
| #include "core/core.h" | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "video_core/control/scheduler.h" | ||||
| #include "video_core/dma_pusher.h" | ||||
| #include "video_core/gpu.h" | ||||
|   | ||||
| @@ -5,6 +5,7 @@ | ||||
|  | ||||
| #include "common/logging/log.h" | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "video_core/renderer_base.h" | ||||
|  | ||||
| namespace VideoCore { | ||||
|   | ||||
| @@ -9,7 +9,7 @@ | ||||
|  | ||||
| #include "common/common_funcs.h" | ||||
| #include "common/common_types.h" | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/framebuffer_layout.h" | ||||
| #include "video_core/gpu.h" | ||||
| #include "video_core/rasterizer_interface.h" | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,8 @@ | ||||
| // SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project | ||||
| // SPDX-License-Identifier: GPL-2.0-or-later | ||||
|  | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "video_core/renderer_null/renderer_null.h" | ||||
|  | ||||
| namespace Null { | ||||
|   | ||||
| @@ -4,6 +4,7 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "shader_recompiler/frontend/ir/basic_block.h" | ||||
| #include "shader_recompiler/frontend/maxwell/control_flow.h" | ||||
|  | ||||
|   | ||||
| @@ -16,7 +16,7 @@ | ||||
| #include "common/settings.h" | ||||
| #include "common/telemetry.h" | ||||
| #include "core/core_timing.h" | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "core/telemetry_session.h" | ||||
| #include "video_core/gpu.h" | ||||
| #include "video_core/renderer_vulkan/renderer_vulkan.h" | ||||
|   | ||||
| @@ -46,6 +46,7 @@ | ||||
| #include "core/core.h" | ||||
| #include "core/cpu_manager.h" | ||||
| #include "core/frontend/framebuffer_layout.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
| #include "input_common/drivers/camera.h" | ||||
| #include "input_common/drivers/keyboard.h" | ||||
| #include "input_common/drivers/mouse.h" | ||||
|   | ||||
| @@ -4,7 +4,9 @@ | ||||
| #pragma once | ||||
|  | ||||
| #include <utility> | ||||
|  | ||||
| #include "core/frontend/emu_window.h" | ||||
| #include "core/frontend/graphics_context.h" | ||||
|  | ||||
| struct SDL_Window; | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user