| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 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 "Benchmark.h" | 8 #include "Benchmark.h" |
| 9 #include "SkBitmap.h" | 9 #include "SkBitmap.h" |
| 10 #include "SkCanvas.h" | 10 #include "SkCanvas.h" |
| (...skipping 10 matching lines...) Expand all Loading... |
| 21 // the passes are collapsed in one. | 21 // the passes are collapsed in one. |
| 22 | 22 |
| 23 class BaseImageFilterCollapseBench : public Benchmark { | 23 class BaseImageFilterCollapseBench : public Benchmark { |
| 24 public: | 24 public: |
| 25 BaseImageFilterCollapseBench(): fImageFilter(nullptr) {} | 25 BaseImageFilterCollapseBench(): fImageFilter(nullptr) {} |
| 26 ~BaseImageFilterCollapseBench() { | 26 ~BaseImageFilterCollapseBench() { |
| 27 SkSafeUnref(fImageFilter); | 27 SkSafeUnref(fImageFilter); |
| 28 } | 28 } |
| 29 | 29 |
| 30 protected: | 30 protected: |
| 31 void doPreDraw(SkColorFilter* colorFilters[], int nFilters) { | 31 void doPreDraw(sk_sp<SkColorFilter> colorFilters[], int nFilters) { |
| 32 // Create a chain of ImageFilters from colorFilters | 32 // Create a chain of ImageFilters from colorFilters |
| 33 fImageFilter = nullptr; | 33 fImageFilter = nullptr; |
| 34 for(int i = nFilters; i --> 0;) { | 34 for(int i = nFilters; i --> 0;) { |
| 35 SkAutoTUnref<SkImageFilter> filter( | 35 SkAutoTUnref<SkImageFilter> filter( |
| 36 SkColorFilterImageFilter::Create(colorFilters[i], fImage
Filter, nullptr) | 36 SkColorFilterImageFilter::Create(colorFilters[i].get(), fIma
geFilter, nullptr) |
| 37 ); | 37 ); |
| 38 SkRefCnt_SafeAssign(fImageFilter, filter.get()); | 38 SkRefCnt_SafeAssign(fImageFilter, filter.get()); |
| 39 } | 39 } |
| 40 } | 40 } |
| 41 | 41 |
| 42 void onDraw(int loops, SkCanvas* canvas) override { | 42 void onDraw(int loops, SkCanvas* canvas) override { |
| 43 makeBitmap(); | 43 makeBitmap(); |
| 44 | 44 |
| 45 for(int i = 0; i < loops; i++) { | 45 for(int i = 0; i < loops; i++) { |
| 46 SkPaint paint; | 46 SkPaint paint; |
| (...skipping 19 matching lines...) Expand all Loading... |
| 66 SK_ColorBLACK, SK_ColorGREEN, SK_ColorCYAN, | 66 SK_ColorBLACK, SK_ColorGREEN, SK_ColorCYAN, |
| 67 SK_ColorRED, 0, SK_ColorBLUE, SK_ColorWHITE | 67 SK_ColorRED, 0, SK_ColorBLUE, SK_ColorWHITE |
| 68 }; | 68 }; |
| 69 paint.setShader(SkGradientShader::MakeLinear(pts, colors, nullptr, SK_AR
RAY_COUNT(colors), | 69 paint.setShader(SkGradientShader::MakeLinear(pts, colors, nullptr, SK_AR
RAY_COUNT(colors), |
| 70 SkShader::kClamp_TileMode))
; | 70 SkShader::kClamp_TileMode))
; |
| 71 canvas.drawPaint(paint); | 71 canvas.drawPaint(paint); |
| 72 } | 72 } |
| 73 }; | 73 }; |
| 74 | 74 |
| 75 class TableCollapseBench: public BaseImageFilterCollapseBench { | 75 class TableCollapseBench: public BaseImageFilterCollapseBench { |
| 76 public: | |
| 77 virtual ~TableCollapseBench() {} | |
| 78 | |
| 79 protected: | 76 protected: |
| 80 virtual const char* onGetName() override { | 77 const char* onGetName() override { |
| 81 return "image_filter_collapse_table"; | 78 return "image_filter_collapse_table"; |
| 82 } | 79 } |
| 83 | 80 |
| 84 virtual void onDelayedSetup() override { | 81 void onDelayedSetup() override { |
| 85 for (int i = 0; i < 256; ++i) { | 82 for (int i = 0; i < 256; ++i) { |
| 86 int n = i >> 5; | 83 int n = i >> 5; |
| 87 table1[i] = (n << 5) | (n << 2) | (n >> 1); | 84 table1[i] = (n << 5) | (n << 2) | (n >> 1); |
| 88 | 85 |
| 89 table2[i] = i * i / 255; | 86 table2[i] = i * i / 255; |
| 90 | 87 |
| 91 float fi = i / 255.0f; | 88 float fi = i / 255.0f; |
| 92 table3[i] = static_cast<uint8_t>(sqrtf(fi) * 255); | 89 table3[i] = static_cast<uint8_t>(sqrtf(fi) * 255); |
| 93 } | 90 } |
| 94 | 91 |
| 95 SkColorFilter* colorFilters[] = { | 92 sk_sp<SkColorFilter> colorFilters[] = { |
| 96 SkTableColorFilter::Create(table1), | 93 SkTableColorFilter::Make(table1), |
| 97 SkTableColorFilter::Create(table2), | 94 SkTableColorFilter::Make(table2), |
| 98 SkTableColorFilter::Create(table3), | 95 SkTableColorFilter::Make(table3), |
| 99 }; | 96 }; |
| 100 | 97 |
| 101 doPreDraw(colorFilters, SK_ARRAY_COUNT(colorFilters)); | 98 doPreDraw(colorFilters, SK_ARRAY_COUNT(colorFilters)); |
| 102 | |
| 103 for(unsigned i = 0; i < SK_ARRAY_COUNT(colorFilters); i++) { | |
| 104 colorFilters[i]->unref(); | |
| 105 } | |
| 106 } | 99 } |
| 107 | 100 |
| 108 private: | 101 private: |
| 109 uint8_t table1[256], table2[256], table3[256]; | 102 uint8_t table1[256], table2[256], table3[256]; |
| 110 }; | 103 }; |
| 111 | 104 |
| 112 static SkColorFilter* make_brightness(float amount) { | 105 static sk_sp<SkColorFilter> make_brightness(float amount) { |
| 113 SkScalar amount255 = SkScalarMul(amount, SkIntToScalar(255)); | 106 SkScalar amount255 = SkScalarMul(amount, SkIntToScalar(255)); |
| 114 SkScalar matrix[20] = { 1, 0, 0, 0, amount255, | 107 SkScalar matrix[20] = { 1, 0, 0, 0, amount255, |
| 115 0, 1, 0, 0, amount255, | 108 0, 1, 0, 0, amount255, |
| 116 0, 0, 1, 0, amount255, | 109 0, 0, 1, 0, amount255, |
| 117 0, 0, 0, 1, 0 }; | 110 0, 0, 0, 1, 0 }; |
| 118 return SkColorMatrixFilter::Create(matrix); | 111 return SkColorFilter::MakeMatrixFilterRowMajor255(matrix); |
| 119 } | 112 } |
| 120 | 113 |
| 121 static SkColorFilter* make_grayscale() { | 114 static sk_sp<SkColorFilter> make_grayscale() { |
| 122 SkScalar matrix[20]; | 115 SkScalar matrix[20]; |
| 123 memset(matrix, 0, 20 * sizeof(SkScalar)); | 116 memset(matrix, 0, 20 * sizeof(SkScalar)); |
| 124 matrix[0] = matrix[5] = matrix[10] = 0.2126f; | 117 matrix[0] = matrix[5] = matrix[10] = 0.2126f; |
| 125 matrix[1] = matrix[6] = matrix[11] = 0.7152f; | 118 matrix[1] = matrix[6] = matrix[11] = 0.7152f; |
| 126 matrix[2] = matrix[7] = matrix[12] = 0.0722f; | 119 matrix[2] = matrix[7] = matrix[12] = 0.0722f; |
| 127 matrix[18] = 1.0f; | 120 matrix[18] = 1.0f; |
| 128 return SkColorMatrixFilter::Create(matrix); | 121 return SkColorFilter::MakeMatrixFilterRowMajor255(matrix); |
| 129 } | 122 } |
| 130 | 123 |
| 131 class MatrixCollapseBench: public BaseImageFilterCollapseBench { | 124 class MatrixCollapseBench: public BaseImageFilterCollapseBench { |
| 132 public: | |
| 133 virtual ~MatrixCollapseBench() {} | |
| 134 | |
| 135 protected: | 125 protected: |
| 136 virtual const char* onGetName() override { | 126 const char* onGetName() override { |
| 137 return "image_filter_collapse_matrix"; | 127 return "image_filter_collapse_matrix"; |
| 138 } | 128 } |
| 139 | 129 |
| 140 virtual void onDelayedSetup() override { | 130 void onDelayedSetup() override { |
| 141 SkColorFilter* colorFilters[] = { | 131 sk_sp<SkColorFilter> colorFilters[] = { |
| 142 make_brightness(0.1f), | 132 make_brightness(0.1f), |
| 143 make_grayscale(), | 133 make_grayscale(), |
| 144 make_brightness(-0.1f), | 134 make_brightness(-0.1f), |
| 145 }; | 135 }; |
| 146 | 136 |
| 147 doPreDraw(colorFilters, SK_ARRAY_COUNT(colorFilters)); | 137 doPreDraw(colorFilters, SK_ARRAY_COUNT(colorFilters)); |
| 148 | |
| 149 for(unsigned i = 0; i < SK_ARRAY_COUNT(colorFilters); i++) { | |
| 150 colorFilters[i]->unref(); | |
| 151 } | |
| 152 } | 138 } |
| 153 }; | 139 }; |
| 154 | 140 |
| 155 DEF_BENCH(return new TableCollapseBench;) | 141 DEF_BENCH(return new TableCollapseBench;) |
| 156 DEF_BENCH(return new MatrixCollapseBench;) | 142 DEF_BENCH(return new MatrixCollapseBench;) |
| OLD | NEW |