blob: 539119e040347b6b6e9c15d639c5e1a15205cf88 [file] [log] [blame]
bsalomonc9c3e622015-04-02 11:12:09 -07001
2/*
3 * Copyright 2015 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
7 */
8
9// This test only works with the GPU backend.
10
11#include "gm.h"
12
13#if SK_SUPPORT_GPU
14
15#include "GrContext.h"
16#include "GrTest.h"
17#include "effects/GrConstColorProcessor.h"
bsalomonf1b7a1d2015-09-28 06:26:28 -070018#include "SkGrPriv.h"
bsalomonc9c3e622015-04-02 11:12:09 -070019#include "SkGradientShader.h"
20
21namespace skiagm {
22/**
23 * This GM directly exercises GrConstColorProcessor.
24 */
25class ConstColorProcessor : public GM {
26public:
27 ConstColorProcessor() {
caryclark65cdba62015-06-15 06:51:08 -070028 this->setBGColor(sk_tool_utils::color_to_565(0xFFDDDDDD));
bsalomonc9c3e622015-04-02 11:12:09 -070029 }
30
31protected:
32 SkString onShortName() override {
33 return SkString("const_color_processor");
34 }
35
36 SkISize onISize() override {
37 return SkISize::Make(kWidth, kHeight);
38 }
39
40 void onOnceBeforeDraw() override {
41 SkColor colors[] = { 0xFFFF0000, 0x2000FF00, 0xFF0000FF};
42 SkPoint pts[] = { SkPoint::Make(0, 0), SkPoint::Make(kRectSize, kRectSize) };
halcanary96fcdcc2015-08-27 07:41:13 -070043 fShader.reset(SkGradientShader::CreateLinear(pts, colors, nullptr, SK_ARRAY_COUNT(colors),
bsalomonc9c3e622015-04-02 11:12:09 -070044 SkShader::kClamp_TileMode));
45 }
46
47 void onDraw(SkCanvas* canvas) override {
48 GrRenderTarget* rt = canvas->internal_private_accessTopLayerRenderTarget();
halcanary96fcdcc2015-08-27 07:41:13 -070049 if (nullptr == rt) {
bsalomonc9c3e622015-04-02 11:12:09 -070050 return;
51 }
52 GrContext* context = rt->getContext();
halcanary96fcdcc2015-08-27 07:41:13 -070053 if (nullptr == context) {
halcanary2a243382015-09-09 08:16:41 -070054 skiagm::GM::DrawGpuOnlyMessage(canvas);
bsalomonc9c3e622015-04-02 11:12:09 -070055 return;
56 }
57
58 static const GrColor kColors[] = {
59 0xFFFFFFFF,
60 0xFFFF00FF,
61 0x80000000,
62 0x00000000,
63 };
64
65 static const SkColor kPaintColors[] = {
66 0xFFFFFFFF,
67 0xFFFF0000,
68 0x80FF0000,
69 0x00000000,
70 };
71
72 static const char* kModeStrs[] {
73 "kIgnore",
74 "kModulateRGBA",
75 "kModulateA",
76 };
77 GR_STATIC_ASSERT(SK_ARRAY_COUNT(kModeStrs) == GrConstColorProcessor::kInputModeCnt);
78
79 SkScalar y = kPad;
80 SkScalar x = kPad;
81 SkScalar maxW = 0;
82 for (size_t paintType = 0; paintType < SK_ARRAY_COUNT(kPaintColors) + 1; ++paintType) {
83 for (size_t procColor = 0; procColor < SK_ARRAY_COUNT(kColors); ++procColor) {
84 for (int m = 0; m < GrConstColorProcessor::kInputModeCnt; ++m) {
85 // translate by x,y for the canvas draws and the test target draws.
86 canvas->save();
87 canvas->translate(x, y);
88 const SkMatrix viewMatrix = SkMatrix::MakeTrans(x, y);
89
90 // rect to draw
91 SkRect renderRect = SkRect::MakeXYWH(0, 0, kRectSize, kRectSize);
92
93 GrTestTarget tt;
94 context->getTestTarget(&tt);
halcanary96fcdcc2015-08-27 07:41:13 -070095 if (nullptr == tt.target()) {
bsalomonc9c3e622015-04-02 11:12:09 -070096 SkDEBUGFAIL("Couldn't get Gr test target.");
97 return;
98 }
99
100 GrPaint grPaint;
101 SkPaint skPaint;
102 if (paintType >= SK_ARRAY_COUNT(kPaintColors)) {
103 skPaint.setShader(fShader);
104 } else {
105 skPaint.setColor(kPaintColors[paintType]);
106 }
bsalomonf1b7a1d2015-09-28 06:26:28 -0700107 SkAssertResult(SkPaintToGrPaint(context, skPaint, viewMatrix, &grPaint));
bsalomonc9c3e622015-04-02 11:12:09 -0700108
109 GrConstColorProcessor::InputMode mode = (GrConstColorProcessor::InputMode) m;
110 GrColor color = kColors[procColor];
111 SkAutoTUnref<GrFragmentProcessor> fp(GrConstColorProcessor::Create(color, mode));
112
bsalomonc9c3e622015-04-02 11:12:09 -0700113 GrClip clip;
joshualitt7b670db2015-07-09 13:25:02 -0700114 GrPipelineBuilder pipelineBuilder(grPaint, rt, clip);
bsalomonac856c92015-08-27 06:30:17 -0700115 pipelineBuilder.addColorFragmentProcessor(fp);
bsalomonc9c3e622015-04-02 11:12:09 -0700116
joshualittd2b23e02015-08-21 10:53:34 -0700117 tt.target()->drawNonAARect(pipelineBuilder,
118 grPaint.getColor(),
119 viewMatrix,
120 renderRect);
bsalomonc9c3e622015-04-02 11:12:09 -0700121
122 // Draw labels for the input to the processor and the processor to the right of
123 // the test rect. The input label appears above the processor label.
124 SkPaint labelPaint;
caryclark1818acb2015-07-24 12:09:25 -0700125 sk_tool_utils::set_portable_typeface(&labelPaint);
bsalomonc9c3e622015-04-02 11:12:09 -0700126 labelPaint.setAntiAlias(true);
127 labelPaint.setTextSize(10.f);
128 SkString inputLabel;
129 inputLabel.set("Input: ");
130 if (paintType >= SK_ARRAY_COUNT(kPaintColors)) {
131 inputLabel.append("gradient");
132 } else {
133 inputLabel.appendf("0x%08x", kPaintColors[paintType]);
134 }
135 SkString procLabel;
136 procLabel.printf("Proc: [0x%08x, %s]", kColors[procColor], kModeStrs[m]);
137
138 SkRect inputLabelBounds;
139 // get the bounds of the text in order to position it
140 labelPaint.measureText(inputLabel.c_str(), inputLabel.size(),
141 &inputLabelBounds);
142 canvas->drawText(inputLabel.c_str(), inputLabel.size(),
143 renderRect.fRight + kPad,
144 -inputLabelBounds.fTop, labelPaint);
145 // update the bounds to reflect the offset we used to draw it.
146 inputLabelBounds.offset(renderRect.fRight + kPad, -inputLabelBounds.fTop);
147
148 SkRect procLabelBounds;
149 labelPaint.measureText(procLabel.c_str(), procLabel.size(),
150 &procLabelBounds);
151 canvas->drawText(procLabel.c_str(), procLabel.size(),
152 renderRect.fRight + kPad,
153 inputLabelBounds.fBottom + 2.f - procLabelBounds.fTop,
154 labelPaint);
155 procLabelBounds.offset(renderRect.fRight + kPad,
156 inputLabelBounds.fBottom + 2.f - procLabelBounds.fTop);
157
158 labelPaint.setStrokeWidth(0);
159 labelPaint.setStyle(SkPaint::kStroke_Style);
160 canvas->drawRect(renderRect, labelPaint);
161
162 canvas->restore();
163
164 // update x and y for the next test case.
165 SkScalar height = renderRect.height();
166 SkScalar width = SkTMax(inputLabelBounds.fRight, procLabelBounds.fRight);
167 maxW = SkTMax(maxW, width);
168 y += height + kPad;
169 if (y + height > kHeight) {
170 y = kPad;
171 x += maxW + kPad;
172 maxW = 0;
173 }
174 }
175 }
176 }
177 }
178
179private:
180 // Use this as a way of generating and input FP
181 SkAutoTUnref<SkShader> fShader;
182
183 static const SkScalar kPad;
184 static const SkScalar kRectSize;
185 static const int kWidth = 820;
186 static const int kHeight = 500;
187
188 typedef GM INHERITED;
189};
190
191const SkScalar ConstColorProcessor::kPad = 10.f;
192const SkScalar ConstColorProcessor::kRectSize = 20.f;
193
halcanary385fe4d2015-08-26 13:07:48 -0700194DEF_GM(return new ConstColorProcessor;)
bsalomonc9c3e622015-04-02 11:12:09 -0700195}
196
197#endif