summaryrefslogtreecommitdiffstats
path: root/views/window
diff options
context:
space:
mode:
authorglen@chromium.org <glen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-04-09 19:49:32 +0000
committerglen@chromium.org <glen@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2010-04-09 19:49:32 +0000
commit5d870f2ee49dfb4fb11b4289048547a0bd3c23e5 (patch)
treeb46a4c912b7f3361d0aa141790635e9689373420 /views/window
parent357cf11306e0f7d56fbb808076276fa9519a4967 (diff)
downloadchromium_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.cc20
-rw-r--r--views/window/window_shape.cc46
-rw-r--r--views/window/window_shape.h21
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_