Merge pull request #12716 from electron/share-more-window-code
Refactor NativeWindow (Part 10): Share more code between NativeWindow implementations
This commit is contained in:
commit
51b7322a0f
6 changed files with 95 additions and 110 deletions
|
@ -13,6 +13,7 @@
|
||||||
#include "atom/common/color_util.h"
|
#include "atom/common/color_util.h"
|
||||||
#include "atom/common/options_switches.h"
|
#include "atom/common/options_switches.h"
|
||||||
#include "native_mate/dictionary.h"
|
#include "native_mate/dictionary.h"
|
||||||
|
#include "ui/views/widget/widget.h"
|
||||||
|
|
||||||
DEFINE_WEB_CONTENTS_USER_DATA_KEY(atom::NativeWindowRelay);
|
DEFINE_WEB_CONTENTS_USER_DATA_KEY(atom::NativeWindowRelay);
|
||||||
|
|
||||||
|
@ -20,7 +21,8 @@ namespace atom {
|
||||||
|
|
||||||
NativeWindow::NativeWindow(const mate::Dictionary& options,
|
NativeWindow::NativeWindow(const mate::Dictionary& options,
|
||||||
NativeWindow* parent)
|
NativeWindow* parent)
|
||||||
: has_frame_(true),
|
: widget_(new views::Widget),
|
||||||
|
has_frame_(true),
|
||||||
transparent_(false),
|
transparent_(false),
|
||||||
enable_larger_than_screen_(false),
|
enable_larger_than_screen_(false),
|
||||||
is_closed_(false),
|
is_closed_(false),
|
||||||
|
@ -509,6 +511,14 @@ void NativeWindow::NotifyWindowMessage(UINT message,
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
views::Widget* NativeWindow::GetWidget() {
|
||||||
|
return widget();
|
||||||
|
}
|
||||||
|
|
||||||
|
const views::Widget* NativeWindow::GetWidget() const {
|
||||||
|
return widget();
|
||||||
|
}
|
||||||
|
|
||||||
NativeWindowRelay::NativeWindowRelay(base::WeakPtr<NativeWindow> window)
|
NativeWindowRelay::NativeWindowRelay(base::WeakPtr<NativeWindow> window)
|
||||||
: key(UserDataKey()), window(window) {}
|
: key(UserDataKey()), window(window) {}
|
||||||
|
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#include "base/supports_user_data.h"
|
#include "base/supports_user_data.h"
|
||||||
#include "content/public/browser/web_contents_user_data.h"
|
#include "content/public/browser/web_contents_user_data.h"
|
||||||
#include "extensions/browser/app_window/size_constraints.h"
|
#include "extensions/browser/app_window/size_constraints.h"
|
||||||
|
#include "ui/views/widget/widget_delegate.h"
|
||||||
|
|
||||||
class SkRegion;
|
class SkRegion;
|
||||||
|
|
||||||
|
@ -47,7 +48,8 @@ class NativeBrowserView;
|
||||||
|
|
||||||
struct DraggableRegion;
|
struct DraggableRegion;
|
||||||
|
|
||||||
class NativeWindow : public base::SupportsUserData {
|
class NativeWindow : public base::SupportsUserData,
|
||||||
|
public views::WidgetDelegate {
|
||||||
public:
|
public:
|
||||||
~NativeWindow() override;
|
~NativeWindow() override;
|
||||||
|
|
||||||
|
@ -259,6 +261,8 @@ class NativeWindow : public base::SupportsUserData {
|
||||||
observers_.RemoveObserver(obs);
|
observers_.RemoveObserver(obs);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
views::Widget* widget() const { return widget_.get(); }
|
||||||
|
|
||||||
bool has_frame() const { return has_frame_; }
|
bool has_frame() const { return has_frame_; }
|
||||||
void set_has_frame(bool has_frame) { has_frame_ = has_frame; }
|
void set_has_frame(bool has_frame) { has_frame_ = has_frame; }
|
||||||
|
|
||||||
|
@ -272,11 +276,17 @@ class NativeWindow : public base::SupportsUserData {
|
||||||
protected:
|
protected:
|
||||||
NativeWindow(const mate::Dictionary& options, NativeWindow* parent);
|
NativeWindow(const mate::Dictionary& options, NativeWindow* parent);
|
||||||
|
|
||||||
|
// views::WidgetDelegate:
|
||||||
|
views::Widget* GetWidget() override;
|
||||||
|
const views::Widget* GetWidget() const override;
|
||||||
|
|
||||||
void set_browser_view(NativeBrowserView* browser_view) {
|
void set_browser_view(NativeBrowserView* browser_view) {
|
||||||
browser_view_ = browser_view;
|
browser_view_ = browser_view;
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
std::unique_ptr<views::Widget> widget_;
|
||||||
|
|
||||||
// Whether window has standard frame.
|
// Whether window has standard frame.
|
||||||
bool has_frame_;
|
bool has_frame_;
|
||||||
|
|
||||||
|
|
|
@ -12,8 +12,6 @@
|
||||||
|
|
||||||
#include "atom/browser/native_window.h"
|
#include "atom/browser/native_window.h"
|
||||||
#include "base/mac/scoped_nsobject.h"
|
#include "base/mac/scoped_nsobject.h"
|
||||||
#include "ui/views/widget/widget_delegate.h"
|
|
||||||
#include "ui/views/widget/widget_observer.h"
|
|
||||||
|
|
||||||
@class AtomNSWindow;
|
@class AtomNSWindow;
|
||||||
@class AtomNSWindowDelegate;
|
@class AtomNSWindowDelegate;
|
||||||
|
@ -23,8 +21,7 @@
|
||||||
|
|
||||||
namespace atom {
|
namespace atom {
|
||||||
|
|
||||||
class NativeWindowMac : public NativeWindow,
|
class NativeWindowMac : public NativeWindow {
|
||||||
public views::WidgetDelegate {
|
|
||||||
public:
|
public:
|
||||||
NativeWindowMac(const mate::Dictionary& options, NativeWindow* parent);
|
NativeWindowMac(const mate::Dictionary& options, NativeWindow* parent);
|
||||||
~NativeWindowMac() override;
|
~NativeWindowMac() override;
|
||||||
|
@ -147,8 +144,6 @@ class NativeWindowMac : public NativeWindow,
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
// views::WidgetDelegate:
|
// views::WidgetDelegate:
|
||||||
views::Widget* GetWidget() override;
|
|
||||||
const views::Widget* GetWidget() const override;
|
|
||||||
bool CanResize() const override;
|
bool CanResize() const override;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -157,7 +152,6 @@ class NativeWindowMac : public NativeWindow,
|
||||||
|
|
||||||
void SetForwardMouseMessages(bool forward);
|
void SetForwardMouseMessages(bool forward);
|
||||||
|
|
||||||
std::unique_ptr<views::Widget> widget_;
|
|
||||||
AtomNSWindow* window_; // Weak ref, managed by widget_.
|
AtomNSWindow* window_; // Weak ref, managed by widget_.
|
||||||
|
|
||||||
base::scoped_nsobject<AtomNSWindowDelegate> window_delegate_;
|
base::scoped_nsobject<AtomNSWindowDelegate> window_delegate_;
|
||||||
|
|
|
@ -308,15 +308,14 @@ NativeWindowMac::NativeWindowMac(const mate::Dictionary& options,
|
||||||
|
|
||||||
// Create views::Widget and assign window_ with it.
|
// Create views::Widget and assign window_ with it.
|
||||||
// TODO(zcbenz): Get rid of the window_ in future.
|
// TODO(zcbenz): Get rid of the window_ in future.
|
||||||
widget_.reset(new views::Widget());
|
|
||||||
views::Widget::InitParams params;
|
views::Widget::InitParams params;
|
||||||
params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
|
params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
|
||||||
params.bounds = bounds;
|
params.bounds = bounds;
|
||||||
params.delegate = this;
|
params.delegate = this;
|
||||||
params.type = views::Widget::InitParams::TYPE_WINDOW;
|
params.type = views::Widget::InitParams::TYPE_WINDOW;
|
||||||
params.native_widget = new AtomNativeWidgetMac(styleMask, widget_.get());
|
params.native_widget = new AtomNativeWidgetMac(styleMask, widget());
|
||||||
widget_->Init(params);
|
widget()->Init(params);
|
||||||
window_ = static_cast<AtomNSWindow*>(widget_->GetNativeWindow());
|
window_ = static_cast<AtomNSWindow*>(widget()->GetNativeWindow());
|
||||||
|
|
||||||
[window_ setShell:this];
|
[window_ setShell:this];
|
||||||
[window_ setEnableLargerThanScreen:enable_larger_than_screen()];
|
[window_ setEnableLargerThanScreen:enable_larger_than_screen()];
|
||||||
|
@ -1305,14 +1304,6 @@ gfx::Rect NativeWindowMac::WindowBoundsToContentBounds(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
views::Widget* NativeWindowMac::GetWidget() {
|
|
||||||
return widget_.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
const views::Widget* NativeWindowMac::GetWidget() const {
|
|
||||||
return widget_.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
bool NativeWindowMac::CanResize() const {
|
bool NativeWindowMac::CanResize() const {
|
||||||
return resizable_;
|
return resizable_;
|
||||||
}
|
}
|
||||||
|
|
|
@ -120,7 +120,6 @@ class NativeWindowClientView : public views::ClientView {
|
||||||
NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
NativeWindow* parent)
|
NativeWindow* parent)
|
||||||
: NativeWindow(options, parent),
|
: NativeWindow(options, parent),
|
||||||
window_(new views::Widget),
|
|
||||||
content_view_(nullptr),
|
content_view_(nullptr),
|
||||||
focused_view_(nullptr),
|
focused_view_(nullptr),
|
||||||
menu_bar_autohide_(false),
|
menu_bar_autohide_(false),
|
||||||
|
@ -138,6 +137,9 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
maximizable_(true),
|
maximizable_(true),
|
||||||
minimizable_(true),
|
minimizable_(true),
|
||||||
fullscreenable_(true) {
|
fullscreenable_(true) {
|
||||||
|
// The root view is this class, it is managed by us.
|
||||||
|
set_owned_by_client();
|
||||||
|
|
||||||
options.Get(options::kTitle, &title_);
|
options.Get(options::kTitle, &title_);
|
||||||
options.Get(options::kAutoHideMenuBar, &menu_bar_autohide_);
|
options.Get(options::kAutoHideMenuBar, &menu_bar_autohide_);
|
||||||
|
|
||||||
|
@ -168,7 +170,7 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
gfx::Rect bounds(0, 0, width, height);
|
gfx::Rect bounds(0, 0, width, height);
|
||||||
widget_size_ = bounds.size();
|
widget_size_ = bounds.size();
|
||||||
|
|
||||||
window_->AddObserver(this);
|
widget()->AddObserver(this);
|
||||||
|
|
||||||
views::Widget::InitParams params;
|
views::Widget::InitParams params;
|
||||||
params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
|
params.ownership = views::Widget::InitParams::WIDGET_OWNS_NATIVE_WIDGET;
|
||||||
|
@ -193,9 +195,9 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
if (parent)
|
if (parent)
|
||||||
params.parent = parent->GetNativeWindow();
|
params.parent = parent->GetNativeWindow();
|
||||||
|
|
||||||
params.native_widget = new AtomDesktopNativeWidgetAura(window_.get());
|
params.native_widget = new AtomDesktopNativeWidgetAura(widget());
|
||||||
atom_desktop_window_tree_host_win_ = new AtomDesktopWindowTreeHostWin(
|
atom_desktop_window_tree_host_win_ = new AtomDesktopWindowTreeHostWin(
|
||||||
this, window_.get(),
|
this, widget(),
|
||||||
static_cast<views::DesktopNativeWidgetAura*>(params.native_widget));
|
static_cast<views::DesktopNativeWidgetAura*>(params.native_widget));
|
||||||
params.desktop_window_tree_host = atom_desktop_window_tree_host_win_;
|
params.desktop_window_tree_host = atom_desktop_window_tree_host_win_;
|
||||||
#elif defined(USE_X11)
|
#elif defined(USE_X11)
|
||||||
|
@ -207,7 +209,7 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
params.wm_class_class = name;
|
params.wm_class_class = name;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
window_->Init(params);
|
widget()->Init(params);
|
||||||
|
|
||||||
bool fullscreen = false;
|
bool fullscreen = false;
|
||||||
options.Get(options::kFullscreen, &fullscreen);
|
options.Get(options::kFullscreen, &fullscreen);
|
||||||
|
@ -287,8 +289,8 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
if (has_frame()) {
|
if (has_frame()) {
|
||||||
// TODO(zcbenz): This was used to force using native frame on Windows 2003,
|
// TODO(zcbenz): This was used to force using native frame on Windows 2003,
|
||||||
// we should check whether setting it in InitParams can work.
|
// we should check whether setting it in InitParams can work.
|
||||||
window_->set_frame_type(views::Widget::FrameType::FRAME_TYPE_FORCE_NATIVE);
|
widget()->set_frame_type(views::Widget::FrameType::FRAME_TYPE_FORCE_NATIVE);
|
||||||
window_->FrameTypeChanged();
|
widget()->FrameTypeChanged();
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
// thickFrame also works for normal window.
|
// thickFrame also works for normal window.
|
||||||
if (!thick_frame_)
|
if (!thick_frame_)
|
||||||
|
@ -302,7 +304,7 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
use_content_size_)
|
use_content_size_)
|
||||||
size = ContentBoundsToWindowBounds(gfx::Rect(size)).size();
|
size = ContentBoundsToWindowBounds(gfx::Rect(size)).size();
|
||||||
|
|
||||||
window_->CenterWindow(size);
|
widget()->CenterWindow(size);
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
// Save initial window state.
|
// Save initial window state.
|
||||||
|
@ -315,7 +317,7 @@ NativeWindowViews::NativeWindowViews(const mate::Dictionary& options,
|
||||||
}
|
}
|
||||||
|
|
||||||
NativeWindowViews::~NativeWindowViews() {
|
NativeWindowViews::~NativeWindowViews() {
|
||||||
window_->RemoveObserver(this);
|
widget()->RemoveObserver(this);
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
// Disable mouse forwarding to relinquish resources, should any be held.
|
// Disable mouse forwarding to relinquish resources, should any be held.
|
||||||
|
@ -345,11 +347,11 @@ void NativeWindowViews::Close() {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
window_->Close();
|
widget()->Close();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::CloseImmediately() {
|
void NativeWindowViews::CloseImmediately() {
|
||||||
window_->CloseNow();
|
widget()->CloseNow();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::Focus(bool focus) {
|
void NativeWindowViews::Focus(bool focus) {
|
||||||
|
@ -358,22 +360,22 @@ void NativeWindowViews::Focus(bool focus) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (focus) {
|
if (focus) {
|
||||||
window_->Activate();
|
widget()->Activate();
|
||||||
} else {
|
} else {
|
||||||
window_->Deactivate();
|
widget()->Deactivate();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsFocused() {
|
bool NativeWindowViews::IsFocused() {
|
||||||
return window_->IsActive();
|
return widget()->IsActive();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::Show() {
|
void NativeWindowViews::Show() {
|
||||||
if (is_modal() && NativeWindow::parent() &&
|
if (is_modal() && NativeWindow::parent() &&
|
||||||
!window_->native_widget_private()->IsVisible())
|
!widget()->native_widget_private()->IsVisible())
|
||||||
static_cast<NativeWindowViews*>(NativeWindow::parent())->SetEnabled(false);
|
NativeWindow::parent()->SetEnabled(false);
|
||||||
|
|
||||||
window_->native_widget_private()->ShowWithWindowState(GetRestoredState());
|
widget()->native_widget_private()->ShowWithWindowState(GetRestoredState());
|
||||||
|
|
||||||
NotifyWindowShow();
|
NotifyWindowShow();
|
||||||
|
|
||||||
|
@ -384,7 +386,7 @@ void NativeWindowViews::Show() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::ShowInactive() {
|
void NativeWindowViews::ShowInactive() {
|
||||||
window_->ShowInactive();
|
widget()->ShowInactive();
|
||||||
|
|
||||||
NotifyWindowShow();
|
NotifyWindowShow();
|
||||||
|
|
||||||
|
@ -396,9 +398,9 @@ void NativeWindowViews::ShowInactive() {
|
||||||
|
|
||||||
void NativeWindowViews::Hide() {
|
void NativeWindowViews::Hide() {
|
||||||
if (is_modal() && NativeWindow::parent())
|
if (is_modal() && NativeWindow::parent())
|
||||||
static_cast<NativeWindowViews*>(NativeWindow::parent())->SetEnabled(true);
|
NativeWindow::parent()->SetEnabled(true);
|
||||||
|
|
||||||
window_->Hide();
|
widget()->Hide();
|
||||||
|
|
||||||
NotifyWindowHide();
|
NotifyWindowHide();
|
||||||
|
|
||||||
|
@ -409,7 +411,7 @@ void NativeWindowViews::Hide() {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsVisible() {
|
bool NativeWindowViews::IsVisible() {
|
||||||
return window_->IsVisible();
|
return widget()->IsVisible();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsEnabled() {
|
bool NativeWindowViews::IsEnabled() {
|
||||||
|
@ -460,9 +462,9 @@ void NativeWindowViews::Maximize() {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (IsVisible())
|
if (IsVisible())
|
||||||
window_->Maximize();
|
widget()->Maximize();
|
||||||
else
|
else
|
||||||
window_->native_widget_private()->ShowWithWindowState(
|
widget()->native_widget_private()->ShowWithWindowState(
|
||||||
ui::SHOW_STATE_MAXIMIZED);
|
ui::SHOW_STATE_MAXIMIZED);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -474,27 +476,27 @@ void NativeWindowViews::Unmaximize() {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
window_->Restore();
|
widget()->Restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsMaximized() {
|
bool NativeWindowViews::IsMaximized() {
|
||||||
return window_->IsMaximized();
|
return widget()->IsMaximized();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::Minimize() {
|
void NativeWindowViews::Minimize() {
|
||||||
if (IsVisible())
|
if (IsVisible())
|
||||||
window_->Minimize();
|
widget()->Minimize();
|
||||||
else
|
else
|
||||||
window_->native_widget_private()->ShowWithWindowState(
|
widget()->native_widget_private()->ShowWithWindowState(
|
||||||
ui::SHOW_STATE_MINIMIZED);
|
ui::SHOW_STATE_MINIMIZED);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::Restore() {
|
void NativeWindowViews::Restore() {
|
||||||
window_->Restore();
|
widget()->Restore();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsMinimized() {
|
bool NativeWindowViews::IsMinimized() {
|
||||||
return window_->IsMinimized();
|
return widget()->IsMinimized();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetFullScreen(bool fullscreen) {
|
void NativeWindowViews::SetFullScreen(bool fullscreen) {
|
||||||
|
@ -529,19 +531,19 @@ void NativeWindowViews::SetFullScreen(bool fullscreen) {
|
||||||
|
|
||||||
// We set the new value after notifying, so we can handle the size event
|
// We set the new value after notifying, so we can handle the size event
|
||||||
// correctly.
|
// correctly.
|
||||||
window_->SetFullscreen(fullscreen);
|
widget()->SetFullscreen(fullscreen);
|
||||||
|
|
||||||
// If restoring from fullscreen and the window isn't visible, force visible,
|
// If restoring from fullscreen and the window isn't visible, force visible,
|
||||||
// else a non-responsive window shell could be rendered.
|
// else a non-responsive window shell could be rendered.
|
||||||
// (this situation may arise when app starts with fullscreen: true)
|
// (this situation may arise when app starts with fullscreen: true)
|
||||||
// Note: the following must be after "window_->SetFullscreen(fullscreen);"
|
// Note: the following must be after "widget()->SetFullscreen(fullscreen);"
|
||||||
if (leaving_fullscreen && !IsVisible())
|
if (leaving_fullscreen && !IsVisible())
|
||||||
FlipWindowStyle(GetAcceleratedWidget(), true, WS_VISIBLE);
|
FlipWindowStyle(GetAcceleratedWidget(), true, WS_VISIBLE);
|
||||||
#else
|
#else
|
||||||
if (IsVisible())
|
if (IsVisible())
|
||||||
window_->SetFullscreen(fullscreen);
|
widget()->SetFullscreen(fullscreen);
|
||||||
else if (fullscreen)
|
else if (fullscreen)
|
||||||
window_->native_widget_private()->ShowWithWindowState(
|
widget()->native_widget_private()->ShowWithWindowState(
|
||||||
ui::SHOW_STATE_FULLSCREEN);
|
ui::SHOW_STATE_FULLSCREEN);
|
||||||
|
|
||||||
// Auto-hide menubar when in fullscreen.
|
// Auto-hide menubar when in fullscreen.
|
||||||
|
@ -553,7 +555,7 @@ void NativeWindowViews::SetFullScreen(bool fullscreen) {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsFullscreen() const {
|
bool NativeWindowViews::IsFullscreen() const {
|
||||||
return window_->IsFullscreen();
|
return widget()->IsFullscreen();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetBounds(const gfx::Rect& bounds, bool animate) {
|
void NativeWindowViews::SetBounds(const gfx::Rect& bounds, bool animate) {
|
||||||
|
@ -566,16 +568,16 @@ void NativeWindowViews::SetBounds(const gfx::Rect& bounds, bool animate) {
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
window_->SetBounds(bounds);
|
widget()->SetBounds(bounds);
|
||||||
}
|
}
|
||||||
|
|
||||||
gfx::Rect NativeWindowViews::GetBounds() {
|
gfx::Rect NativeWindowViews::GetBounds() {
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
if (IsMinimized())
|
if (IsMinimized())
|
||||||
return window_->GetRestoredBounds();
|
return widget()->GetRestoredBounds();
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return window_->GetWindowBoundsInScreen();
|
return widget()->GetWindowBoundsInScreen();
|
||||||
}
|
}
|
||||||
|
|
||||||
gfx::Rect NativeWindowViews::GetContentBounds() {
|
gfx::Rect NativeWindowViews::GetContentBounds() {
|
||||||
|
@ -602,16 +604,13 @@ void NativeWindowViews::SetContentSizeConstraints(
|
||||||
#endif
|
#endif
|
||||||
// widget_delegate() is only available after Init() is called, we make use of
|
// widget_delegate() is only available after Init() is called, we make use of
|
||||||
// this to determine whether native widget has initialized.
|
// this to determine whether native widget has initialized.
|
||||||
if (window_ && window_->widget_delegate())
|
if (widget() && widget()->widget_delegate())
|
||||||
window_->OnSizeConstraintsChanged();
|
widget()->OnSizeConstraintsChanged();
|
||||||
#if defined(OS_WIN) || defined(USE_X11)
|
|
||||||
if (resizable_)
|
if (resizable_)
|
||||||
old_size_constraints_ = size_constraints;
|
old_size_constraints_ = size_constraints;
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetResizable(bool resizable) {
|
void NativeWindowViews::SetResizable(bool resizable) {
|
||||||
#if defined(OS_WIN) || defined(USE_X11)
|
|
||||||
if (resizable != resizable_) {
|
if (resizable != resizable_) {
|
||||||
// On Linux there is no "resizable" property of a window, we have to set
|
// On Linux there is no "resizable" property of a window, we have to set
|
||||||
// both the minimum and maximum size to the window size to achieve it.
|
// both the minimum and maximum size to the window size to achieve it.
|
||||||
|
@ -625,7 +624,6 @@ void NativeWindowViews::SetResizable(bool resizable) {
|
||||||
extensions::SizeConstraints(content_size, content_size));
|
extensions::SizeConstraints(content_size, content_size));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
if (has_frame() && thick_frame_)
|
if (has_frame() && thick_frame_)
|
||||||
FlipWindowStyle(GetAcceleratedWidget(), resizable, WS_THICKFRAME);
|
FlipWindowStyle(GetAcceleratedWidget(), resizable, WS_THICKFRAME);
|
||||||
|
@ -648,11 +646,8 @@ bool NativeWindowViews::IsResizable() {
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
if (has_frame())
|
if (has_frame())
|
||||||
return ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE) & WS_THICKFRAME;
|
return ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE) & WS_THICKFRAME;
|
||||||
else
|
|
||||||
return CanResize();
|
|
||||||
#else
|
|
||||||
return CanResize();
|
|
||||||
#endif
|
#endif
|
||||||
|
return CanResize();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetMovable(bool movable) {
|
void NativeWindowViews::SetMovable(bool movable) {
|
||||||
|
@ -736,24 +731,24 @@ void NativeWindowViews::SetAlwaysOnTop(bool top,
|
||||||
const std::string& level,
|
const std::string& level,
|
||||||
int relativeLevel,
|
int relativeLevel,
|
||||||
std::string* error) {
|
std::string* error) {
|
||||||
window_->SetAlwaysOnTop(top);
|
widget()->SetAlwaysOnTop(top);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsAlwaysOnTop() {
|
bool NativeWindowViews::IsAlwaysOnTop() {
|
||||||
return window_->IsAlwaysOnTop();
|
return widget()->IsAlwaysOnTop();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::Center() {
|
void NativeWindowViews::Center() {
|
||||||
window_->CenterWindow(GetSize());
|
widget()->CenterWindow(GetSize());
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::Invalidate() {
|
void NativeWindowViews::Invalidate() {
|
||||||
window_->SchedulePaintInRect(gfx::Rect(GetBounds().size()));
|
widget()->SchedulePaintInRect(gfx::Rect(GetBounds().size()));
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetTitle(const std::string& title) {
|
void NativeWindowViews::SetTitle(const std::string& title) {
|
||||||
title_ = title;
|
title_ = title;
|
||||||
window_->UpdateWindowTitle();
|
widget()->UpdateWindowTitle();
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string NativeWindowViews::GetTitle() {
|
std::string NativeWindowViews::GetTitle() {
|
||||||
|
@ -773,7 +768,7 @@ void NativeWindowViews::FlashFrame(bool flash) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
window_->FlashFrame(flash);
|
widget()->FlashFrame(flash);
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetSkipTaskbar(bool skip) {
|
void NativeWindowViews::SetSkipTaskbar(bool skip) {
|
||||||
|
@ -1015,11 +1010,11 @@ void NativeWindowViews::SetParentWindow(NativeWindow* parent) {
|
||||||
}
|
}
|
||||||
|
|
||||||
gfx::NativeView NativeWindowViews::GetNativeView() const {
|
gfx::NativeView NativeWindowViews::GetNativeView() const {
|
||||||
return window_->GetNativeView();
|
return widget()->GetNativeView();
|
||||||
}
|
}
|
||||||
|
|
||||||
gfx::NativeWindow NativeWindowViews::GetNativeWindow() const {
|
gfx::NativeWindow NativeWindowViews::GetNativeWindow() const {
|
||||||
return window_->GetNativeWindow();
|
return widget()->GetNativeWindow();
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetProgressBar(double progress,
|
void NativeWindowViews::SetProgressBar(double progress,
|
||||||
|
@ -1073,7 +1068,7 @@ bool NativeWindowViews::IsMenuBarVisible() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::SetVisibleOnAllWorkspaces(bool visible) {
|
void NativeWindowViews::SetVisibleOnAllWorkspaces(bool visible) {
|
||||||
window_->SetVisibleOnAllWorkspaces(visible);
|
widget()->SetVisibleOnAllWorkspaces(visible);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool NativeWindowViews::IsVisibleOnAllWorkspaces() {
|
bool NativeWindowViews::IsVisibleOnAllWorkspaces() {
|
||||||
|
@ -1104,7 +1099,7 @@ gfx::Rect NativeWindowViews::ContentBoundsToWindowBounds(
|
||||||
gfx::Rect dpi_bounds = display::win::ScreenWin::DIPToScreenRect(hwnd, bounds);
|
gfx::Rect dpi_bounds = display::win::ScreenWin::DIPToScreenRect(hwnd, bounds);
|
||||||
window_bounds = display::win::ScreenWin::ScreenToDIPRect(
|
window_bounds = display::win::ScreenWin::ScreenToDIPRect(
|
||||||
hwnd,
|
hwnd,
|
||||||
window_->non_client_view()->GetWindowBoundsForClientBounds(dpi_bounds));
|
widget()->non_client_view()->GetWindowBoundsForClientBounds(dpi_bounds));
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (menu_bar_ && menu_bar_visible_) {
|
if (menu_bar_ && menu_bar_visible_) {
|
||||||
|
@ -1161,16 +1156,15 @@ void NativeWindowViews::SetIcon(HICON window_icon, HICON app_icon) {
|
||||||
}
|
}
|
||||||
#elif defined(USE_X11)
|
#elif defined(USE_X11)
|
||||||
void NativeWindowViews::SetIcon(const gfx::ImageSkia& icon) {
|
void NativeWindowViews::SetIcon(const gfx::ImageSkia& icon) {
|
||||||
views::DesktopWindowTreeHostX11* tree_host =
|
auto* tree_host = static_cast<views::DesktopWindowTreeHost*>(
|
||||||
views::DesktopWindowTreeHostX11::GetHostForXID(GetAcceleratedWidget());
|
views::DesktopWindowTreeHostX11::GetHostForXID(GetAcceleratedWidget()));
|
||||||
static_cast<views::DesktopWindowTreeHost*>(tree_host)->SetWindowIcons(icon,
|
tree_host->SetWindowIcons(icon, icon);
|
||||||
icon);
|
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void NativeWindowViews::OnWidgetActivationChanged(views::Widget* widget,
|
void NativeWindowViews::OnWidgetActivationChanged(views::Widget* changed_widget,
|
||||||
bool active) {
|
bool active) {
|
||||||
if (widget != window_.get())
|
if (changed_widget != widget())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Post the notification to next tick.
|
// Post the notification to next tick.
|
||||||
|
@ -1187,9 +1181,9 @@ void NativeWindowViews::OnWidgetActivationChanged(views::Widget* widget,
|
||||||
menu_bar_alt_pressed_ = false;
|
menu_bar_alt_pressed_ = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void NativeWindowViews::OnWidgetBoundsChanged(views::Widget* widget,
|
void NativeWindowViews::OnWidgetBoundsChanged(views::Widget* changed_widget,
|
||||||
const gfx::Rect& bounds) {
|
const gfx::Rect& bounds) {
|
||||||
if (widget != window_.get())
|
if (changed_widget != widget())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
// Note: We intentionally use `GetBounds()` instead of `bounds` to properly
|
// Note: We intentionally use `GetBounds()` instead of `bounds` to properly
|
||||||
|
@ -1222,8 +1216,7 @@ void NativeWindowViews::OnWidgetBoundsChanged(views::Widget* widget,
|
||||||
|
|
||||||
void NativeWindowViews::DeleteDelegate() {
|
void NativeWindowViews::DeleteDelegate() {
|
||||||
if (is_modal() && NativeWindow::parent()) {
|
if (is_modal() && NativeWindow::parent()) {
|
||||||
NativeWindowViews* parent =
|
auto* parent = NativeWindow::parent();
|
||||||
static_cast<NativeWindowViews*>(NativeWindow::parent());
|
|
||||||
// Enable parent window after current window gets closed.
|
// Enable parent window after current window gets closed.
|
||||||
parent->SetEnabled(true);
|
parent->SetEnabled(true);
|
||||||
// Focus on parent window.
|
// Focus on parent window.
|
||||||
|
@ -1261,14 +1254,6 @@ bool NativeWindowViews::ShouldHandleSystemCommands() const {
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
views::Widget* NativeWindowViews::GetWidget() {
|
|
||||||
return window_.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
const views::Widget* NativeWindowViews::GetWidget() const {
|
|
||||||
return window_.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
views::View* NativeWindowViews::GetContentsView() {
|
views::View* NativeWindowViews::GetContentsView() {
|
||||||
return this;
|
return this;
|
||||||
}
|
}
|
||||||
|
@ -1284,7 +1269,7 @@ bool NativeWindowViews::ShouldDescendIntoChildForEventHandling(
|
||||||
// And the events on border for dragging resizable frameless window.
|
// And the events on border for dragging resizable frameless window.
|
||||||
if (!has_frame() && CanResize()) {
|
if (!has_frame() && CanResize()) {
|
||||||
FramelessView* frame =
|
FramelessView* frame =
|
||||||
static_cast<FramelessView*>(window_->non_client_view()->frame_view());
|
static_cast<FramelessView*>(widget()->non_client_view()->frame_view());
|
||||||
return frame->ResizingBorderHitTest(location) == HTNOWHERE;
|
return frame->ResizingBorderHitTest(location) == HTNOWHERE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -12,7 +12,6 @@
|
||||||
#include <vector>
|
#include <vector>
|
||||||
|
|
||||||
#include "atom/browser/ui/accelerator_util.h"
|
#include "atom/browser/ui/accelerator_util.h"
|
||||||
#include "ui/views/widget/widget_delegate.h"
|
|
||||||
#include "ui/views/widget/widget_observer.h"
|
#include "ui/views/widget/widget_observer.h"
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
|
@ -41,7 +40,7 @@ class NativeWindowViews : public NativeWindow,
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
public MessageHandlerDelegate,
|
public MessageHandlerDelegate,
|
||||||
#endif
|
#endif
|
||||||
public views::WidgetDelegateView,
|
public views::View,
|
||||||
public views::WidgetObserver {
|
public views::WidgetObserver {
|
||||||
public:
|
public:
|
||||||
NativeWindowViews(const mate::Dictionary& options, NativeWindow* parent);
|
NativeWindowViews(const mate::Dictionary& options, NativeWindow* parent);
|
||||||
|
@ -139,7 +138,6 @@ class NativeWindowViews : public NativeWindow,
|
||||||
void SetIcon(const gfx::ImageSkia& icon);
|
void SetIcon(const gfx::ImageSkia& icon);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
views::Widget* widget() const { return window_.get(); }
|
|
||||||
views::View* content_view() const { return content_view_; }
|
views::View* content_view() const { return content_view_; }
|
||||||
SkRegion* draggable_region() const { return draggable_region_.get(); }
|
SkRegion* draggable_region() const { return draggable_region_.get(); }
|
||||||
|
|
||||||
|
@ -161,8 +159,6 @@ class NativeWindowViews : public NativeWindow,
|
||||||
bool CanMinimize() const override;
|
bool CanMinimize() const override;
|
||||||
base::string16 GetWindowTitle() const override;
|
base::string16 GetWindowTitle() const override;
|
||||||
bool ShouldHandleSystemCommands() const override;
|
bool ShouldHandleSystemCommands() const override;
|
||||||
views::Widget* GetWidget() override;
|
|
||||||
const views::Widget* GetWidget() const override;
|
|
||||||
views::View* GetContentsView() override;
|
views::View* GetContentsView() override;
|
||||||
bool ShouldDescendIntoChildForEventHandling(
|
bool ShouldDescendIntoChildForEventHandling(
|
||||||
gfx::NativeView child,
|
gfx::NativeView child,
|
||||||
|
@ -211,7 +207,6 @@ class NativeWindowViews : public NativeWindow,
|
||||||
// Returns the restore state for the window.
|
// Returns the restore state for the window.
|
||||||
ui::WindowShowState GetRestoredState();
|
ui::WindowShowState GetRestoredState();
|
||||||
|
|
||||||
std::unique_ptr<views::Widget> window_;
|
|
||||||
views::View* content_view_; // Weak ref.
|
views::View* content_view_; // Weak ref.
|
||||||
views::View* focused_view_; // The view should be focused by default.
|
views::View* focused_view_; // The view should be focused by default.
|
||||||
|
|
||||||
|
@ -220,6 +215,12 @@ class NativeWindowViews : public NativeWindow,
|
||||||
bool menu_bar_visible_;
|
bool menu_bar_visible_;
|
||||||
bool menu_bar_alt_pressed_;
|
bool menu_bar_alt_pressed_;
|
||||||
|
|
||||||
|
// The "resizable" flag on Linux is implemented by setting size constraints,
|
||||||
|
// we need to make sure size constraints are restored when window becomes
|
||||||
|
// resizable again. This is also used on Windows, to keep taskbar resize
|
||||||
|
// events from resizing the window.
|
||||||
|
extensions::SizeConstraints old_size_constraints_;
|
||||||
|
|
||||||
#if defined(USE_X11)
|
#if defined(USE_X11)
|
||||||
std::unique_ptr<GlobalMenuBarX11> global_menu_bar_;
|
std::unique_ptr<GlobalMenuBarX11> global_menu_bar_;
|
||||||
|
|
||||||
|
@ -229,13 +230,7 @@ class NativeWindowViews : public NativeWindow,
|
||||||
// To disable the mouse events.
|
// To disable the mouse events.
|
||||||
std::unique_ptr<EventDisabler> event_disabler_;
|
std::unique_ptr<EventDisabler> event_disabler_;
|
||||||
#endif
|
#endif
|
||||||
#if defined(OS_WIN) || defined(USE_X11)
|
|
||||||
// The "resizable" flag on Linux is implemented by setting size constraints,
|
|
||||||
// we need to make sure size constraints are restored when window becomes
|
|
||||||
// resizable again. This is also used on Windows, to keep taskbar resize
|
|
||||||
// events from resizing the window.
|
|
||||||
extensions::SizeConstraints old_size_constraints_;
|
|
||||||
#endif
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
// Weak ref.
|
// Weak ref.
|
||||||
AtomDesktopWindowTreeHostWin* atom_desktop_window_tree_host_win_;
|
AtomDesktopWindowTreeHostWin* atom_desktop_window_tree_host_win_;
|
||||||
|
|
Loading…
Reference in a new issue