diff options
| author | 2022-10-06 09:31:12 -0400 | |
|---|---|---|
| committer | 2022-10-07 17:33:59 -0400 | |
| commit | a5476541f2adf5a61820033e5f2d77ab5ab4d5fc (patch) | |
| tree | 18150114340decce507d23650b0efd002ea39789 | |
| parent | Merge pull request #6142 from lat9nq/prog_meta_ref_bind_address (diff) | |
| download | yuzu-a5476541f2adf5a61820033e5f2d77ab5ab4d5fc.tar.gz yuzu-a5476541f2adf5a61820033e5f2d77ab5ab4d5fc.tar.xz yuzu-a5476541f2adf5a61820033e5f2d77ab5ab4d5fc.zip | |
video_core: don't block rendering on screenshots
| -rw-r--r-- | src/video_core/renderer_base.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/src/video_core/renderer_base.cpp b/src/video_core/renderer_base.cpp index 45791aa75..e8761a747 100644 --- a/src/video_core/renderer_base.cpp +++ b/src/video_core/renderer_base.cpp | |||
| @@ -1,6 +1,8 @@ | |||
| 1 | // SPDX-FileCopyrightText: 2015 Citra Emulator Project | 1 | // SPDX-FileCopyrightText: 2015 Citra Emulator Project |
| 2 | // SPDX-License-Identifier: GPL-2.0-or-later | 2 | // SPDX-License-Identifier: GPL-2.0-or-later |
| 3 | 3 | ||
| 4 | #include <thread> | ||
| 5 | |||
| 4 | #include "common/logging/log.h" | 6 | #include "common/logging/log.h" |
| 5 | #include "core/frontend/emu_window.h" | 7 | #include "core/frontend/emu_window.h" |
| 6 | #include "video_core/renderer_base.h" | 8 | #include "video_core/renderer_base.h" |
| @@ -35,8 +37,12 @@ void RendererBase::RequestScreenshot(void* data, std::function<void(bool)> callb | |||
| 35 | LOG_ERROR(Render, "A screenshot is already requested or in progress, ignoring the request"); | 37 | LOG_ERROR(Render, "A screenshot is already requested or in progress, ignoring the request"); |
| 36 | return; | 38 | return; |
| 37 | } | 39 | } |
| 40 | auto async_callback{[callback = std::move(callback)](bool invert_y) { | ||
| 41 | std::thread t{callback, invert_y}; | ||
| 42 | t.detach(); | ||
| 43 | }}; | ||
| 38 | renderer_settings.screenshot_bits = data; | 44 | renderer_settings.screenshot_bits = data; |
| 39 | renderer_settings.screenshot_complete_callback = std::move(callback); | 45 | renderer_settings.screenshot_complete_callback = async_callback; |
| 40 | renderer_settings.screenshot_framebuffer_layout = layout; | 46 | renderer_settings.screenshot_framebuffer_layout = layout; |
| 41 | renderer_settings.screenshot_requested = true; | 47 | renderer_settings.screenshot_requested = true; |
| 42 | } | 48 | } |