Reorgnize how attributes work

This commit is contained in:
Cheng Zhao 2016-01-23 02:23:18 -08:00
parent ae7e96f181
commit d704b3f7ba
5 changed files with 55 additions and 78 deletions

View file

@ -116,23 +116,15 @@ void NativeWindow::InitFromOptions(const mate::Dictionary& options) {
SetSizeConstraints(size_constraints); SetSizeConstraints(size_constraints);
} }
#if defined(OS_WIN) || defined(USE_X11) #if defined(OS_WIN) || defined(USE_X11)
bool resizable;
if (options.Get(options::kResizable, &resizable)) {
SetResizable(resizable);
}
bool minimizable;
if (options.Get(options::kMinimizable, &minimizable)) {
SetMinimizable(minimizable);
}
bool closable; bool closable;
if (options.Get(options::kClosable, &closable)) { if (options.Get(options::kClosable, &closable)) {
SetClosable(closable); SetClosable(closable);
} }
bool maximizable;
if (options.Get(options::kMaximizable, &maximizable)) {
SetMaximizable(maximizable);
}
#endif #endif
bool movable;
if (options.Get(options::kMovable, &movable) && movable) {
SetMovable(movable);
}
bool top; bool top;
if (options.Get(options::kAlwaysOnTop, &top) && top) { if (options.Get(options::kAlwaysOnTop, &top) && top) {
SetAlwaysOnTop(true); SetAlwaysOnTop(true);

View file

@ -394,12 +394,12 @@ NativeWindowMac::NativeWindowMac(
useStandardWindow = false; useStandardWindow = false;
} }
NSUInteger styleMask = NSTitledWindowMask | NSClosableWindowMask; NSUInteger styleMask = NSTitledWindowMask;
if (minimizable) { if (minimizable) {
styleMask |= NSMiniaturizableWindowMask; styleMask |= NSMiniaturizableWindowMask;
} }
if (!closable) { if (closable) {
styleMask &= ~NSClosableWindowMask; styleMask |= NSClosableWindowMask;
} }
if (!useStandardWindow || transparent() || !has_frame()) { if (!useStandardWindow || transparent() || !has_frame()) {
styleMask |= NSTexturedBackgroundWindowMask; styleMask |= NSTexturedBackgroundWindowMask;
@ -472,11 +472,6 @@ NativeWindowMac::NativeWindowMac(
set_force_using_draggable_region(true); set_force_using_draggable_region(true);
} }
bool movable;
if (options.Get(options::kMovable, &movable)) {
[window_ setMovable:movable];
}
// On OS X the initial window size doesn't include window frame. // On OS X the initial window size doesn't include window frame.
bool use_content_size = false; bool use_content_size = false;
options.Get(options::kUseContentSize, &use_content_size); options.Get(options::kUseContentSize, &use_content_size);

View file

@ -59,6 +59,17 @@ const int kMenuBarHeight = 20;
const int kMenuBarHeight = 25; const int kMenuBarHeight = 25;
#endif #endif
#if defined(OS_WIN)
void FlipWindowStyle(HWND handle, bool on, DWORD flag) {
DWORD style = ::GetWindowLong(handle, GWL_STYLE);
if (on)
style |= flag;
else
style &= ~flag;
::SetWindowLong(handle, GWL_STYLE, style);
}
#endif
bool IsAltKey(const content::NativeWebKeyboardEvent& event) { bool IsAltKey(const content::NativeWebKeyboardEvent& event) {
return event.windowsKeyCode == ui::VKEY_MENU; return event.windowsKeyCode == ui::VKEY_MENU;
} }
@ -103,9 +114,9 @@ NativeWindowViews::NativeWindowViews(
menu_bar_alt_pressed_(false), menu_bar_alt_pressed_(false),
keyboard_event_handler_(new views::UnhandledKeyboardEventHandler), keyboard_event_handler_(new views::UnhandledKeyboardEventHandler),
use_content_size_(false), use_content_size_(false),
movable_(true),
resizable_(true), resizable_(true),
maximizable_(true), maximizable_(true),
movable_(true),
minimizable_(true) { minimizable_(true) {
options.Get(options::kTitle, &title_); options.Get(options::kTitle, &title_);
options.Get(options::kAutoHideMenuBar, &menu_bar_autohide_); options.Get(options::kAutoHideMenuBar, &menu_bar_autohide_);
@ -114,7 +125,6 @@ NativeWindowViews::NativeWindowViews(
// On Windows we rely on the CanResize() to indicate whether window can be // On Windows we rely on the CanResize() to indicate whether window can be
// resized, and it should be set before window is created. // resized, and it should be set before window is created.
options.Get(options::kResizable, &resizable_); options.Get(options::kResizable, &resizable_);
options.Get(options::kMovable, &movable_);
options.Get(options::kMinimizable, &minimizable_); options.Get(options::kMinimizable, &minimizable_);
options.Get(options::kMaximizable, &maximizable_); options.Get(options::kMaximizable, &maximizable_);
#endif #endif
@ -216,25 +226,29 @@ NativeWindowViews::NativeWindowViews(
last_window_state_ = ui::SHOW_STATE_FULLSCREEN; last_window_state_ = ui::SHOW_STATE_FULLSCREEN;
else else
last_window_state_ = ui::SHOW_STATE_NORMAL; last_window_state_ = ui::SHOW_STATE_NORMAL;
last_normal_size_ = gfx::Size(widget_size_); last_normal_size_ = gfx::Size(widget_size_);
DWORD style = ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE); if (!has_frame()) {
style |= WS_THICKFRAME | WS_CAPTION | WS_MINIMIZEBOX; // Set Window style so that we get a minimize and maximize animation when
// frameless.
DWORD frame_style = WS_CAPTION;
if (resizable_)
frame_style |= WS_THICKFRAME;
if (minimizable_)
frame_style |= WS_MINIMIZEBOX;
if (maximizable_)
frame_style |= WS_MAXIMIZEBOX;
// We should not show a frame for transparent window.
if (transparent())
frame_style &= ~(WS_THICKFRAME | WS_CAPTION);
::SetWindowLong(GetAcceleratedWidget(), GWL_STYLE, frame_style);
}
if (transparent()) { if (transparent()) {
DWORD ex_style = ::GetWindowLong(GetAcceleratedWidget(), GWL_EXSTYLE); // Transparent window on Windows has to have WS_EX_COMPOSITED style.
LONG ex_style = ::GetWindowLong(GetAcceleratedWidget(), GWL_EXSTYLE);
ex_style |= WS_EX_COMPOSITED; ex_style |= WS_EX_COMPOSITED;
::SetWindowLong(GetAcceleratedWidget(), GWL_EXSTYLE, ex_style); ::SetWindowLong(GetAcceleratedWidget(), GWL_EXSTYLE, ex_style);
if (!has_frame()) {
// We should not show a frame for transparent window.
style &= ~(WS_THICKFRAME | WS_CAPTION);
}
}
if (!transparent() || !has_frame()) {
::SetWindowLong(GetAcceleratedWidget(), GWL_STYLE, style);
} }
#endif #endif
@ -405,18 +419,8 @@ void NativeWindowViews::SetContentSizeConstraints(
void NativeWindowViews::SetResizable(bool resizable) { void NativeWindowViews::SetResizable(bool resizable) {
#if defined(OS_WIN) #if defined(OS_WIN)
// WS_MAXIMIZEBOX => Maximize button if (!transparent())
// WS_MINIMIZEBOX => Minimize button FlipWindowStyle(GetAcceleratedWidget(), resizable, WS_THICKFRAME);
// WS_THICKFRAME => Resize handle
if (!transparent()) {
DWORD style = ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE);
if (resizable) {
style |= WS_THICKFRAME;
} else {
style &= ~(WS_THICKFRAME);
}
::SetWindowLong(GetAcceleratedWidget(), GWL_STYLE, style);
}
#elif defined(USE_X11) #elif 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
@ -437,7 +441,7 @@ void NativeWindowViews::SetResizable(bool resizable) {
} }
bool NativeWindowViews::IsResizable() { bool NativeWindowViews::IsResizable() {
return resizable_; return CanResize();
} }
void NativeWindowViews::SetMovable(bool movable) { void NativeWindowViews::SetMovable(bool movable) {
@ -447,51 +451,38 @@ void NativeWindowViews::SetMovable(bool movable) {
bool NativeWindowViews::IsMovable() { bool NativeWindowViews::IsMovable() {
#if defined(OS_WIN) #if defined(OS_WIN)
return movable_; return movable_;
#elif defined(USE_X11) #else
return true; return true; // Not implemented on Linux.
#endif #endif
} }
void NativeWindowViews::SetMinimizable(bool minimizable) { void NativeWindowViews::SetMinimizable(bool minimizable) {
#if defined(OS_WIN) #if defined(OS_WIN)
if (!transparent()) { FlipWindowStyle(GetAcceleratedWidget(), minimizable, WS_MINIMIZEBOX);
DWORD style = ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE);
if (minimizable)
style |= WS_MINIMIZEBOX;
else
style &= (~WS_MINIMIZEBOX);
::SetWindowLong(GetAcceleratedWidget(), GWL_STYLE, style);
}
#endif #endif
minimizable_ = minimizable; minimizable_ = minimizable;
} }
bool NativeWindowViews::IsMinimizable() { bool NativeWindowViews::IsMinimizable() {
#if defined(OS_WIN) #if defined(OS_WIN)
return ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE) & WS_MINIMIZEBOX; return CanMinimize();
#elif defined(USE_X11) #else
return true; return true; // CanMinimize() Not implemented on Linux.
#endif #endif
} }
void NativeWindowViews::SetMaximizable(bool maximizable) { void NativeWindowViews::SetMaximizable(bool maximizable) {
#if defined(OS_WIN) #if defined(OS_WIN)
DWORD style = ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE); FlipWindowStyle(GetAcceleratedWidget(), maximizable, WS_MAXIMIZEBOX);
if (maximizable) {
style |= WS_MAXIMIZEBOX;
} else {
style &= (~WS_MAXIMIZEBOX);
}
::SetWindowLong(GetAcceleratedWidget(), GWL_STYLE, style);
#endif #endif
maximizable_ = maximizable;
} }
bool NativeWindowViews::IsMaximizable() { bool NativeWindowViews::IsMaximizable() {
#if defined(OS_WIN) #if defined(OS_WIN)
return ::GetWindowLong(GetAcceleratedWidget(), GWL_STYLE) & WS_MAXIMIZEBOX; return CanMaximize();
#elif defined(USE_X11) #else
return true; return true; // CanMaximize() Not implemented on Linux.
#endif #endif
} }
@ -786,7 +777,7 @@ bool NativeWindowViews::CanResize() const {
} }
bool NativeWindowViews::CanMaximize() const { bool NativeWindowViews::CanMaximize() const {
return resizable_; return resizable_ && maximizable_;
} }
bool NativeWindowViews::CanMinimize() const { bool NativeWindowViews::CanMinimize() const {

View file

@ -206,9 +206,9 @@ class NativeWindowViews : public NativeWindow,
accelerator_util::AcceleratorTable accelerator_table_; accelerator_util::AcceleratorTable accelerator_table_;
bool use_content_size_; bool use_content_size_;
bool movable_;
bool resizable_; bool resizable_;
bool maximizable_; bool maximizable_;
bool movable_;
bool minimizable_; bool minimizable_;
std::string title_; std::string title_;
gfx::Size widget_size_; gfx::Size widget_size_;

View file

@ -96,9 +96,8 @@ bool NativeWindowViews::PreHandleMSG(
return false; return false;
case WM_MOVING: { case WM_MOVING: {
if (!movable_) { if (!movable_)
::GetWindowRect(GetAcceleratedWidget(), (LPRECT)l_param); ::GetWindowRect(GetAcceleratedWidget(), (LPRECT)l_param);
}
return false; return false;
} }