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

Unified Diff: bench/BlurRectsBench.cpp

Issue 787913002: Add bench to measure blur rects performance (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 6 years 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 | « no previous file | gyp/bench.gypi » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: bench/BlurRectsBench.cpp
diff --git a/bench/BlurRectsBench.cpp b/bench/BlurRectsBench.cpp
new file mode 100644
index 0000000000000000000000000000000000000000..7b98e00c9255b8dbe84947e23a9b7fea0cf84723
--- /dev/null
+++ b/bench/BlurRectsBench.cpp
@@ -0,0 +1,80 @@
+/*
+* Copyright 2014 Google Inc.
+*
+* Use of this source code is governed by a BSD-style license that can be
+* found in the LICENSE file.
+*/
+
+#include "Benchmark.h"
+#include "SkBlurMaskFilter.h"
+#include "SkCanvas.h"
+#include "SkPaint.h"
+#include "SkPath.h"
+#include "SkRect.h"
+#include "SkString.h"
+
+class BlurRectsBench : public Benchmark {
+public:
+ BlurRectsBench(SkRect outer, SkRect inner, SkScalar radius) {
+ fRadius = radius;
+ fOuter = outer;
+ fInner = inner;
+ }
+
+ virtual const char* onGetName() SK_OVERRIDE {
+ return fName.c_str();
+ }
+
+ void setName(const SkString& name) {
+ fName = name;
+ }
+
+ virtual void onDraw(const int loops, SkCanvas* canvas) SK_OVERRIDE {
+ SkPaint paint;
+ paint.setMaskFilter(SkBlurMaskFilter::Create(kNormal_SkBlurStyle, fRadius))->unref();
+
+ SkPath path;
+ path.addRect(fOuter, SkPath::kCW_Direction);
+ path.addRect(fInner, SkPath::kCW_Direction);
+
+ for (int i = 0; i < loops; i++) {
+ canvas->drawPath(path, paint);
+ }
+ }
+
+private:
+ SkString fName;
+ SkRect fOuter;
+ SkRect fInner;
+ SkScalar fRadius;
+
+ typedef Benchmark INHERITED;
+};
+
+class BlurRectsNinePatchBench: public BlurRectsBench {
+public:
+ BlurRectsNinePatchBench(SkRect outer, SkRect inner, SkScalar radius)
+ : INHERITED(outer, inner, radius) {
+ this->setName(SkString("blurrectsninepatch"));
+ }
+private:
+ typedef BlurRectsBench INHERITED;
+};
+
+class BlurRectsNonNinePatchBench: public BlurRectsBench {
+public:
+ BlurRectsNonNinePatchBench(SkRect outer, SkRect inner, SkScalar radius)
+ : INHERITED(outer, inner, radius) {
+ SkString name;
+ this->setName(SkString("blurrectsnonninepatch"));
+ }
+private:
+ typedef BlurRectsBench INHERITED;
+};
+
+DEF_BENCH(return new BlurRectsNinePatchBench(SkRect::MakeXYWH(10, 10, 100, 100),
+ SkRect::MakeXYWH(20, 20, 60, 60),
+ 2.3f);)
+DEF_BENCH(return new BlurRectsNonNinePatchBench(SkRect::MakeXYWH(10, 10, 100, 100),
+ SkRect::MakeXYWH(50, 50, 10, 10),
+ 4.3f);)
« no previous file with comments | « no previous file | gyp/bench.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698