feat: enable Windows Control Overlay on Linux (#42682)
* feat: enable Windows Control Overlay on Linux Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * docs: update documentation for Linux WCO Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * fix: initial symbol painting Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * test: enable WCO tests for Linux Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * fix: add missing Layer include Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * chore: fix gn-check failure Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * fix: enable BrowserWindow.setTitleBarOverlay on Linux Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * test: fix test for maximize event on Linux Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * fix: geometry updating on BrowserWindow.setTitleBarOverlay Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * fix: crash when invalid titleBarStyle set Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * chore: clean up ordering and comments Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * Update docs/api/structures/base-window-options.md Co-authored-by: Erick Zhao <erick@hotmail.ca> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * feat: enable customizing symbolColor Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * docs: correct symbolColor reference Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> * chore: update patches Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> * chore: remove Chrome-specific padding Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> --------- Co-authored-by: trop[bot] <37223003+trop[bot]@users.noreply.github.com> Co-authored-by: Shelley Vohr <shelley.vohr@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
This commit is contained in:
parent
89d09922f7
commit
342ef8e7e1
24 changed files with 1026 additions and 107 deletions
205
shell/browser/ui/views/opaque_frame_view.h
Normal file
205
shell/browser/ui/views/opaque_frame_view.h
Normal file
|
@ -0,0 +1,205 @@
|
|||
// Copyright 2024 Microsoft GmbH.
|
||||
// Use of this source code is governed by a BSD-style license that can be
|
||||
// found in the LICENSE file.
|
||||
|
||||
#ifndef ELECTRON_SHELL_BROWSER_UI_VIEWS_OPAQUE_FRAME_VIEW_H_
|
||||
#define ELECTRON_SHELL_BROWSER_UI_VIEWS_OPAQUE_FRAME_VIEW_H_
|
||||
|
||||
#include <memory>
|
||||
|
||||
#include "base/memory/raw_ptr.h"
|
||||
#include "base/scoped_observation.h"
|
||||
#include "chrome/browser/ui/view_ids.h"
|
||||
#include "shell/browser/ui/views/frameless_view.h"
|
||||
#include "ui/base/metadata/metadata_header_macros.h"
|
||||
#include "ui/gfx/font_list.h"
|
||||
#include "ui/linux/nav_button_provider.h"
|
||||
#include "ui/linux/window_button_order_observer.h"
|
||||
#include "ui/views/controls/button/button.h"
|
||||
#include "ui/views/window/caption_button_types.h"
|
||||
#include "ui/views/window/frame_buttons.h"
|
||||
#include "ui/views/window/non_client_view.h"
|
||||
|
||||
class CaptionButtonPlaceholderContainer;
|
||||
|
||||
namespace electron {
|
||||
|
||||
class OpaqueFrameView : public FramelessView {
|
||||
METADATA_HEADER(OpaqueFrameView, FramelessView)
|
||||
|
||||
public:
|
||||
// Constants used by OpaqueBrowserFrameView as well.
|
||||
static const int kContentEdgeShadowThickness;
|
||||
|
||||
static constexpr int kNonClientExtraTopThickness = 1;
|
||||
|
||||
OpaqueFrameView();
|
||||
~OpaqueFrameView() override;
|
||||
|
||||
// FramelessView:
|
||||
void Init(NativeWindowViews* window, views::Widget* frame) override;
|
||||
int ResizingBorderHitTest(const gfx::Point& point) override;
|
||||
void InvalidateCaptionButtons() override;
|
||||
|
||||
// views::NonClientFrameView:
|
||||
gfx::Rect GetBoundsForClientView() const override;
|
||||
gfx::Rect GetWindowBoundsForClientBounds(
|
||||
const gfx::Rect& client_bounds) const override;
|
||||
int NonClientHitTest(const gfx::Point& point) override;
|
||||
void ResetWindowControls() override;
|
||||
views::View* TargetForRect(views::View* root, const gfx::Rect& rect) override;
|
||||
|
||||
// views::View:
|
||||
void Layout(PassKey) override;
|
||||
void OnPaint(gfx::Canvas* canvas) override;
|
||||
|
||||
private:
|
||||
enum ButtonAlignment { ALIGN_LEADING, ALIGN_TRAILING };
|
||||
|
||||
struct TopAreaPadding {
|
||||
int leading;
|
||||
int trailing;
|
||||
};
|
||||
|
||||
void PaintAsActiveChanged();
|
||||
|
||||
void UpdateCaptionButtonPlaceholderContainerBackground();
|
||||
void UpdateFrameCaptionButtons();
|
||||
void LayoutWindowControls();
|
||||
void LayoutWindowControlsOverlay();
|
||||
|
||||
// Creates and returns an ImageButton with |this| as its listener.
|
||||
// Memory is owned by the caller.
|
||||
views::Button* CreateButton(ViewID view_id,
|
||||
int accessibility_string_id,
|
||||
views::CaptionButtonIcon icon_type,
|
||||
int ht_component,
|
||||
const gfx::VectorIcon& icon_image,
|
||||
views::Button::PressedCallback callback);
|
||||
|
||||
/** Layout-Related Utility Functions **/
|
||||
|
||||
// Returns the insets from the native window edge to the client view.
|
||||
// This does not include any client edge. If |restored| is true, this
|
||||
// is calculated as if the window was restored, regardless of its
|
||||
// current node_data.
|
||||
gfx::Insets FrameBorderInsets(bool restored) const;
|
||||
|
||||
// Returns the thickness of the border that makes up the window frame edge
|
||||
// along the top of the frame. If |restored| is true, this acts as if the
|
||||
// window is restored regardless of the actual mode.
|
||||
int FrameTopBorderThickness(bool restored) const;
|
||||
|
||||
// Returns the spacing between the edge of the browser window and the first
|
||||
// frame buttons.
|
||||
TopAreaPadding GetTopAreaPadding(bool has_leading_buttons,
|
||||
bool has_trailing_buttons) const;
|
||||
|
||||
// Determines whether the top frame is condensed vertically, as when the
|
||||
// window is maximized. If true, the top frame is just the height of a tab,
|
||||
// rather than having extra vertical space above the tabs.
|
||||
bool IsFrameCondensed() const;
|
||||
|
||||
// The insets from the native window edge to the client view when the window
|
||||
// is restored. This goes all the way to the web contents on the left, right,
|
||||
// and bottom edges.
|
||||
gfx::Insets RestoredFrameBorderInsets() const;
|
||||
|
||||
// The insets from the native window edge to the flat portion of the
|
||||
// window border. That is, this function returns the "3D portion" of the
|
||||
// border when the window is restored. The returned insets will not be larger
|
||||
// than RestoredFrameBorderInsets().
|
||||
gfx::Insets RestoredFrameEdgeInsets() const;
|
||||
|
||||
// Additional vertical padding between tabs and the top edge of the window
|
||||
// when the window is restored.
|
||||
int NonClientExtraTopThickness() const;
|
||||
|
||||
// Returns the height of the entire nonclient top border, from the edge of the
|
||||
// window to the top of the tabs. If |restored| is true, this is calculated as
|
||||
// if the window was restored, regardless of its current state.
|
||||
int NonClientTopHeight(bool restored) const;
|
||||
|
||||
// Returns the y-coordinate of button |button_id|. If |restored| is true,
|
||||
// acts as if the window is restored regardless of the real mode.
|
||||
int CaptionButtonY(views::FrameButton button_id, bool restored) const;
|
||||
|
||||
// Returns the y-coordinate of the caption button when native frame buttons
|
||||
// are disabled. If |restored| is true, acts as if the window is restored
|
||||
// regardless of the real mode.
|
||||
int DefaultCaptionButtonY(bool restored) const;
|
||||
|
||||
// Returns the insets from the native window edge to the flat portion of the
|
||||
// window border. That is, this function returns the "3D portion" of the
|
||||
// border. If |restored| is true, acts as if the window is restored
|
||||
// regardless of the real mode.
|
||||
gfx::Insets FrameEdgeInsets(bool restored) const;
|
||||
|
||||
// Returns the size of the window icon. This can be platform dependent
|
||||
// because of differences in fonts.
|
||||
int GetIconSize() const;
|
||||
|
||||
// Returns the spacing between the edge of the browser window and the first
|
||||
// frame buttons.
|
||||
TopAreaPadding GetTopAreaPadding() const;
|
||||
|
||||
// Returns the color of the frame.
|
||||
SkColor GetFrameColor() const;
|
||||
|
||||
// Initializes the button with |button_id| to be aligned according to
|
||||
// |alignment|.
|
||||
void ConfigureButton(views::FrameButton button_id, ButtonAlignment alignment);
|
||||
|
||||
// Sets the visibility of all buttons associated with |button_id| to false.
|
||||
void HideButton(views::FrameButton button_id);
|
||||
|
||||
// Adds a window caption button to either the leading or trailing side.
|
||||
void SetBoundsForButton(views::FrameButton button_id,
|
||||
views::Button* button,
|
||||
ButtonAlignment alignment);
|
||||
|
||||
// Computes the height of the top area of the frame.
|
||||
int GetTopAreaHeight() const;
|
||||
|
||||
// Returns the margin around button |button_id|. If |leading_spacing| is
|
||||
// true, returns the left margin (in RTL), otherwise returns the right margin
|
||||
// (in RTL). Extra margin may be added if |is_leading_button| is true.
|
||||
int GetWindowCaptionSpacing(views::FrameButton button_id,
|
||||
bool leading_spacing,
|
||||
bool is_leading_button) const;
|
||||
|
||||
// Window controls.
|
||||
raw_ptr<views::Button> minimize_button_;
|
||||
raw_ptr<views::Button> maximize_button_;
|
||||
raw_ptr<views::Button> restore_button_;
|
||||
raw_ptr<views::Button> close_button_;
|
||||
|
||||
// The leading and trailing x positions of the empty space available for
|
||||
// laying out titlebar elements.
|
||||
int available_space_leading_x_ = 0;
|
||||
int available_space_trailing_x_ = 0;
|
||||
|
||||
// Whether any of the window control buttons were packed on the leading or
|
||||
// trailing sides. This state is only valid while layout is being performed.
|
||||
bool placed_leading_button_ = false;
|
||||
bool placed_trailing_button_ = false;
|
||||
|
||||
// The size of the window buttons. This does not count labels or other
|
||||
// elements that should be counted in a minimal frame.
|
||||
int minimum_size_for_buttons_ = 0;
|
||||
|
||||
std::vector<views::FrameButton> leading_buttons_;
|
||||
std::vector<views::FrameButton> trailing_buttons_{
|
||||
views::FrameButton::kMinimize, views::FrameButton::kMaximize,
|
||||
views::FrameButton::kClose};
|
||||
|
||||
base::CallbackListSubscription paint_as_active_changed_subscription_;
|
||||
|
||||
// PlaceholderContainer beneath the controls button for WCO.
|
||||
raw_ptr<CaptionButtonPlaceholderContainer>
|
||||
caption_button_placeholder_container_;
|
||||
};
|
||||
|
||||
} // namespace electron
|
||||
|
||||
#endif // ELECTRON_SHELL_BROWSER_UI_VIEWS_OPAQUE_FRAME_VIEW_H_
|
Loading…
Add table
Add a link
Reference in a new issue