From 601217218759d088f12680a428fead8c8b26a5e0 Mon Sep 17 00:00:00 2001 From: David Sanders Date: Fri, 31 Mar 2023 09:06:09 -0700 Subject: [PATCH] fix: set background color for menu bar on Windows (#37766) --- shell/browser/ui/views/menu_bar.cc | 15 ++++++++++++--- shell/browser/ui/views/menu_bar.h | 3 +++ 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/shell/browser/ui/views/menu_bar.cc b/shell/browser/ui/views/menu_bar.cc index 7a0ba8139e1f..0ec33726417b 100644 --- a/shell/browser/ui/views/menu_bar.cc +++ b/shell/browser/ui/views/menu_bar.cc @@ -35,12 +35,11 @@ const char MenuBar::kViewClassName[] = "ElectronMenuBar"; MenuBar::MenuBar(NativeWindow* window, RootView* root_view) : background_color_(kDefaultColor), window_(window), root_view_(root_view) { const ui::NativeTheme* theme = root_view_->GetNativeTheme(); - RefreshColorCache(theme); - UpdateViewColors(); #if BUILDFLAG(IS_WIN) SetBackground(views::CreateThemedSolidBackground(ui::kColorMenuBackground)); - background_color_ = GetBackground()->get_color(); #endif + RefreshColorCache(theme); + UpdateViewColors(); SetFocusBehavior(FocusBehavior::ALWAYS); SetLayoutManager(std::make_unique( views::BoxLayout::Orientation::kHorizontal)); @@ -209,6 +208,14 @@ void MenuBar::ButtonPressed(size_t id, const ui::Event& event) { menu_delegate->AddObserver(this); } +void MenuBar::ViewHierarchyChanged( + const views::ViewHierarchyChangedDetails& details) { + views::AccessiblePaneView::ViewHierarchyChanged(details); +#if BUILDFLAG(IS_WIN) + background_color_ = GetBackground()->get_color(); +#endif +} + void MenuBar::RefreshColorCache(const ui::NativeTheme* theme) { if (theme) { #if BUILDFLAG(IS_LINUX) @@ -217,6 +224,8 @@ void MenuBar::RefreshColorCache(const ui::NativeTheme* theme) { gtk::GetFgColor("GtkMenuBar#menubar GtkMenuItem#menuitem GtkLabel"); disabled_color_ = gtk::GetFgColor( "GtkMenuBar#menubar GtkMenuItem#menuitem:disabled GtkLabel"); +#elif BUILDFLAG(IS_WIN) + background_color_ = GetBackground()->get_color(); #endif } } diff --git a/shell/browser/ui/views/menu_bar.h b/shell/browser/ui/views/menu_bar.h index 91546fb33cc5..b4beb95a723e 100644 --- a/shell/browser/ui/views/menu_bar.h +++ b/shell/browser/ui/views/menu_bar.h @@ -50,6 +50,9 @@ class MenuBar : public views::AccessiblePaneView, ElectronMenuModel** menu_model, views::MenuButton** button); + void ViewHierarchyChanged( + const views::ViewHierarchyChangedDetails& details) override; + private: // MenuDelegate::Observer: void OnBeforeExecuteCommand() override;