diff --git a/Source/Core/DolphinNoGUI/PlatformWin32.cpp b/Source/Core/DolphinNoGUI/PlatformWin32.cpp index b92849a3b6..78a9cd783d 100644 --- a/Source/Core/DolphinNoGUI/PlatformWin32.cpp +++ b/Source/Core/DolphinNoGUI/PlatformWin32.cpp @@ -13,6 +13,7 @@ #include #include #include +#include #include "VideoCommon/Present.h" #include "resource.h" @@ -180,6 +181,18 @@ LRESULT PlatformWin32::WndProc(HWND hwnd, UINT msg, WPARAM wParam, LPARAM lParam return DefWindowProc(hwnd, msg, wParam, lParam); } + case WM_CREATE: + { + if (hwnd) + { + // Remove rounded corners from the render window on Windows 11 + const DWM_WINDOW_CORNER_PREFERENCE corner_preference = DWMWCP_DONOTROUND; + DwmSetWindowAttribute(hwnd, DWMWA_WINDOW_CORNER_PREFERENCE, &corner_preference, + sizeof(corner_preference)); + } + } + break; + case WM_SIZE: { if (g_presenter) diff --git a/Source/Core/DolphinQt/RenderWidget.cpp b/Source/Core/DolphinQt/RenderWidget.cpp index 225e2f2113..99d6c988ff 100644 --- a/Source/Core/DolphinQt/RenderWidget.cpp +++ b/Source/Core/DolphinQt/RenderWidget.cpp @@ -37,6 +37,7 @@ #ifdef _WIN32 #include +#include #endif RenderWidget::RenderWidget(QWidget* parent) : QWidget(parent) @@ -69,7 +70,7 @@ RenderWidget::RenderWidget(QWidget* parent) : QWidget(parent) // (which results in them not getting called) connect(this, &RenderWidget::StateChanged, Host::GetInstance(), &Host::SetRenderFullscreen, Qt::DirectConnection); - connect(this, &RenderWidget::HandleChanged, Host::GetInstance(), &Host::SetRenderHandle, + connect(this, &RenderWidget::HandleChanged, this, &RenderWidget::OnHandleChanged, Qt::DirectConnection); connect(this, &RenderWidget::SizeChanged, Host::GetInstance(), &Host::ResizeSurface, Qt::DirectConnection); @@ -133,6 +134,20 @@ void RenderWidget::dropEvent(QDropEvent* event) State::LoadAs(Core::System::GetInstance(), path.toStdString()); } +void RenderWidget::OnHandleChanged(void* handle) +{ + if (handle) + { +#ifdef _WIN32 + // Remove rounded corners from the render window on Windows 11 + const DWM_WINDOW_CORNER_PREFERENCE corner_preference = DWMWCP_DONOTROUND; + DwmSetWindowAttribute(reinterpret_cast(handle), DWMWA_WINDOW_CORNER_PREFERENCE, + &corner_preference, sizeof(corner_preference)); +#endif + } + Host::GetInstance()->SetRenderHandle(handle); +} + void RenderWidget::OnHideCursorChanged() { UpdateCursor(); diff --git a/Source/Core/DolphinQt/RenderWidget.h b/Source/Core/DolphinQt/RenderWidget.h index c214ead7d0..d828bf36d1 100644 --- a/Source/Core/DolphinQt/RenderWidget.h +++ b/Source/Core/DolphinQt/RenderWidget.h @@ -34,6 +34,7 @@ signals: private: void HandleCursorTimer(); + void OnHandleChanged(void* handle); void OnHideCursorChanged(); void OnNeverHideCursorChanged(); void OnLockCursorChanged();