don't load images forever to avoid a never ending slowdown

This commit is contained in:
otavepto 2024-02-09 10:32:33 +02:00
parent 8f62d7d487
commit 0af025ea5d
3 changed files with 14 additions and 4 deletions

View File

@ -80,6 +80,10 @@ struct Overlay_Achievement
uint32 unlock_time; uint32 unlock_time;
std::weak_ptr<uint64_t> icon; std::weak_ptr<uint64_t> icon;
std::weak_ptr<uint64_t> icon_gray; std::weak_ptr<uint64_t> icon_gray;
constexpr const static int ICON_LOAD_MAX_TRIALS = 3;
uint8_t icon_load_trials = ICON_LOAD_MAX_TRIALS;
uint8_t icon_gray_load_trials = ICON_LOAD_MAX_TRIALS;
}; };
#ifdef EMU_OVERLAY #ifdef EMU_OVERLAY

View File

@ -1181,7 +1181,8 @@ void Steam_Overlay::OverlayProc()
bool achieved = x.achieved; bool achieved = x.achieved;
bool hidden = x.hidden && !achieved; bool hidden = x.hidden && !achieved;
if (x.icon.expired()) { if (x.icon.expired() && x.icon_load_trials) {
--x.icon_load_trials;
std::string file_path = Local_Storage::get_game_settings_path() + x.icon_name; std::string file_path = Local_Storage::get_game_settings_path() + x.icon_name;
unsigned long long file_size = file_size_(file_path); unsigned long long file_size = file_size_(file_path);
if (!file_size) { if (!file_size) {
@ -1192,10 +1193,12 @@ void Steam_Overlay::OverlayProc()
std::string img = Local_Storage::load_image_resized(file_path, "", settings->overlay_appearance.icon_size); std::string img = Local_Storage::load_image_resized(file_path, "", settings->overlay_appearance.icon_size);
if (img.length() > 0) { if (img.length() > 0) {
if (_renderer) x.icon = _renderer->CreateImageResource((void*)img.c_str(), settings->overlay_appearance.icon_size, settings->overlay_appearance.icon_size); if (_renderer) x.icon = _renderer->CreateImageResource((void*)img.c_str(), settings->overlay_appearance.icon_size, settings->overlay_appearance.icon_size);
if (!x.icon.expired()) x.icon_load_trials = Overlay_Achievement::ICON_LOAD_MAX_TRIALS;
} }
} }
} }
if (x.icon_gray.expired()) { if (x.icon_gray.expired() && x.icon_gray_load_trials) {
--x.icon_gray_load_trials;
std::string file_path = Local_Storage::get_game_settings_path() + x.icon_gray_name; std::string file_path = Local_Storage::get_game_settings_path() + x.icon_gray_name;
unsigned long long file_size = file_size_(file_path); unsigned long long file_size = file_size_(file_path);
if (!file_size) { if (!file_size) {
@ -1206,6 +1209,7 @@ void Steam_Overlay::OverlayProc()
std::string img = Local_Storage::load_image_resized(file_path, "", settings->overlay_appearance.icon_size); std::string img = Local_Storage::load_image_resized(file_path, "", settings->overlay_appearance.icon_size);
if (img.length() > 0) { if (img.length() > 0) {
if (_renderer) x.icon_gray = _renderer->CreateImageResource((void*)img.c_str(), settings->overlay_appearance.icon_size, settings->overlay_appearance.icon_size); if (_renderer) x.icon_gray = _renderer->CreateImageResource((void*)img.c_str(), settings->overlay_appearance.icon_size, settings->overlay_appearance.icon_size);
if (!x.icon_gray.expired()) x.icon_gray_load_trials = Overlay_Achievement::ICON_LOAD_MAX_TRIALS;
} }
} }
} }

View File

@ -182,8 +182,10 @@ void DX12_Hook::_PrepareForOverlay(IDXGISwapChain* pSwapChain, ID3D12CommandQueu
{ {
// UINT bufferIndex = pSwapChain3->GetCurrentBackBufferIndex(); // UINT bufferIndex = pSwapChain3->GetCurrentBackBufferIndex();
pDevice = nullptr; pDevice = nullptr;
if (pSwapChain3->GetDevice(IID_PPV_ARGS(&pDevice)) != S_OK) if (pSwapChain3->GetDevice(IID_PPV_ARGS(&pDevice)) != S_OK) {
pSwapChain3->Release();
return; return;
}
UINT bufferCount = sc_desc.BufferCount; UINT bufferCount = sc_desc.BufferCount;
@ -217,9 +219,9 @@ void DX12_Hook::_PrepareForOverlay(IDXGISwapChain* pSwapChain, ID3D12CommandQueu
desc.NodeMask = 1; desc.NodeMask = 1;
if (pDevice->CreateDescriptorHeap(&desc, IID_PPV_ARGS(&pRtvDescHeap)) != S_OK) if (pDevice->CreateDescriptorHeap(&desc, IID_PPV_ARGS(&pRtvDescHeap)) != S_OK)
{ {
pSrvDescHeap->Release();
pDevice->Release(); pDevice->Release();
pSwapChain3->Release(); pSwapChain3->Release();
pSrvDescHeap->Release();
return; return;
} }