blob: 183440868039e09807a56e79b24c43a7356ad338 [file] [log] [blame]
reed@google.com05d63ae2011-10-28 18:57:32 +00001/*
2 * Copyright 2011 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/SkCanvas.h"
10#include "include/core/SkPaint.h"
11#include "include/core/SkShader.h"
12#include "include/core/SkString.h"
13#include "include/core/SkVertices.h"
14#include "include/utils/SkRandom.h"
reed@google.com05d63ae2011-10-28 18:57:32 +000015
16enum VertFlags {
17 kColors_VertFlag,
18 kTexture_VertFlag,
19};
20
tfarinaf168b862014-06-19 12:32:29 -070021class VertBench : public Benchmark {
reed@google.com05d63ae2011-10-28 18:57:32 +000022 SkString fName;
23 enum {
24 W = 640,
25 H = 480,
26 ROW = 20,
27 COL = 20,
28 PTS = (ROW + 1) * (COL + 1),
29 IDX = ROW * COL * 6,
reed@google.com05d63ae2011-10-28 18:57:32 +000030 };
31
32 SkPoint fPts[PTS];
33 SkColor fColors[PTS];
reed@google.com05d63ae2011-10-28 18:57:32 +000034 uint16_t fIdx[IDX];
35
36 static void load_2_tris(uint16_t idx[], int x, int y, int rb) {
37 int n = y * rb + x;
38 idx[0] = n; idx[1] = n + 1; idx[2] = rb + n + 1;
39 idx[3] = n; idx[4] = rb + n + 1; idx[5] = n + rb;
40 }
rmistry@google.comfbfcd562012-08-23 18:09:54 +000041
reed@google.com05d63ae2011-10-28 18:57:32 +000042public:
mtklein@google.com410e6e82013-09-13 19:52:27 +000043 VertBench() {
reed@google.com05d63ae2011-10-28 18:57:32 +000044 const SkScalar dx = SkIntToScalar(W) / COL;
45 const SkScalar dy = SkIntToScalar(H) / COL;
46
47 SkPoint* pts = fPts;
48 uint16_t* idx = fIdx;
49
50 SkScalar yy = 0;
51 for (int y = 0; y <= ROW; y++) {
52 SkScalar xx = 0;
53 for (int x = 0; x <= COL; ++x) {
54 pts->set(xx, yy);
55 pts += 1;
56 xx += dx;
rmistry@google.comfbfcd562012-08-23 18:09:54 +000057
reed@google.com05d63ae2011-10-28 18:57:32 +000058 if (x < COL && y < ROW) {
59 load_2_tris(idx, x, y, COL + 1);
60 for (int i = 0; i < 6; i++) {
61 SkASSERT(idx[i] < PTS);
62 }
63 idx += 6;
64 }
65 }
66 yy += dy;
67 }
68 SkASSERT(PTS == pts - fPts);
69 SkASSERT(IDX == idx - fIdx);
70
commit-bot@chromium.orge0e7cfe2013-09-09 20:09:12 +000071 SkRandom rand;
reed@google.com05d63ae2011-10-28 18:57:32 +000072 for (int i = 0; i < PTS; ++i) {
73 fColors[i] = rand.nextU() | (0xFF << 24);
74 }
75
76 fName.set("verts");
77 }
78
79protected:
Mike Reed887cdf12017-04-03 11:11:09 -040080 const char* onGetName() override { return fName.c_str(); }
81 void onDraw(int loops, SkCanvas* canvas) override {
reed@google.com05d63ae2011-10-28 18:57:32 +000082 SkPaint paint;
83 this->setupPaint(&paint);
bsalomon@google.com4a018bb2011-10-28 19:50:21 +000084
Mike Reed887cdf12017-04-03 11:11:09 -040085 auto verts = SkVertices::MakeCopy(SkVertices::kTriangles_VertexMode, PTS,
86 fPts, nullptr, fColors, IDX, fIdx);
commit-bot@chromium.org33614712013-12-03 18:17:16 +000087 for (int i = 0; i < loops; i++) {
Mike Reed887cdf12017-04-03 11:11:09 -040088 canvas->drawVertices(verts, SkBlendMode::kModulate, paint);
reed@google.com05d63ae2011-10-28 18:57:32 +000089 }
reed@google.com05d63ae2011-10-28 18:57:32 +000090 }
91private:
tfarinaf168b862014-06-19 12:32:29 -070092 typedef Benchmark INHERITED;
reed@google.com05d63ae2011-10-28 18:57:32 +000093};
halcanary385fe4d2015-08-26 13:07:48 -070094DEF_BENCH(return new VertBench();)
Mike Reed1d0e68b2019-03-22 15:57:45 -040095
96/////////////////////////////////////////////////////////////////////////////////////////////////
97
Mike Kleinc0bd9f92019-04-23 12:05:21 -050098#include "include/core/SkRSXform.h"
99#include "include/utils/SkRandom.h"
100#include "tools/Resources.h"
Mike Reed1d0e68b2019-03-22 15:57:45 -0400101
102enum AtlasFlags {
103 kColors_Flag = 1 << 0,
104 kVerts_Flag = 1 << 1,
105};
106
107class AtlasBench : public Benchmark {
108 unsigned fFlags;
109 SkString fName;
110 enum {
111 W = 640,
112 H = 480,
113 N = 10*1000,
114 };
115
116 sk_sp<SkImage> fAtlas;
117 SkRSXform fXforms[N];
118 SkRect fRects[N];
119 SkColor fColors[N];
120
121public:
122 AtlasBench(unsigned flags) : fFlags(flags) {
123 fName.printf("drawAtlas_%d", flags);
124 }
125 ~AtlasBench() override {}
126
127protected:
128 const char* onGetName() override { return fName.c_str(); }
129 void onDelayedSetup() override {
130 fAtlas = GetResourceAsImage("images/mandrill_256.png");
131 if (fAtlas) {
132 fAtlas = fAtlas->makeRasterImage();
133 }
134
135 const SkScalar imageW = fAtlas->width();
136 const SkScalar imageH = fAtlas->height();
137
138 SkRandom rand;
139 for (int i = 0; i < N; ++i) {
140 fRects[i] = SkRect::MakeXYWH(rand.nextF() * (imageW - 8),
141 rand.nextF() * (imageH - 8), 8, 8);
142 fColors[i] = rand.nextU();
143 fXforms[i] = SkRSXform::Make(1, 0, rand.nextF() * W, rand.nextF() * H);
144 }
145 }
146 void onDraw(int loops, SkCanvas* canvas) override {
147 const SkRect* cullRect = nullptr;
148 const SkPaint* paintPtr = nullptr;
149 const SkColor* colors = nullptr;
150 const SkImage* atlas = nullptr;
151 if (fFlags & kColors_Flag) {
152 colors = fColors;
153 }
154 if (fFlags & kVerts_Flag) {
155 atlas = fAtlas.get();
156 }
157 for (int i = 0; i < loops; i++) {
158 canvas->drawAtlas(atlas, fXforms, fRects, colors, N, SkBlendMode::kSrcOver,
159 cullRect, paintPtr);
160 }
161 }
162private:
163 typedef Benchmark INHERITED;
164};
165//DEF_BENCH(return new AtlasBench(0);)
166//DEF_BENCH(return new AtlasBench(kColors_Flag);)
167DEF_BENCH(return new AtlasBench(kVerts_Flag);)
168DEF_BENCH(return new AtlasBench(kVerts_Flag | kColors_Flag);)
169