1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
|
/*
* Copyright 2017 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#include "Benchmark.h"
#include "SkCanvas.h"
#include "SkDrawShadowInfo.h"
#include "SkPaint.h"
#include "SkPath.h"
#include "SkShadowUtils.h"
class ShadowBench : public Benchmark {
// Draws a set of shadowed rrects filling the canvas, in various modes:
// * opaque or transparent
// * use analytic fast path or geometric tessellation
public:
ShadowBench(bool transparent, bool forceGeometric)
: fTransparent(transparent)
, fForceGeometric(forceGeometric) {
computeName("shadows");
}
bool isVisual() override { return true; }
protected:
enum {
kWidth = 640,
kHeight = 480,
kRRSize = 50,
kRRRadius = 6,
kRRSpace = 8,
kRRStep = kRRSize + kRRSpace,
kElevation = 16,
kNumRRects = ((kWidth - kRRSpace) / kRRStep)*((kHeight - kRRSpace) / kRRStep)
};
void computeName(const char root[]) {
static const char kTransChars[2] = {
'o', 't'
};
static const char kGeomChars[2] = {
'a', 'g'
};
fBaseName.printf("%s_%c_%c", root, kTransChars[fTransparent], kGeomChars[fForceGeometric]);
}
void genRRects() {
int i = 0;
for (int x = kRRSpace; x < kWidth - kRRStep; x += kRRStep) {
for (int y = kRRSpace; y < kHeight - kRRStep; y += kRRStep) {
SkRect rect = SkRect::MakeXYWH(x, y, kRRSize, kRRSize);
fRRects[i].addRRect(SkRRect::MakeRectXY(rect, kRRRadius, kRRRadius));
++i;
}
}
SkASSERT(i == kNumRRects);
}
const char* onGetName() override { return fBaseName.c_str(); }
void onDelayedSetup() override {
fRec.fZPlaneParams = SkPoint3::Make(0, 0, kElevation);
fRec.fLightPos = SkPoint3::Make(270, 0, 600);
fRec.fLightRadius = 800;
fRec.fAmbientAlpha = 0.1f;
fRec.fSpotAlpha = 0.25f;
fRec.fColor = SK_ColorBLACK;
fRec.fFlags = 0;
if (fTransparent) {
fRec.fFlags |= SkShadowFlags::kTransparentOccluder_ShadowFlag;
}
if (fForceGeometric) {
fRec.fFlags |= SkShadowFlags::kGeometricOnly_ShadowFlag;
}
this->genRRects();
}
void onDraw(int loops, SkCanvas* canvas) override {
SkPaint paint;
paint.setColor(SK_ColorWHITE);
this->setupPaint(&paint);
for (int i = 0; i < loops; ++i) {
// use the private canvas call so we don't include the time to stuff data in the Rec
canvas->private_draw_shadow_rec(fRRects[i % kNumRRects], fRec);
}
}
private:
SkString fBaseName;
SkPath fRRects[kNumRRects];
SkDrawShadowRec fRec;
int fTransparent;
int fForceGeometric;
typedef Benchmark INHERITED;
};
DEF_BENCH(return new ShadowBench(false, false);)
DEF_BENCH(return new ShadowBench(false, true);)
DEF_BENCH(return new ShadowBench(true, false);)
DEF_BENCH(return new ShadowBench(true, true);)
|