diff options
author | glen@chromium.org <glen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-09 19:49:32 +0000 |
---|---|---|
committer | glen@chromium.org <glen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2010-04-09 19:49:32 +0000 |
commit | 5d870f2ee49dfb4fb11b4289048547a0bd3c23e5 (patch) | |
tree | b46a4c912b7f3361d0aa141790635e9689373420 /views/window | |
parent | 357cf11306e0f7d56fbb808076276fa9519a4967 (diff) | |
download | chromium_src-5d870f2ee49dfb4fb11b4289048547a0bd3c23e5.zip chromium_src-5d870f2ee49dfb4fb11b4289048547a0bd3c23e5.tar.gz chromium_src-5d870f2ee49dfb4fb11b4289048547a0bd3c23e5.tar.bz2 |
Make the bottom edges of the opaque frame rounded.
BUG=40024
TEST=On a non-AeroGlass Windows machine, verify that the bottom edges of the Window are rounded.
Review URL: http://codereview.chromium.org/1560021
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@44115 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'views/window')
-rw-r--r-- | views/window/custom_frame_view.cc | 20 | ||||
-rw-r--r-- | views/window/window_shape.cc | 46 | ||||
-rw-r--r-- | views/window/window_shape.h | 21 |
3 files changed, 69 insertions, 18 deletions
diff --git a/views/window/custom_frame_view.cc b/views/window/custom_frame_view.cc index 1598bdd..8bdb3c4 100644 --- a/views/window/custom_frame_view.cc +++ b/views/window/custom_frame_view.cc @@ -17,6 +17,7 @@ #include "grit/app_resources.h" #include "grit/app_strings.h" #include "views/window/client_view.h" +#include "views/window/window_shape.h" #if defined(OS_LINUX) #include "views/window/hit_test.h" #endif @@ -185,27 +186,10 @@ int CustomFrameView::NonClientHitTest(const gfx::Point& point) { void CustomFrameView::GetWindowMask(const gfx::Size& size, gfx::Path* window_mask) { DCHECK(window_mask); - if (frame_->IsMaximized()) return; - // Redefine the window visible region for the new size. - window_mask->moveTo(0, 3); - window_mask->lineTo(1, 2); - window_mask->lineTo(1, 1); - window_mask->lineTo(2, 1); - window_mask->lineTo(3, 0); - - window_mask->lineTo(SkIntToScalar(size.width() - 3), 0); - window_mask->lineTo(SkIntToScalar(size.width() - 2), 1); - window_mask->lineTo(SkIntToScalar(size.width() - 1), 1); - window_mask->lineTo(SkIntToScalar(size.width() - 1), 2); - window_mask->lineTo(SkIntToScalar(size.width()), 3); - - window_mask->lineTo(SkIntToScalar(size.width()), - SkIntToScalar(size.height())); - window_mask->lineTo(0, SkIntToScalar(size.height())); - window_mask->close(); + views::GetDefaultWindowMask(size, window_mask); } void CustomFrameView::EnableClose(bool enable) { diff --git a/views/window/window_shape.cc b/views/window/window_shape.cc new file mode 100644 index 0000000..692602d --- /dev/null +++ b/views/window/window_shape.cc @@ -0,0 +1,46 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#include "views/window/window_shape.h" + +#include "gfx/path.h" +#include "gfx/size.h" + +namespace views { + +void GetDefaultWindowMask(const gfx::Size &size, gfx::Path *window_mask) { + // Redefine the window visible region for the new size. + window_mask->moveTo(0, 3); + window_mask->lineTo(1, 2); + window_mask->lineTo(1, 1); + window_mask->lineTo(2, 1); + window_mask->lineTo(3, 0); + + window_mask->lineTo(SkIntToScalar(size.width() - 3), 0); + window_mask->lineTo(SkIntToScalar(size.width() - 2), 1); + window_mask->lineTo(SkIntToScalar(size.width() - 1), 1); + window_mask->lineTo(SkIntToScalar(size.width() - 1), 2); + window_mask->lineTo(SkIntToScalar(size.width()), 3); + + window_mask->lineTo(SkIntToScalar(size.width()), + SkIntToScalar(size.height() - 3)); + window_mask->lineTo(SkIntToScalar(size.width() - 1), + SkIntToScalar(size.height() - 3)); + window_mask->lineTo(SkIntToScalar(size.width() - 1), + SkIntToScalar(size.height() - 1)); + window_mask->lineTo(SkIntToScalar(size.width() - 3), + SkIntToScalar(size.height() - 2)); + window_mask->lineTo(SkIntToScalar(size.width() - 3), + SkIntToScalar(size.height())); + + window_mask->lineTo(3, SkIntToScalar(size.height())); + window_mask->lineTo(2, SkIntToScalar(size.height() - 2)); + window_mask->lineTo(1, SkIntToScalar(size.height() - 1)); + window_mask->lineTo(1, SkIntToScalar(size.height() - 3)); + window_mask->lineTo(0, SkIntToScalar(size.height() - 3)); + + window_mask->close(); +} + +} // namespace views
\ No newline at end of file diff --git a/views/window/window_shape.h b/views/window/window_shape.h new file mode 100644 index 0000000..5b47415 --- /dev/null +++ b/views/window/window_shape.h @@ -0,0 +1,21 @@ +// Copyright (c) 2010 The Chromium Authors. All rights reserved. +// Use of this source code is governed by a BSD-style license that can be +// found in the LICENSE file. + +#ifndef VIEWS_WINDOW_WINDOW_SHAPE_H_ +#define VIEWS_WINDOW_WINDOW_SHAPE_H_ + +namespace gfx { +class Size; +class Path; +} + +namespace views { + +// Sets the window mask to a style that most likely matches +// app/resources/window_* +void GetDefaultWindowMask(const gfx::Size& size, gfx::Path* window_mask); + +} // namespace views + +#endif // #ifndef VIEWS_WINDOW_WINDOW_SHAPE_H_ |