From c7648462caafa845ecbf1585efe420576fb74996 Mon Sep 17 00:00:00 2001 From: Micha Hanselmann Date: Thu, 7 Oct 2021 15:14:36 +0200 Subject: [PATCH] fix: black window on screen capture when content protection is enabled --- shell/browser/native_window_views.cc | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/shell/browser/native_window_views.cc b/shell/browser/native_window_views.cc index 8e9228e7e21a3..64ce33b54b0d4 100644 --- a/shell/browser/native_window_views.cc +++ b/shell/browser/native_window_views.cc @@ -1108,8 +1108,17 @@ void NativeWindowViews::SetIgnoreMouseEvents(bool ignore, bool forward) { void NativeWindowViews::SetContentProtection(bool enable) { #if defined(OS_WIN) + HWND hwnd = GetAcceleratedWidget(); + if (!layered_) { + // Workaround to prevent black window on screen capture after hiding and + // showing the BrowserWindow. + LONG ex_style = ::GetWindowLong(hwnd, GWL_EXSTYLE); + ex_style |= WS_EX_LAYERED; + ::SetWindowLong(hwnd, GWL_EXSTYLE, ex_style); + layered_ = true; + } DWORD affinity = enable ? WDA_EXCLUDEFROMCAPTURE : WDA_NONE; - ::SetWindowDisplayAffinity(GetAcceleratedWidget(), affinity); + ::SetWindowDisplayAffinity(hwnd, affinity); #endif }