blob: 1b393f32a37a063f565b5dcf015c700e427a5402 [file] [log] [blame]
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +00001/*
2 * Copyright 2013 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
egdaniel309e3462014-12-09 10:35:58 -08008#include "GrBitmapTextGeoProc.h"
egdaniel605dd0f2014-11-12 08:35:25 -08009#include "GrInvariantOutput.h"
joshualitteb2a6762014-12-04 11:35:33 -080010#include "GrTexture.h"
joshualittb0a8a372014-09-23 09:50:21 -070011#include "gl/GrGLProcessor.h"
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000012#include "gl/GrGLSL.h"
13#include "gl/GrGLTexture.h"
joshualitt249af152014-09-15 11:41:13 -070014#include "gl/GrGLGeometryProcessor.h"
joshualitteb2a6762014-12-04 11:35:33 -080015#include "gl/builders/GrGLProgramBuilder.h"
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000016
joshualitt9b989322014-12-15 14:16:27 -080017struct BitmapTextBatchTracker {
18 GrGPInput fInputColorType;
19 GrColor fColor;
20};
21
egdaniel309e3462014-12-09 10:35:58 -080022class GrGLBitmapTextGeoProc : public GrGLGeometryProcessor {
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000023public:
joshualitt9b989322014-12-15 14:16:27 -080024 GrGLBitmapTextGeoProc(const GrGeometryProcessor&, const GrBatchTracker&)
25 : fColor(GrColor_ILLEGAL) {}
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000026
joshualittc369e7c2014-10-22 10:56:26 -070027 virtual void emitCode(const EmitArgs& args) SK_OVERRIDE {
egdaniel309e3462014-12-09 10:35:58 -080028 const GrBitmapTextGeoProc& cte = args.fGP.cast<GrBitmapTextGeoProc>();
joshualitt9b989322014-12-15 14:16:27 -080029 const BitmapTextBatchTracker& local = args.fBT.cast<BitmapTextBatchTracker>();
joshualitt2dd1ae02014-12-03 06:24:10 -080030
joshualitt9b989322014-12-15 14:16:27 -080031 GrGLGPBuilder* pb = args.fPB;
32 GrGLVertexBuilder* vsBuilder = pb->getVertexShaderBuilder();
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000033
joshualitt74077b92014-10-24 11:26:03 -070034 GrGLVertToFrag v(kVec2f_GrSLType);
joshualitt9b989322014-12-15 14:16:27 -080035 pb->addVarying("TextureCoords", &v);
joshualitt2dd1ae02014-12-03 06:24:10 -080036 vsBuilder->codeAppendf("%s = %s;", v.vsOut(), cte.inTextureCoords()->fName);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000037
joshualitt9b989322014-12-15 14:16:27 -080038 // Setup pass through color
39 this->setupColorPassThrough(pb, local.fInputColorType, args.fOutputColor, cte.inColor(),
40 &fColorUniform);
joshualitt2dd1ae02014-12-03 06:24:10 -080041
42 // setup output coords
43 vsBuilder->codeAppendf("%s = %s;", vsBuilder->positionCoords(), cte.inPosition()->fName);
44 vsBuilder->codeAppendf("%s = %s;", vsBuilder->localCoords(), cte.inPosition()->fName);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000045
joshualitt4973d9d2014-11-08 09:24:25 -080046 // setup position varying
47 vsBuilder->codeAppendf("%s = %s * vec3(%s, 1);", vsBuilder->glPosition(),
joshualitt2dd1ae02014-12-03 06:24:10 -080048 vsBuilder->uViewM(), cte.inPosition()->fName);
joshualitt4973d9d2014-11-08 09:24:25 -080049
joshualitt9b989322014-12-15 14:16:27 -080050 GrGLGPFragmentBuilder* fsBuilder = pb->getFragmentShaderBuilder();
joshualitt2dd1ae02014-12-03 06:24:10 -080051 fsBuilder->codeAppendf("%s = ", args.fOutputCoverage);
52 fsBuilder->appendTextureLookup(args.fSamplers[0], v.fsIn(), kVec2f_GrSLType);
joshualitt74077b92014-10-24 11:26:03 -070053 fsBuilder->codeAppend(";");
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000054 }
55
joshualitt9b989322014-12-15 14:16:27 -080056 virtual void setData(const GrGLProgramDataManager& pdman,
57 const GrPrimitiveProcessor& gp,
58 const GrBatchTracker& bt) SK_OVERRIDE {
59 const BitmapTextBatchTracker& local = bt.cast<BitmapTextBatchTracker>();
60 if (kUniform_GrGPInput == local.fInputColorType && local.fColor != fColor) {
61 GrGLfloat c[4];
62 GrColorToRGBAFloat(local.fColor, c);
63 pdman.set4fv(fColorUniform, 1, c);
64 fColor = local.fColor;
65 }
joshualitt2dd1ae02014-12-03 06:24:10 -080066 }
67
joshualitt9b989322014-12-15 14:16:27 -080068 static inline void GenKey(const GrGeometryProcessor& proc,
69 const GrBatchTracker& bt,
70 const GrGLCaps&,
71 GrProcessorKeyBuilder* b) {
72 const BitmapTextBatchTracker& local = bt.cast<BitmapTextBatchTracker>();
73 // We have to put the optional vertex attribute as part of the key. See the comment
74 // on addVertexAttrib.
75 // TODO When we have deferred geometry we can fix this
76 const GrBitmapTextGeoProc& gp = proc.cast<GrBitmapTextGeoProc>();
77 b->add32(SkToBool(gp.inColor()));
78 b->add32(local.fInputColorType);
79 }
joshualitt2dd1ae02014-12-03 06:24:10 -080080
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000081private:
joshualitt9b989322014-12-15 14:16:27 -080082 GrColor fColor;
83 UniformHandle fColorUniform;
84
joshualitt249af152014-09-15 11:41:13 -070085 typedef GrGLGeometryProcessor INHERITED;
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000086};
87
88///////////////////////////////////////////////////////////////////////////////
89
joshualitt2e3b3e32014-12-09 13:31:14 -080090GrBitmapTextGeoProc::GrBitmapTextGeoProc(GrColor color, GrTexture* texture,
joshualitt56995b52014-12-11 15:44:02 -080091 const GrTextureParams& params, bool useColorAttrib,
92 bool opaqueVertexColors)
93 : INHERITED(color, opaqueVertexColors), fTextureAccess(texture, params), fInColor(NULL) {
egdaniel309e3462014-12-09 10:35:58 -080094 this->initClassID<GrBitmapTextGeoProc>();
joshualitt2dd1ae02014-12-03 06:24:10 -080095 fInPosition = &this->addVertexAttrib(GrAttribute("inPosition", kVec2f_GrVertexAttribType));
egdaniel309e3462014-12-09 10:35:58 -080096 if (useColorAttrib) {
joshualitt2dd1ae02014-12-03 06:24:10 -080097 fInColor = &this->addVertexAttrib(GrAttribute("inColor", kVec4ub_GrVertexAttribType));
98 this->setHasVertexColor();
99 }
100 fInTextureCoords = &this->addVertexAttrib(GrAttribute("inTextureCoords",
101 kVec2f_GrVertexAttribType));
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000102 this->addTextureAccess(&fTextureAccess);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000103}
104
egdaniel309e3462014-12-09 10:35:58 -0800105bool GrBitmapTextGeoProc::onIsEqual(const GrGeometryProcessor& other) const {
106 const GrBitmapTextGeoProc& gp = other.cast<GrBitmapTextGeoProc>();
joshualitt2dd1ae02014-12-03 06:24:10 -0800107 return SkToBool(this->inColor()) == SkToBool(gp.inColor());
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000108}
109
joshualitt56995b52014-12-11 15:44:02 -0800110void GrBitmapTextGeoProc::onGetInvariantOutputCoverage(GrInitInvariantOutput* out) const {
egdanielf8449ba2014-11-25 10:24:56 -0800111 if (GrPixelConfigIsAlphaOnly(this->texture(0)->config())) {
joshualitt56995b52014-12-11 15:44:02 -0800112 out->setUnknownSingleComponent();
egdanielf8449ba2014-11-25 10:24:56 -0800113 } else if (GrPixelConfigIsOpaque(this->texture(0)->config())) {
joshualitt56995b52014-12-11 15:44:02 -0800114 out->setUnknownOpaqueFourComponents();
115 out->setUsingLCDCoverage();
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000116 } else {
joshualitt56995b52014-12-11 15:44:02 -0800117 out->setUnknownFourComponents();
118 out->setUsingLCDCoverage();
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000119 }
120}
121
egdaniel309e3462014-12-09 10:35:58 -0800122void GrBitmapTextGeoProc::getGLProcessorKey(const GrBatchTracker& bt,
123 const GrGLCaps& caps,
124 GrProcessorKeyBuilder* b) const {
125 GrGLBitmapTextGeoProc::GenKey(*this, bt, caps, b);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000126}
127
joshualitteb2a6762014-12-04 11:35:33 -0800128GrGLGeometryProcessor*
egdaniel309e3462014-12-09 10:35:58 -0800129GrBitmapTextGeoProc::createGLInstance(const GrBatchTracker& bt) const {
130 return SkNEW_ARGS(GrGLBitmapTextGeoProc, (*this, bt));
joshualitteb2a6762014-12-04 11:35:33 -0800131}
joshualitt9b989322014-12-15 14:16:27 -0800132
133void GrBitmapTextGeoProc::initBatchTracker(GrBatchTracker* bt, const InitBT& init) const {
134 BitmapTextBatchTracker* local = bt->cast<BitmapTextBatchTracker>();
135 local->fInputColorType = GetColorInputType(&local->fColor, this->color(), init,
136 SkToBool(fInColor));
137}
138
139bool GrBitmapTextGeoProc::onCanMakeEqual(const GrBatchTracker& m, const GrBatchTracker& t) const {
140 const BitmapTextBatchTracker& mine = m.cast<BitmapTextBatchTracker>();
141 const BitmapTextBatchTracker& theirs = t.cast<BitmapTextBatchTracker>();
142 return CanCombineOutput(mine.fInputColorType, mine.fColor,
143 theirs.fInputColorType, theirs.fColor);
144}
145
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000146///////////////////////////////////////////////////////////////////////////////
147
egdaniel309e3462014-12-09 10:35:58 -0800148GR_DEFINE_GEOMETRY_PROCESSOR_TEST(GrBitmapTextGeoProc);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000149
egdaniel309e3462014-12-09 10:35:58 -0800150GrGeometryProcessor* GrBitmapTextGeoProc::TestCreate(SkRandom* random,
151 GrContext*,
152 const GrDrawTargetCaps&,
153 GrTexture* textures[]) {
joshualittb0a8a372014-09-23 09:50:21 -0700154 int texIdx = random->nextBool() ? GrProcessorUnitTest::kSkiaPMTextureIdx :
155 GrProcessorUnitTest::kAlphaTextureIdx;
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000156 static const SkShader::TileMode kTileModes[] = {
157 SkShader::kClamp_TileMode,
158 SkShader::kRepeat_TileMode,
159 SkShader::kMirror_TileMode,
160 };
161 SkShader::TileMode tileModes[] = {
162 kTileModes[random->nextULessThan(SK_ARRAY_COUNT(kTileModes))],
163 kTileModes[random->nextULessThan(SK_ARRAY_COUNT(kTileModes))],
164 };
165 GrTextureParams params(tileModes, random->nextBool() ? GrTextureParams::kBilerp_FilterMode :
166 GrTextureParams::kNone_FilterMode);
167
joshualitt2e3b3e32014-12-09 13:31:14 -0800168 return GrBitmapTextGeoProc::Create(GrRandomColor(random), textures[texIdx], params,
joshualitt56995b52014-12-11 15:44:02 -0800169 random->nextBool(), random->nextBool());
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000170}