• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1  /*
2   * Copyright 2012 Google Inc.
3   *
4   * Use of this source code is governed by a BSD-style license that can be
5   * found in the LICENSE file.
6   */
7  #include "Benchmark.h"
8  #include "SkCanvas.h"
9  #include "SkMatrixConvolutionImageFilter.h"
10  #include "SkPaint.h"
11  #include "SkRandom.h"
12  #include "SkString.h"
13  
name(SkMatrixConvolutionImageFilter::TileMode mode)14  static const char* name(SkMatrixConvolutionImageFilter::TileMode mode) {
15      switch (mode) {
16          case SkMatrixConvolutionImageFilter::kClamp_TileMode:        return "clamp";
17          case SkMatrixConvolutionImageFilter::kRepeat_TileMode:       return "repeat";
18          case SkMatrixConvolutionImageFilter::kClampToBlack_TileMode: return "clampToBlack";
19      }
20      return "oops";
21  }
22  
23  class MatrixConvolutionBench : public Benchmark {
24  public:
MatrixConvolutionBench(SkMatrixConvolutionImageFilter::TileMode tileMode,bool convolveAlpha)25      MatrixConvolutionBench(SkMatrixConvolutionImageFilter::TileMode tileMode, bool convolveAlpha)
26          : fName(SkStringPrintf("matrixconvolution_%s%s",
27                                 name(tileMode),
28                                 convolveAlpha ? "" : "_noConvolveAlpha")) {
29          SkISize kernelSize = SkISize::Make(3, 3);
30          SkScalar kernel[9] = {
31              SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1),
32              SkIntToScalar( 1), SkIntToScalar(-7), SkIntToScalar( 1),
33              SkIntToScalar( 1), SkIntToScalar( 1), SkIntToScalar( 1),
34          };
35          SkScalar gain = 0.3f, bias = SkIntToScalar(100);
36          SkIPoint kernelOffset = SkIPoint::Make(1, 1);
37          fFilter = SkMatrixConvolutionImageFilter::Make(kernelSize, kernel, gain, bias,
38                                                         kernelOffset, tileMode, convolveAlpha,
39                                                         nullptr);
40      }
41  
42  protected:
onGetName()43      virtual const char* onGetName() {
44          return fName.c_str();
45      }
46  
onDraw(int loops,SkCanvas * canvas)47      virtual void onDraw(int loops, SkCanvas* canvas) {
48          SkPaint paint;
49          this->setupPaint(&paint);
50          paint.setAntiAlias(true);
51          SkRandom rand;
52          for (int i = 0; i < loops; i++) {
53              SkRect r = SkRect::MakeWH(rand.nextUScalar1() * 400,
54                                        rand.nextUScalar1() * 400);
55              paint.setImageFilter(fFilter);
56              canvas->drawOval(r, paint);
57          }
58      }
59  
60  private:
61      sk_sp<SkImageFilter> fFilter;
62      SkString fName;
63  
64      typedef Benchmark INHERITED;
65  };
66  
67  DEF_BENCH( return new MatrixConvolutionBench(SkMatrixConvolutionImageFilter::kClamp_TileMode, true); )
68  DEF_BENCH( return new MatrixConvolutionBench(SkMatrixConvolutionImageFilter::kRepeat_TileMode, true); )
69  DEF_BENCH( return new MatrixConvolutionBench(SkMatrixConvolutionImageFilter::kClampToBlack_TileMode, true); )
70  DEF_BENCH( return new MatrixConvolutionBench(SkMatrixConvolutionImageFilter::kClampToBlack_TileMode, false); )
71