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
|
/*
* Copyright 2016 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 "SkMaskFilter.h"
#include "SkPaint.h"
#include "SkRRect.h"
#include "SkRect.h"
#include "sk_tool_utils.h"
class BlurOccludedRRectBench : public Benchmark {
public:
BlurOccludedRRectBench() {}
const char* onGetName() override {
return "bluroccludedrrect";
}
SkIPoint onGetSize() override {
return SkIPoint::Make(1024, 2048);
}
void onDraw(int loops, SkCanvas* canvas) override {
for (int l = 0; l < loops; ++l) {
SkPaint opaque;
opaque.setAntiAlias(true);
opaque.setColor(SK_ColorWHITE);
const SkRect r = SkRect::MakeWH(480, 230);
const SkRRect rr = SkRRect::MakeRectXY(r, 8, 8);
SkRect occRect = sk_tool_utils::compute_central_occluder(rr);
for (int i = 0; i < 2; ++i) {
canvas->save();
canvas->translate(i*502.0f+20, 10.0f);
for (int j = 0; j < 8; ++j) {
canvas->save();
canvas->translate(0.0f, j*256.0f);
SkPaint firstBlur;
firstBlur.setAntiAlias(true);
firstBlur.setColor(0x09000000);
firstBlur.setMaskFilter(SkMaskFilter::MakeBlur(kNormal_SkBlurStyle,
2.5f,
occRect));
canvas->drawRRect(rr, firstBlur);
canvas->save();
canvas->translate(1.5f, 1.5f);
SkPaint secondBlur;
secondBlur.setAntiAlias(true);
secondBlur.setColor(0x30000000);
secondBlur.setMaskFilter(SkMaskFilter::MakeBlur(kNormal_SkBlurStyle,
6.0f,
occRect));
canvas->drawRRect(rr, secondBlur);
canvas->restore();
canvas->drawRRect(rr, opaque);
canvas->restore();
}
canvas->restore();
}
}
}
private:
typedef Benchmark INHERITED;
};
DEF_BENCH(return new BlurOccludedRRectBench();)
|