3 * Copyright 2011 Google Inc.
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
9 #include "SkBlurMask.h"
10 #include "SkBlurMaskFilter.h"
18 #define SMALL SkIntToScalar(2)
20 #define BIG SkIntToScalar(10)
21 #define REALBIG 100.5f
23 static const char* gStyleName[] = {
30 class BlurBench : public Benchmark {
37 BlurBench(SkScalar rad, SkBlurStyle bs, uint32_t flags = 0) {
41 const char* name = rad > 0 ? gStyleName[bs] : "none";
42 const char* quality = flags & SkBlurMaskFilter::kHighQuality_BlurFlag ? "high_quality"
44 if (SkScalarFraction(rad) != 0) {
45 fName.printf("blur_%.2f_%s_%s", SkScalarToFloat(rad), name, quality);
47 fName.printf("blur_%d_%s_%s", SkScalarRoundToInt(rad), name, quality);
52 virtual const char* onGetName() {
56 virtual void onDraw(const int loops, SkCanvas* canvas) {
58 this->setupPaint(&paint);
60 paint.setAntiAlias(true);
63 for (int i = 0; i < loops; i++) {
64 SkRect r = SkRect::MakeWH(rand.nextUScalar1() * 400,
65 rand.nextUScalar1() * 400);
66 r.offset(fRadius, fRadius);
69 SkMaskFilter* mf = SkBlurMaskFilter::Create(fStyle,
70 SkBlurMask::ConvertRadiusToSigma(fRadius),
72 paint.setMaskFilter(mf)->unref();
74 canvas->drawOval(r, paint);
79 typedef Benchmark INHERITED;
82 DEF_BENCH(return new BlurBench(MINI, kNormal_SkBlurStyle);)
83 DEF_BENCH(return new BlurBench(MINI, kSolid_SkBlurStyle);)
84 DEF_BENCH(return new BlurBench(MINI, kOuter_SkBlurStyle);)
85 DEF_BENCH(return new BlurBench(MINI, kInner_SkBlurStyle);)
87 DEF_BENCH(return new BlurBench(SMALL, kNormal_SkBlurStyle);)
88 DEF_BENCH(return new BlurBench(SMALL, kSolid_SkBlurStyle);)
89 DEF_BENCH(return new BlurBench(SMALL, kOuter_SkBlurStyle);)
90 DEF_BENCH(return new BlurBench(SMALL, kInner_SkBlurStyle);)
92 DEF_BENCH(return new BlurBench(BIG, kNormal_SkBlurStyle);)
93 DEF_BENCH(return new BlurBench(BIG, kSolid_SkBlurStyle);)
94 DEF_BENCH(return new BlurBench(BIG, kOuter_SkBlurStyle);)
95 DEF_BENCH(return new BlurBench(BIG, kInner_SkBlurStyle);)
97 DEF_BENCH(return new BlurBench(REALBIG, kNormal_SkBlurStyle);)
98 DEF_BENCH(return new BlurBench(REALBIG, kSolid_SkBlurStyle);)
99 DEF_BENCH(return new BlurBench(REALBIG, kOuter_SkBlurStyle);)
100 DEF_BENCH(return new BlurBench(REALBIG, kInner_SkBlurStyle);)
102 DEF_BENCH(return new BlurBench(REAL, kNormal_SkBlurStyle);)
103 DEF_BENCH(return new BlurBench(REAL, kSolid_SkBlurStyle);)
104 DEF_BENCH(return new BlurBench(REAL, kOuter_SkBlurStyle);)
105 DEF_BENCH(return new BlurBench(REAL, kInner_SkBlurStyle);)
107 DEF_BENCH(return new BlurBench(MINI, kNormal_SkBlurStyle, SkBlurMaskFilter::kHighQuality_BlurFlag);)
109 DEF_BENCH(return new BlurBench(SMALL, kNormal_SkBlurStyle, SkBlurMaskFilter::kHighQuality_BlurFlag);)
111 DEF_BENCH(return new BlurBench(BIG, kNormal_SkBlurStyle, SkBlurMaskFilter::kHighQuality_BlurFlag);)
113 DEF_BENCH(return new BlurBench(REALBIG, kNormal_SkBlurStyle, SkBlurMaskFilter::kHighQuality_BlurFlag);)
115 DEF_BENCH(return new BlurBench(REAL, kNormal_SkBlurStyle, SkBlurMaskFilter::kHighQuality_BlurFlag);)
117 DEF_BENCH(return new BlurBench(0, kNormal_SkBlurStyle);)