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

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: Border caching added 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
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..9185f6824f6f12cecd6f836facbf06a22cd6deea
--- /dev/null
+++ b/ui/views/shadow_border.cc
@@ -0,0 +1,59 @@
+// 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() {}
+
+void ShadowBorder::Paint(const views::View& view, gfx::Canvas* canvas) {
+ gfx::Rect bounds(view.size());
+
+ if (bounds != cache_bounds_ || !cached_border_.get()) {
+ cache_bounds_ = bounds;
+
+ // We cache the border since re-painting a shadow looper on every paint call
+ // may yield poor performance. So we draw the border on a separate canvas
+ // and cache the bitmap of the drawn border.
+ gfx::Canvas border_canvas(view.size(), canvas->scale_factor(), false);
+
+ 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);
+ bounds.Inset(gfx::Insets(blur_ / 2, blur_ / 2, blur_ / 2, blur_ / 2));
+ border_canvas.DrawRect(bounds, paint);
+
+ cached_border_.reset(new gfx::ImageSkia(border_canvas.ExtractImageRep()));
dewittj 2013/07/15 18:38:58 Does this cache an image the size of the contained
sidharthms 2013/07/15 23:16:37 Removed for now. I'll submit a separate cl to add
+ }
+ canvas->DrawImageInt(*cached_border_.get(), 0, 0);
+}
+
+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

Powered by Google App Engine
This is Rietveld 408576698