blob: 06afe91dc5c730b812e8755eebee28b742ecba3d [file] [log] [blame]
egdaniel02cafcc2014-07-21 11:37:28 -07001/*
2 * Copyright 2014 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
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "bench/Benchmark.h"
9#include "include/core/SkBitmap.h"
10#include "include/core/SkCanvas.h"
11#include "include/core/SkPaint.h"
12#include "include/core/SkPath.h"
13#include "include/core/SkString.h"
14#include "include/effects/SkGradientShader.h"
egdaniel02cafcc2014-07-21 11:37:28 -070015
16enum ColorPattern {
17 kWhite_ColorPattern,
18 kBlue_ColorPattern,
19 kOpaqueBitmap_ColorPattern,
20 kAlphaBitmap_ColorPattern,
21};
22
23static const struct ColorPatternData{
24 SkColor fColor;
25 bool fIsBitmap;
26 const char* fName;
27} gColorPatterns[] = {
28 // Keep this in same order as ColorPattern enum
29 { SK_ColorWHITE, false, "white" }, // kWhite_ColorPattern
30 { SK_ColorBLUE, false, "blue" }, // kBlue_ColorPattern
31 { SK_ColorWHITE, true, "obaqueBitMap" }, // kOpaqueBitmap_ColorPattern
32 { 0x10000000, true, "alphaBitmap" }, // kAlphaBitmap_ColorPattern
33};
34
35enum DrawType {
36 kRect_DrawType,
37 kPath_DrawType,
38};
39
40static void makebm(SkBitmap* bm, int w, int h) {
41 bm->allocN32Pixels(w, h);
42 bm->eraseColor(SK_ColorTRANSPARENT);
43
44 SkCanvas canvas(*bm);
Brian Osman7f364052020-02-06 11:25:43 -050045 SkScalar s = SkIntToScalar(std::min(w, h));
egdaniel02cafcc2014-07-21 11:37:28 -070046 static const SkPoint kPts0[] = { { 0, 0 }, { s, s } };
47 static const SkPoint kPts1[] = { { s/2, 0 }, { s/2, s } };
48 static const SkScalar kPos[] = { 0, SK_Scalar1/2, SK_Scalar1 };
49 static const SkColor kColors0[] = {0x80F00080, 0xF0F08000, 0x800080F0 };
50 static const SkColor kColors1[] = {0xF08000F0, 0x8080F000, 0xF000F080 };
51
52
53 SkPaint paint;
54
reedc6f28f72016-03-14 12:22:10 -070055 paint.setShader(SkGradientShader::MakeLinear(kPts0, kColors0, kPos, SK_ARRAY_COUNT(kColors0),
Mike Reedfae8fce2019-04-03 10:27:45 -040056 SkTileMode::kClamp));
egdaniel02cafcc2014-07-21 11:37:28 -070057 canvas.drawPaint(paint);
reedc6f28f72016-03-14 12:22:10 -070058 paint.setShader(SkGradientShader::MakeLinear(kPts1, kColors1, kPos, SK_ARRAY_COUNT(kColors1),
Mike Reedfae8fce2019-04-03 10:27:45 -040059 SkTileMode::kClamp));
egdaniel02cafcc2014-07-21 11:37:28 -070060 canvas.drawPaint(paint);
61}
62
63/**
64 * This bench draws a grid of either rects or filled paths, with two alternating color patterns.
65 * This color patterns are passed in as enums to the class. The options are:
66 * 1) solid white color
67 * 2) solid blue color
68 * 3) opaque bitmap
69 * 4) partial alpha bitmap
70 * The same color pattern can be set for both arguments to create a uniform pattern on all draws.
71 *
72 * The bench is used to test a few things. First it can test any optimizations made for a specific
73 * color pattern (for example drawing an opaque bitmap versus one with partial alpha). Also it can
Brian Salomon09d994e2016-12-21 11:14:46 -050074 * be used to test the cost of program switching and/or GrDrawOp combining when alternating between
75 * different patterns when on the gpu.
egdaniel02cafcc2014-07-21 11:37:28 -070076 */
77class AlternatingColorPatternBench : public Benchmark {
78public:
79 enum {
80 NX = 5,
81 NY = 5,
82 NUM_DRAWS = NX * NY,
83 };
reedc6f28f72016-03-14 12:22:10 -070084 sk_sp<SkShader> fBmShader;
egdaniel02cafcc2014-07-21 11:37:28 -070085
86 SkPath fPaths[NUM_DRAWS];
87 SkRect fRects[NUM_DRAWS];
88 SkColor fColors[NUM_DRAWS];
reedc6f28f72016-03-14 12:22:10 -070089 sk_sp<SkShader> fShaders[NUM_DRAWS];
egdaniel02cafcc2014-07-21 11:37:28 -070090
91 SkString fName;
92 ColorPatternData fPattern1;
93 ColorPatternData fPattern2;
94 DrawType fDrawType;
95 SkBitmap fBmp;
96
97
reedc6f28f72016-03-14 12:22:10 -070098 AlternatingColorPatternBench(ColorPattern pattern1, ColorPattern pattern2, DrawType drawType) {
egdaniel02cafcc2014-07-21 11:37:28 -070099 fPattern1 = gColorPatterns[pattern1];
100 fPattern2 = gColorPatterns[pattern2];
101 fName.printf("colorPattern_%s_%s_%s",
102 fPattern1.fName, fPattern2.fName,
103 kRect_DrawType == drawType ? "rect" : "path");
104 fDrawType = drawType;
105 }
106
egdaniel02cafcc2014-07-21 11:37:28 -0700107protected:
mtklein36352bf2015-03-25 18:17:31 -0700108 const char* onGetName() override {
egdaniel02cafcc2014-07-21 11:37:28 -0700109 return fName.c_str();
110 }
111
joshualitt8a6697a2015-09-30 12:11:07 -0700112 void onDelayedSetup() override {
egdaniel02cafcc2014-07-21 11:37:28 -0700113 int w = 40;
114 int h = 40;
115 makebm(&fBmp, w, h);
Mike Reed50acf8f2019-04-08 13:20:23 -0400116 fBmShader = fBmp.makeShader(SkTileMode::kRepeat, SkTileMode::kRepeat);
egdaniel02cafcc2014-07-21 11:37:28 -0700117 int offset = 2;
118 int count = 0;
119 for (int j = 0; j < NY; ++j) {
120 for (int i = 0; i < NX; ++i) {
121 int x = (w + offset) * i;
122 int y = (h * offset) * j;
123 if (kRect_DrawType == fDrawType) {
Mike Reed92b33352019-08-24 19:39:13 -0400124 fRects[count].setXYWH(SkIntToScalar(x), SkIntToScalar(y),
125 SkIntToScalar(w), SkIntToScalar(h));
egdaniel02cafcc2014-07-21 11:37:28 -0700126 } else {
127 fPaths[count].moveTo(SkIntToScalar(x), SkIntToScalar(y));
128 fPaths[count].rLineTo(SkIntToScalar(w), 0);
129 fPaths[count].rLineTo(0, SkIntToScalar(h));
130 fPaths[count].rLineTo(SkIntToScalar(-w + 1), 0);
131 }
132 if (0 == count % 2) {
133 fColors[count] = fPattern1.fColor;
halcanary96fcdcc2015-08-27 07:41:13 -0700134 fShaders[count] = fPattern1.fIsBitmap ? fBmShader : nullptr;
egdaniel02cafcc2014-07-21 11:37:28 -0700135 } else {
136 fColors[count] = fPattern2.fColor;
halcanary96fcdcc2015-08-27 07:41:13 -0700137 fShaders[count] = fPattern2.fIsBitmap ? fBmShader : nullptr;
egdaniel02cafcc2014-07-21 11:37:28 -0700138 }
139 ++count;
140 }
141 }
142 }
143
mtkleina1ebeb22015-10-01 09:43:39 -0700144 void onDraw(int loops, SkCanvas* canvas) override {
egdaniel02cafcc2014-07-21 11:37:28 -0700145 SkPaint paint;
146 paint.setAntiAlias(false);
reed93a12152015-03-16 10:08:34 -0700147 paint.setFilterQuality(kLow_SkFilterQuality);
egdaniel02cafcc2014-07-21 11:37:28 -0700148
149 for (int i = 0; i < loops; ++i) {
150 for (int j = 0; j < NUM_DRAWS; ++j) {
151 paint.setColor(fColors[j]);
152 paint.setShader(fShaders[j]);
153 if (kRect_DrawType == fDrawType) {
154 canvas->drawRect(fRects[j], paint);
155 } else {
156 canvas->drawPath(fPaths[j], paint);
157 }
158 }
159 }
160 }
161
162private:
163 typedef Benchmark INHERITED;
164};
165
halcanary385fe4d2015-08-26 13:07:48 -0700166DEF_BENCH(return new AlternatingColorPatternBench(kWhite_ColorPattern,
167 kWhite_ColorPattern,
168 kPath_DrawType);)
169DEF_BENCH(return new AlternatingColorPatternBench(kBlue_ColorPattern,
170 kBlue_ColorPattern,
171 kPath_DrawType);)
172DEF_BENCH(return new AlternatingColorPatternBench(kWhite_ColorPattern,
173 kBlue_ColorPattern,
174 kPath_DrawType);)
egdaniel02cafcc2014-07-21 11:37:28 -0700175
halcanary385fe4d2015-08-26 13:07:48 -0700176DEF_BENCH(return new AlternatingColorPatternBench(kOpaqueBitmap_ColorPattern,
177 kOpaqueBitmap_ColorPattern,
178 kPath_DrawType);)
179DEF_BENCH(return new AlternatingColorPatternBench(kAlphaBitmap_ColorPattern,
180 kAlphaBitmap_ColorPattern,
181 kPath_DrawType);)
182DEF_BENCH(return new AlternatingColorPatternBench(kOpaqueBitmap_ColorPattern,
183 kAlphaBitmap_ColorPattern,
184 kPath_DrawType);)
egdaniel02cafcc2014-07-21 11:37:28 -0700185
halcanary385fe4d2015-08-26 13:07:48 -0700186DEF_BENCH(return new AlternatingColorPatternBench(kOpaqueBitmap_ColorPattern,
187 kOpaqueBitmap_ColorPattern,
188 kRect_DrawType);)
189DEF_BENCH(return new AlternatingColorPatternBench(kAlphaBitmap_ColorPattern,
190 kAlphaBitmap_ColorPattern,
191 kRect_DrawType);)
192DEF_BENCH(return new AlternatingColorPatternBench(kOpaqueBitmap_ColorPattern,
193 kAlphaBitmap_ColorPattern,
194 kRect_DrawType);)