OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 | 7 |
8 #include "SkBenchmark.h" | 8 #include "Benchmark.h" |
| 9 #include "SkBlurMask.h" |
9 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
10 #include "SkPaint.h" | 11 #include "SkPaint.h" |
11 #include "SkRandom.h" | 12 #include "SkRandom.h" |
12 #include "SkShader.h" | 13 #include "SkShader.h" |
13 #include "SkString.h" | 14 #include "SkString.h" |
14 #include "SkBlurMask.h" | |
15 | 15 |
16 #define SMALL SkIntToScalar(2) | 16 #define SMALL SkIntToScalar(2) |
17 #define REAL 1.5f | 17 #define REAL 1.5f |
18 static const SkScalar kMedium = SkIntToScalar(5); | 18 static const SkScalar kMedium = SkIntToScalar(5); |
19 #define BIG SkIntToScalar(10) | 19 #define BIG SkIntToScalar(10) |
20 static const SkScalar kMedBig = SkIntToScalar(20); | 20 static const SkScalar kMedBig = SkIntToScalar(20); |
21 #define REALBIG 30.5f | 21 #define REALBIG 30.5f |
22 | 22 |
23 class BlurRectBench: public SkBenchmark { | 23 class BlurRectBench: public Benchmark { |
24 int fLoopCount; | 24 int fLoopCount; |
25 SkScalar fRadius; | 25 SkScalar fRadius; |
26 SkString fName; | 26 SkString fName; |
27 | 27 |
28 public: | 28 public: |
29 BlurRectBench(SkScalar rad) { | 29 BlurRectBench(SkScalar rad) { |
30 fRadius = rad; | 30 fRadius = rad; |
31 | 31 |
32 if (fRadius > SkIntToScalar(25)) { | 32 if (fRadius > SkIntToScalar(25)) { |
33 fLoopCount = 100; | 33 fLoopCount = 100; |
(...skipping 29 matching lines...) Expand all Loading... |
63 preBenchSetup(r); | 63 preBenchSetup(r); |
64 | 64 |
65 for (int i = 0; i < loops; i++) { | 65 for (int i = 0; i < loops; i++) { |
66 makeBlurryRect(r); | 66 makeBlurryRect(r); |
67 } | 67 } |
68 } | 68 } |
69 | 69 |
70 virtual void makeBlurryRect(const SkRect&) = 0; | 70 virtual void makeBlurryRect(const SkRect&) = 0; |
71 virtual void preBenchSetup(const SkRect&) {} | 71 virtual void preBenchSetup(const SkRect&) {} |
72 private: | 72 private: |
73 typedef SkBenchmark INHERITED; | 73 typedef Benchmark INHERITED; |
74 }; | 74 }; |
75 | 75 |
76 | 76 |
77 class BlurRectDirectBench: public BlurRectBench { | 77 class BlurRectDirectBench: public BlurRectBench { |
78 public: | 78 public: |
79 BlurRectDirectBench(SkScalar rad) : INHERITED(rad) { | 79 BlurRectDirectBench(SkScalar rad) : INHERITED(rad) { |
80 SkString name; | 80 SkString name; |
81 | 81 |
82 if (SkScalarFraction(rad) != 0) { | 82 if (SkScalarFraction(rad) != 0) { |
83 name.printf("blurrect_direct_%.2f", SkScalarToFloat(rad)); | 83 name.printf("blurrect_direct_%.2f", SkScalarToFloat(rad)); |
(...skipping 135 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
219 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(12));) | 219 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(12));) |
220 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(13));) | 220 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(13));) |
221 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(14));) | 221 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(14));) |
222 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(15));) | 222 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(15));) |
223 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(16));) | 223 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(16));) |
224 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(17));) | 224 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(17));) |
225 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(18));) | 225 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(18));) |
226 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(19));) | 226 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(19));) |
227 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(20));) | 227 DEF_BENCH(return new BlurRectGaussianBench(SkIntToScalar(20));) |
228 #endif | 228 #endif |
OLD | NEW |