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
109
110
111
112
113
114
|
/*
* 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 "SkShader.h"
#include "SkGradientShader.h"
#include "SkString.h"
#include "SkColor.h"
#include "SkPaint.h"
class HardStopGradientBench_ScaleNumHardStops : public Benchmark {
public:
HardStopGradientBench_ScaleNumHardStops(int colorCount, int hardStopCount) {
SkASSERT(hardStopCount <= colorCount/2);
fName.printf("hardstop_scale_num_hard_stops_%03d_colors_%03d_hard_stops",
colorCount, hardStopCount);
fColorCount = colorCount;
fHardStopCount = hardStopCount;
}
const char* onGetName() override {
return fName.c_str();
}
SkIPoint onGetSize() override {
return SkIPoint::Make(kSize, kSize);
}
void onPreDraw(SkCanvas* canvas) override {
// Left to right
SkPoint points[2] = {
SkPoint::Make(0, kSize/2),
SkPoint::Make(kSize-1, kSize/2),
};
constexpr int kNumColorChoices = 4;
SkColor color_choices[kNumColorChoices] = {
SK_ColorRED,
SK_ColorGREEN,
SK_ColorBLUE,
SK_ColorYELLOW,
};
// Alternate between different choices
SkAutoTArray<SkColor> colors(fColorCount);
for (int i = 0; i < fColorCount; i++) {
colors[i] = color_choices[i % kNumColorChoices];
}
// Create requisite number of hard stops, and evenly
// space positions after that
SkAutoTArray<SkScalar> positions(fColorCount);
int k = 0;
for (int i = 0; i < fHardStopCount; i++) {
float val = k/2.0f;
positions[k++] = val / fColorCount;
positions[k++] = val / fColorCount;
}
for (int i = k; i < fColorCount; i++) {
positions[i] = i / (fColorCount - 1.0f);
}
fPaint.setShader(SkGradientShader::MakeLinear(points,
colors.get(),
positions.get(),
fColorCount,
SkShader::kClamp_TileMode,
0,
nullptr));
}
/*
* Draw simple linear gradient from left to right
*/
void onDraw(int loops, SkCanvas* canvas) override {
for (int i = 0; i < loops; i++) {
canvas->drawPaint(fPaint);
}
}
private:
static const int kSize = 500;
SkString fName;
int fColorCount;
int fHardStopCount;
SkPaint fPaint;
typedef Benchmark INHERITED;
};
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(10, 1);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(10, 2);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(10, 5);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(20, 1);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(20, 5);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(20, 10);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(50, 1);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(50, 10);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(50, 25);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(100, 1);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(100, 25);)
DEF_BENCH(return new HardStopGradientBench_ScaleNumHardStops(100, 50);)
|