fix: window content protection on older Windows versions (#47856)
This commit is contained in:
parent
c569d5e4ba
commit
01faaa30ea
3 changed files with 17 additions and 6 deletions
|
@ -1282,12 +1282,7 @@ void NativeWindowViews::SetOpacity(const double opacity) {
|
|||
#if BUILDFLAG(IS_WIN)
|
||||
const double boundedOpacity = std::clamp(opacity, 0.0, 1.0);
|
||||
HWND hwnd = GetAcceleratedWidget();
|
||||
if (!layered_) {
|
||||
LONG ex_style = ::GetWindowLong(hwnd, GWL_EXSTYLE);
|
||||
ex_style |= WS_EX_LAYERED;
|
||||
::SetWindowLong(hwnd, GWL_EXSTYLE, ex_style);
|
||||
layered_ = true;
|
||||
}
|
||||
SetLayered();
|
||||
::SetLayeredWindowAttributes(hwnd, 0, boundedOpacity * 255, LWA_ALPHA);
|
||||
opacity_ = boundedOpacity;
|
||||
#else
|
||||
|
@ -1730,6 +1725,16 @@ void NativeWindowViews::UpdateThickFrame() {
|
|||
FlipWindowStyle(GetAcceleratedWidget(), resizable_, WS_THICKFRAME);
|
||||
}
|
||||
}
|
||||
|
||||
void NativeWindowViews::SetLayered() {
|
||||
HWND hwnd = GetAcceleratedWidget();
|
||||
if (!layered_) {
|
||||
LONG ex_style = ::GetWindowLong(hwnd, GWL_EXSTYLE);
|
||||
ex_style |= WS_EX_LAYERED;
|
||||
::SetWindowLong(hwnd, GWL_EXSTYLE, ex_style);
|
||||
layered_ = true;
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
void NativeWindowViews::OnWidgetActivationChanged(views::Widget* changed_widget,
|
||||
|
|
|
@ -178,6 +178,7 @@ class NativeWindowViews : public NativeWindow,
|
|||
#if BUILDFLAG(IS_WIN)
|
||||
TaskbarHost& taskbar_host() { return taskbar_host_; }
|
||||
void UpdateThickFrame();
|
||||
void SetLayered();
|
||||
#endif
|
||||
|
||||
SkColor overlay_button_color() const { return overlay_button_color_; }
|
||||
|
|
|
@ -176,6 +176,11 @@ void ElectronDesktopWindowTreeHostWin::UpdateAllowScreenshots() {
|
|||
if (allowed == allow_screenshots_)
|
||||
return;
|
||||
|
||||
// On some older Windows versions, setting the display affinity
|
||||
// to WDA_EXCLUDEFROMCAPTURE won't prevent the window from being
|
||||
// captured - setting WS_EX_LAYERED mitigates this issue.
|
||||
if (base::win::GetVersion() < base::win::Version::WIN11_22H2)
|
||||
native_window_view_->SetLayered();
|
||||
::SetWindowDisplayAffinity(
|
||||
GetAcceleratedWidget(),
|
||||
allow_screenshots_ ? WDA_NONE : WDA_EXCLUDEFROMCAPTURE);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue