OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 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 "SkBenchmark.h" |
9 #include "SkCanvas.h" | 9 #include "SkCanvas.h" |
10 #include "SkPaint.h" | 10 #include "SkPaint.h" |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
43 } else { | 43 } else { |
44 fName.printf("morph_%d_%s", SkScalarRound(rad), name); | 44 fName.printf("morph_%d_%s", SkScalarRound(rad), name); |
45 } | 45 } |
46 } | 46 } |
47 | 47 |
48 protected: | 48 protected: |
49 virtual const char* onGetName() { | 49 virtual const char* onGetName() { |
50 return fName.c_str(); | 50 return fName.c_str(); |
51 } | 51 } |
52 | 52 |
53 virtual void onDraw(SkCanvas* canvas) { | 53 virtual void onDraw(const int loops, SkCanvas* canvas) { |
54 SkPaint paint; | 54 SkPaint paint; |
55 this->setupPaint(&paint); | 55 this->setupPaint(&paint); |
56 | 56 |
57 paint.setAntiAlias(true); | 57 paint.setAntiAlias(true); |
58 | 58 |
59 SkRandom rand; | 59 SkRandom rand; |
60 for (int i = 0; i < this->getLoops(); i++) { | 60 for (int i = 0; i < loops; i++) { |
61 SkRect r = SkRect::MakeWH(rand.nextUScalar1() * 400, | 61 SkRect r = SkRect::MakeWH(rand.nextUScalar1() * 400, |
62 rand.nextUScalar1() * 400); | 62 rand.nextUScalar1() * 400); |
63 r.offset(fRadius, fRadius); | 63 r.offset(fRadius, fRadius); |
64 | 64 |
65 if (fRadius > 0) { | 65 if (fRadius > 0) { |
66 SkMorphologyImageFilter* mf = NULL; | 66 SkMorphologyImageFilter* mf = NULL; |
67 switch (fStyle) { | 67 switch (fStyle) { |
68 case kDilate_MT: | 68 case kDilate_MT: |
69 mf = new SkDilateImageFilter(SkScalarFloorToInt(fRadius), | 69 mf = new SkDilateImageFilter(SkScalarFloorToInt(fRadius), |
70 SkScalarFloorToInt(fRadius)); | 70 SkScalarFloorToInt(fRadius)); |
(...skipping 20 matching lines...) Expand all Loading... |
91 DEF_BENCH( return new MorphologyBench(SMALL, kDilate_MT); ) | 91 DEF_BENCH( return new MorphologyBench(SMALL, kDilate_MT); ) |
92 | 92 |
93 DEF_BENCH( return new MorphologyBench(BIG, kErode_MT); ) | 93 DEF_BENCH( return new MorphologyBench(BIG, kErode_MT); ) |
94 DEF_BENCH( return new MorphologyBench(BIG, kDilate_MT); ) | 94 DEF_BENCH( return new MorphologyBench(BIG, kDilate_MT); ) |
95 | 95 |
96 DEF_BENCH( return new MorphologyBench(REAL, kErode_MT); ) | 96 DEF_BENCH( return new MorphologyBench(REAL, kErode_MT); ) |
97 DEF_BENCH( return new MorphologyBench(REAL, kDilate_MT); ) | 97 DEF_BENCH( return new MorphologyBench(REAL, kDilate_MT); ) |
98 | 98 |
99 DEF_BENCH( return new MorphologyBench(0, kErode_MT); ) | 99 DEF_BENCH( return new MorphologyBench(0, kErode_MT); ) |
100 #endif | 100 #endif |
OLD | NEW |