diff options
-rw-r--r-- | chrome/browser/views/frame/aero_glass_non_client_view.cc | 17 | ||||
-rw-r--r-- | chrome/browser/views/frame/opaque_non_client_view.cc | 2 |
2 files changed, 11 insertions, 8 deletions
diff --git a/chrome/browser/views/frame/aero_glass_non_client_view.cc b/chrome/browser/views/frame/aero_glass_non_client_view.cc index cf8ba83..b3036ed 100644 --- a/chrome/browser/views/frame/aero_glass_non_client_view.cc +++ b/chrome/browser/views/frame/aero_glass_non_client_view.cc @@ -143,6 +143,9 @@ gfx::Rect AeroGlassNonClientView::CalculateClientAreaBounds(int width, gfx::Size AeroGlassNonClientView::CalculateWindowSizeForClientSize( int width, int height) const { + if (!browser_view_->IsTabStripVisible()) + return gfx::Size(width, height); + int border_thickness = NonClientBorderThickness(); return gfx::Size(width + (2 * border_thickness), height + NonClientTopBorderHeight() + border_thickness); @@ -151,14 +154,14 @@ gfx::Size AeroGlassNonClientView::CalculateWindowSizeForClientSize( gfx::Point AeroGlassNonClientView::GetSystemMenuPoint() const { gfx::Point system_menu_point; if (browser_view_->IsBrowserTypeNormal()) { - // The maximized mode bit here is because in maximized mode the frame edge + // The X coordinate conditional is because in maximized mode the frame edge // and the client edge are both offscreen, whereas in the opaque frame // (where we don't do this trick) maximized windows have no client edge and // only the frame edge is offscreen. system_menu_point.SetPoint(NonClientBorderThickness() - - (frame_->IsMaximized() ? 0 : kClientEdgeThickness), + (browser_view_->CanCurrentlyResize() ? kClientEdgeThickness : 0), NonClientTopBorderHeight() + browser_view_->GetTabStripHeight() - - kClientEdgeThickness); + (browser_view_->IsFullscreen() ? 0 : kClientEdgeThickness)); } else { system_menu_point.SetPoint(0, -kFrameShadowThickness); } @@ -220,16 +223,16 @@ void AeroGlassNonClientView::ViewHierarchyChanged(bool is_add, // AeroGlassNonClientView, private: int AeroGlassNonClientView::FrameBorderThickness() const { - return GetSystemMetrics(SM_CXSIZEFRAME); + return browser_view_->IsFullscreen() ? 0 : GetSystemMetrics(SM_CXSIZEFRAME); } int AeroGlassNonClientView::NonClientBorderThickness() const { - return kNonClientBorderThickness; + return browser_view_->IsFullscreen() ? 0 : kNonClientBorderThickness; } int AeroGlassNonClientView::NonClientTopBorderHeight() const { - return FrameBorderThickness() + - (frame_->IsMaximized() ? 0 : kNonClientRestoredExtraThickness); + return FrameBorderThickness() + (browser_view_->CanCurrentlyResize() ? + kNonClientRestoredExtraThickness : 0); } void AeroGlassNonClientView::PaintDistributorLogo(ChromeCanvas* canvas) { diff --git a/chrome/browser/views/frame/opaque_non_client_view.cc b/chrome/browser/views/frame/opaque_non_client_view.cc index eeb1000..48d88db 100644 --- a/chrome/browser/views/frame/opaque_non_client_view.cc +++ b/chrome/browser/views/frame/opaque_non_client_view.cc @@ -472,7 +472,7 @@ gfx::Size OpaqueNonClientView::CalculateWindowSizeForClientSize( gfx::Point OpaqueNonClientView::GetSystemMenuPoint() const { gfx::Point system_menu_point(FrameBorderThickness(), NonClientTopBorderHeight() + browser_view_->GetTabStripHeight() - - kClientEdgeThickness); + (browser_view_->IsFullscreen() ? 0 : kClientEdgeThickness)); ConvertPointToScreen(this, &system_menu_point); return system_menu_point; } |