Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(183)

Unified Diff: ui/views/shadow_border.cc

Issue 18003003: Message center re-organized (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « ui/views/shadow_border.h ('k') | ui/views/views.gyp » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: ui/views/shadow_border.cc
diff --git a/ui/views/shadow_border.cc b/ui/views/shadow_border.cc
new file mode 100644
index 0000000000000000000000000000000000000000..f57a5c067b5ae95929fac8a7857d86913157f9c0
--- /dev/null
+++ b/ui/views/shadow_border.cc
@@ -0,0 +1,48 @@
+// Copyright (c) 2013 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 "ui/views/shadow_border.h"
+
+#include "ui/gfx/canvas.h"
+#include "ui/gfx/insets.h"
+#include "ui/gfx/shadow_value.h"
+#include "ui/gfx/skia_util.h"
+
+namespace views {
+
+ShadowBorder::ShadowBorder(int blur,
+ SkColor color,
+ int vertical_offset,
+ int horizontal_offset)
+ : views::Border(),
+ blur_(blur),
+ color_(color),
+ vertical_offset_(vertical_offset),
+ horizontal_offset_(horizontal_offset) {}
+
+ShadowBorder::~ShadowBorder() {}
+
+// TODO(sidharthms): Re-painting a shadow looper on every paint call may yield
+// poor performance. Ideally we should be caching the border to bitmaps.
+void ShadowBorder::Paint(const views::View& view, gfx::Canvas* canvas) {
+ SkPaint paint;
+ std::vector<gfx::ShadowValue> shadows;
+ shadows.push_back(gfx::ShadowValue(gfx::Point(), blur_, color_));
+ skia::RefPtr<SkDrawLooper> looper = gfx::CreateShadowDrawLooper(shadows);
+ paint.setLooper(looper.get());
+ paint.setColor(SK_ColorTRANSPARENT);
+ paint.setStrokeJoin(SkPaint::kRound_Join);
+ gfx::Rect bounds(view.size());
+ bounds.Inset(gfx::Insets(blur_ / 2, blur_ / 2, blur_ / 2, blur_ / 2));
+ canvas->DrawRect(bounds, paint);
+}
+
+gfx::Insets ShadowBorder::GetInsets() const {
+ return gfx::Insets(blur_ / 2 - vertical_offset_,
+ blur_ / 2 - horizontal_offset_,
+ blur_ / 2 + vertical_offset_,
+ blur_ / 2 + horizontal_offset_);
+}
+
+} // namespace views
« no previous file with comments | « ui/views/shadow_border.h ('k') | ui/views/views.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698