From ce138fe96954b23c76583b5c1af3abbff0b2f661 Mon Sep 17 00:00:00 2001 From: Raymond Zhao <7199958+rzhao271@users.noreply.github.com> Date: Thu, 13 Oct 2022 08:39:40 -0700 Subject: [PATCH] fix: Windows 7 frame showing for frameless non-resizable windows (#35365) --- patches/chromium/.patches | 2 +- .../feat_add_set_can_resize_mutator.patch | 27 ----------- ...x_remove_caption-removing_style_call.patch | 48 +++++++++++++++++++ shell/browser/native_window_views.cc | 17 ------- 4 files changed, 49 insertions(+), 45 deletions(-) delete mode 100644 patches/chromium/feat_add_set_can_resize_mutator.patch create mode 100644 patches/chromium/fix_remove_caption-removing_style_call.patch diff --git a/patches/chromium/.patches b/patches/chromium/.patches index 5bea8874225..77ac984a3a5 100644 --- a/patches/chromium/.patches +++ b/patches/chromium/.patches @@ -115,7 +115,6 @@ chore_allow_chromium_to_handle_synthetic_mouse_events_for_touch.patch add_maximized_parameter_to_linuxui_getwindowframeprovider.patch revert_spellcheck_fully_launch_spell_check_delayed_initialization.patch add_electron_deps_to_license_credits_file.patch -feat_add_set_can_resize_mutator.patch fix_crash_loading_non-standard_schemes_in_iframes.patch disable_optimization_guide_for_preconnect_feature.patch fix_return_v8_value_from_localframe_requestexecutescript.patch @@ -123,3 +122,4 @@ create_browser_v8_snapshot_file_name_fuse.patch feat_ensure_mas_builds_of_the_same_application_can_use_safestorage.patch cherry-pick-c83640db21b5.patch fix_on-screen-keyboard_hides_on_input_blur_in_webview.patch +fix_remove_caption-removing_style_call.patch diff --git a/patches/chromium/feat_add_set_can_resize_mutator.patch b/patches/chromium/feat_add_set_can_resize_mutator.patch deleted file mode 100644 index b8f40ec8006..00000000000 --- a/patches/chromium/feat_add_set_can_resize_mutator.patch +++ /dev/null @@ -1,27 +0,0 @@ -From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 -From: Raymond Zhao <7199958+rzhao271@users.noreply.github.com> -Date: Tue, 2 Aug 2022 09:30:36 -0700 -Subject: feat: Add set_can_resize mutator - -Adds a set_can_resize mutator to WidgetDelegate that -doesn't emit the OnSizeConstraintsChanged event. -This way, we can call set_can_resize from Electron before -the widget is initialized to set the value earlier, -and in turn, avoid showing a frame at startup -for frameless applications. - -diff --git a/ui/views/widget/widget_delegate.h b/ui/views/widget/widget_delegate.h -index 8e15368a19ec68a468ad9834dd6d08b5b30f98a8..9b73c9faf0fa25568d0a278b1e9a1933ba20224f 100644 ---- a/ui/views/widget/widget_delegate.h -+++ b/ui/views/widget/widget_delegate.h -@@ -323,6 +323,10 @@ class VIEWS_EXPORT WidgetDelegate { - // be cycled through with keyboard focus. - virtual void GetAccessiblePanes(std::vector* panes) {} - -+ // A setter for the can_resize parameter that doesn't -+ // emit any events. -+ void set_can_resize(bool can_resize) { params_.can_resize = can_resize; } -+ - // Setters for data parameters of the WidgetDelegate. If you use these - // setters, there is no need to override the corresponding virtual getters. - void SetAccessibleRole(ax::mojom::Role role); diff --git a/patches/chromium/fix_remove_caption-removing_style_call.patch b/patches/chromium/fix_remove_caption-removing_style_call.patch new file mode 100644 index 00000000000..b7923a81dde --- /dev/null +++ b/patches/chromium/fix_remove_caption-removing_style_call.patch @@ -0,0 +1,48 @@ +From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001 +From: Raymond Zhao <7199958+rzhao271@users.noreply.github.com> +Date: Wed, 17 Aug 2022 13:49:40 -0700 +Subject: fix: Adjust caption-removing style call + +There is a SetWindowLong call that removes WS_CAPTION for frameless +windows, but Electron uses WS_CAPTION even for frameless windows, +unless they are transparent. + +Changing this call only affects frameless windows, and it fixes +a visual glitch where they showed a Windows 7 style frame +during startup. + +The if statement was originally introduced by +https://codereview.chromium.org/9372053/, and it was there to fix +a visual glitch with the close button showing up during startup +or resizing, but Electron does not seem to run into that issue +for opaque frameless windows even with that block commented out. + +diff --git a/ui/views/win/hwnd_message_handler.cc b/ui/views/win/hwnd_message_handler.cc +index 400278ab26a4e095fd837fcf84c952a1297b173d..55afa69870f27b877826ea8a442ab20a8b336d74 100644 +--- a/ui/views/win/hwnd_message_handler.cc ++++ b/ui/views/win/hwnd_message_handler.cc +@@ -1731,7 +1731,23 @@ LRESULT HWNDMessageHandler::OnCreate(CREATESTRUCT* create_struct) { + SendMessage(hwnd(), WM_CHANGEUISTATE, MAKELPARAM(UIS_CLEAR, UISF_HIDEFOCUS), + 0); + +- if (!delegate_->HasFrame()) { ++ LONG is_popup = ++ GetWindowLong(hwnd(), GWL_STYLE) & static_cast(WS_POPUP); ++ ++ // For transparent windows, Electron removes the WS_CAPTION style, ++ // so we continue to remove it here. If we didn't, an opaque rectangle ++ // would show up. ++ // For non-transparent windows, Electron keeps the WS_CAPTION style, ++ // so we don't remove it in that case. If we did, a Windows 7 frame ++ // would show up. ++ // We also need this block for frameless popup windows. When the user opens ++ // a dropdown in an Electron app, the internal popup menu from ++ // third_party/blink/renderer/core/html/forms/internal_popup_menu.h ++ // is rendered. That menu is actually an HTML page inside of a frameless popup window. ++ // A new popup window is created every time the user opens the dropdown, ++ // and this code path is run. The code block below runs SendFrameChanged, ++ // which gives the dropdown options the proper layout. ++ if (!delegate_->HasFrame() && (is_translucent_ || is_popup)) { + SetWindowLong(hwnd(), GWL_STYLE, + GetWindowLong(hwnd(), GWL_STYLE) & ~WS_CAPTION); + SendFrameChanged(); diff --git a/shell/browser/native_window_views.cc b/shell/browser/native_window_views.cc index 1b10f9446c9..4e80fad3dfb 100644 --- a/shell/browser/native_window_views.cc +++ b/shell/browser/native_window_views.cc @@ -280,24 +280,7 @@ NativeWindowViews::NativeWindowViews(const gin_helper::Dictionary& options, new ElectronDesktopWindowTreeHostLinux(this, native_widget); #endif - // Ref https://github.com/electron/electron/issues/30760 - // Set the can_resize param before initializing the widget. - // When resizable_ is true, this causes the WS_THICKFRAME style - // to be passed into CreateWindowEx and SetWindowLong calls in - // WindowImpl::Init and HwndMessageHandler::SizeConstraintsChanged - // respectively. As a result, the Windows 7 frame doesn't show, - // but it isn't clear why this is the case. - // When resizable_ is false, WS_THICKFRAME is not passed into the - // SetWindowLong call, so the Windows 7 frame still shows. - // One workaround would be to call set_can_resize(true) here, - // and then move the SetCanResize(resizable_) call after the - // SetWindowLong call around line 365, but that's a much larger change. - set_can_resize(true); widget()->Init(std::move(params)); - - // When the workaround above is not needed anymore, only this - // call should be necessary. - // With the workaround in place, this call doesn't do anything. SetCanResize(resizable_); bool fullscreen = false;