diff --git a/overlay_experimental/DX10_Hook.cpp b/overlay_experimental/DX10_Hook.cpp index 8ce5dfe..ceba0e6 100644 --- a/overlay_experimental/DX10_Hook.cpp +++ b/overlay_experimental/DX10_Hook.cpp @@ -194,7 +194,17 @@ DX10_Hook::~DX10_Hook() { PRINT_DEBUG("DX10 Hook removed\n"); - resetRenderState(); + if (initialized) + { + mainRenderTargetView->Release(); + + //ImGui_ImplDX10_Shutdown(); + ImGui_ImplDX10_InvalidateDeviceObjects(); + Windows_Hook::Inst().resetRenderState(); + ImGui::DestroyContext(); + + initialized = false; + } FreeLibrary(reinterpret_cast(_library)); diff --git a/overlay_experimental/DX11_Hook.cpp b/overlay_experimental/DX11_Hook.cpp index e225b07..5e5c197 100644 --- a/overlay_experimental/DX11_Hook.cpp +++ b/overlay_experimental/DX11_Hook.cpp @@ -212,7 +212,18 @@ DX11_Hook::~DX11_Hook() { PRINT_DEBUG("DX11 Hook removed\n"); - resetRenderState(); + if (initialized) + { + mainRenderTargetView->Release(); + pContext->Release(); + + //ImGui_ImplDX11_Shutdown(); + ImGui_ImplDX11_InvalidateDeviceObjects(); + Windows_Hook::Inst().resetRenderState(); + ImGui::DestroyContext(); + + initialized = false; + } FreeLibrary(reinterpret_cast(_library)); diff --git a/overlay_experimental/DX12_Hook.cpp b/overlay_experimental/DX12_Hook.cpp index bd1aa1e..edb85f8 100644 --- a/overlay_experimental/DX12_Hook.cpp +++ b/overlay_experimental/DX12_Hook.cpp @@ -243,7 +243,19 @@ DX12_Hook::~DX12_Hook() { PRINT_DEBUG("DX12 Hook removed\n"); - resetRenderState(); + if (initialized) + { + pCmdAlloc->Release(); + pCmdList->Release(); + pDescriptorHeap->Release(); + + //ImGui_ImplDX12_Shutdown(); + ImGui_ImplDX12_InvalidateDeviceObjects(); + Windows_Hook::Inst().resetRenderState(); + ImGui::DestroyContext(); + + initialized = false; + } FreeLibrary(reinterpret_cast(_library));