blob: ad06792fb5ac2afe3c7b70727bba3f6540d82dbd [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"
jvanverth5a105ff2015-02-18 11:36:35 -08009#include "GrFontAtlasSizes.h"
egdaniel605dd0f2014-11-12 08:35:25 -080010#include "GrInvariantOutput.h"
joshualitteb2a6762014-12-04 11:35:33 -080011#include "GrTexture.h"
joshualittb0a8a372014-09-23 09:50:21 -070012#include "gl/GrGLProcessor.h"
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000013#include "gl/GrGLSL.h"
14#include "gl/GrGLTexture.h"
joshualitt249af152014-09-15 11:41:13 -070015#include "gl/GrGLGeometryProcessor.h"
joshualitteb2a6762014-12-04 11:35:33 -080016#include "gl/builders/GrGLProgramBuilder.h"
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000017
egdaniel309e3462014-12-09 10:35:58 -080018class GrGLBitmapTextGeoProc : public GrGLGeometryProcessor {
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000019public:
joshualitt9b989322014-12-15 14:16:27 -080020 GrGLBitmapTextGeoProc(const GrGeometryProcessor&, const GrBatchTracker&)
21 : fColor(GrColor_ILLEGAL) {}
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000022
mtklein36352bf2015-03-25 18:17:31 -070023 void onEmitCode(EmitArgs& args, GrGPArgs* gpArgs) override{
egdaniel309e3462014-12-09 10:35:58 -080024 const GrBitmapTextGeoProc& cte = args.fGP.cast<GrBitmapTextGeoProc>();
joshualitt2dd1ae02014-12-03 06:24:10 -080025
joshualitt9b989322014-12-15 14:16:27 -080026 GrGLGPBuilder* pb = args.fPB;
27 GrGLVertexBuilder* vsBuilder = pb->getVertexShaderBuilder();
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000028
joshualittabb52a12015-01-13 15:02:10 -080029 // emit attributes
30 vsBuilder->emitAttributes(cte);
31
joshualitt74077b92014-10-24 11:26:03 -070032 GrGLVertToFrag v(kVec2f_GrSLType);
joshualitt9b989322014-12-15 14:16:27 -080033 pb->addVarying("TextureCoords", &v);
jvanverth5a105ff2015-02-18 11:36:35 -080034 // this is only used with text, so our texture bounds always match the glyph atlas
jvanverthcb251f12015-03-11 11:18:11 -070035 if (cte.maskFormat() == kA8_GrMaskFormat) {
36 vsBuilder->codeAppendf("%s = vec2(" GR_FONT_ATLAS_A8_RECIP_WIDTH ", "
37 GR_FONT_ATLAS_RECIP_HEIGHT ")*%s;", v.vsOut(),
38 cte.inTextureCoords()->fName);
39 } else {
40 vsBuilder->codeAppendf("%s = vec2(" GR_FONT_ATLAS_RECIP_WIDTH ", "
41 GR_FONT_ATLAS_RECIP_HEIGHT ")*%s;", v.vsOut(),
42 cte.inTextureCoords()->fName);
43 }
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000044
joshualitt9b989322014-12-15 14:16:27 -080045 // Setup pass through color
joshualittb8c241a2015-05-19 08:23:30 -070046 if (!cte.colorIgnored()) {
47 if (cte.hasVertexColor()) {
48 pb->addPassThroughAttribute(cte.inColor(), args.fOutputColor);
49 } else {
50 this->setupUniformColor(pb, args.fOutputColor, &fColorUniform);
51 }
52 }
joshualitt2dd1ae02014-12-03 06:24:10 -080053
joshualittabb52a12015-01-13 15:02:10 -080054 // Setup position
joshualitte578a952015-05-14 10:09:13 -070055 this->setupPosition(pb, gpArgs, cte.inPosition()->fName);
joshualitt4973d9d2014-11-08 09:24:25 -080056
joshualittabb52a12015-01-13 15:02:10 -080057 // emit transforms
robertphillips46d36f02015-01-18 08:14:14 -080058 this->emitTransforms(args.fPB, gpArgs->fPositionVar, cte.inPosition()->fName,
joshualittabb52a12015-01-13 15:02:10 -080059 cte.localMatrix(), args.fTransformsIn, args.fTransformsOut);
60
egdaniel29bee0f2015-04-29 11:54:42 -070061 GrGLFragmentBuilder* fsBuilder = pb->getFragmentShaderBuilder();
joshualitt02b05012015-02-11 06:56:30 -080062 if (cte.maskFormat() == kARGB_GrMaskFormat) {
63 fsBuilder->codeAppendf("%s = ", args.fOutputColor);
64 fsBuilder->appendTextureLookupAndModulate(args.fOutputColor,
65 args.fSamplers[0],
66 v.fsIn(),
67 kVec2f_GrSLType);
68 fsBuilder->codeAppend(";");
69 fsBuilder->codeAppendf("%s = vec4(1);", args.fOutputCoverage);
70 } else {
71 fsBuilder->codeAppendf("%s = ", args.fOutputCoverage);
72 fsBuilder->appendTextureLookup(args.fSamplers[0], v.fsIn(), kVec2f_GrSLType);
73 fsBuilder->codeAppend(";");
74 }
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +000075 }
76
joshualitt9b989322014-12-15 14:16:27 -080077 virtual void setData(const GrGLProgramDataManager& pdman,
78 const GrPrimitiveProcessor& gp,
mtklein36352bf2015-03-25 18:17:31 -070079 const GrBatchTracker& bt) override {
joshualittb8c241a2015-05-19 08:23:30 -070080 const GrBitmapTextGeoProc& btgp = gp.cast<GrBitmapTextGeoProc>();
81 if (btgp.color() != fColor && !btgp.hasVertexColor()) {
joshualitt9b989322014-12-15 14:16:27 -080082 GrGLfloat c[4];
joshualittb8c241a2015-05-19 08:23:30 -070083 GrColorToRGBAFloat(btgp.color(), c);
joshualitt9b989322014-12-15 14:16:27 -080084 pdman.set4fv(fColorUniform, 1, c);
joshualittb8c241a2015-05-19 08:23:30 -070085 fColor = btgp.color();
joshualitt9b989322014-12-15 14:16:27 -080086 }
joshualitt2dd1ae02014-12-03 06:24:10 -080087 }
88
joshualitte3ababe2015-05-15 07:56:07 -070089 void setTransformData(const GrPrimitiveProcessor& primProc,
90 const GrGLProgramDataManager& pdman,
91 int index,
92 const SkTArray<const GrCoordTransform*, true>& transforms) override {
93 this->setTransformDataHelper<GrBitmapTextGeoProc>(primProc, pdman, index, transforms);
94 }
95
joshualitt9b989322014-12-15 14:16:27 -080096 static inline void GenKey(const GrGeometryProcessor& proc,
97 const GrBatchTracker& bt,
jvanverthcfc18862015-04-28 08:48:20 -070098 const GrGLSLCaps&,
joshualitt9b989322014-12-15 14:16:27 -080099 GrProcessorKeyBuilder* b) {
joshualitt9b989322014-12-15 14:16:27 -0800100 const GrBitmapTextGeoProc& gp = proc.cast<GrBitmapTextGeoProc>();
joshualitt8fc6c2d2014-12-22 15:27:05 -0800101 uint32_t key = 0;
joshualittb8c241a2015-05-19 08:23:30 -0700102 key |= gp.usesLocalCoords() && gp.localMatrix().hasPerspective() ? 0x1 : 0x0;
103 key |= gp.colorIgnored() ? 0x2 : 0x0;
104 key |= gp.maskFormat() << 3;
105 b->add32(key);
joshualitt9b989322014-12-15 14:16:27 -0800106 }
joshualitt2dd1ae02014-12-03 06:24:10 -0800107
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000108private:
joshualitt9b989322014-12-15 14:16:27 -0800109 GrColor fColor;
110 UniformHandle fColorUniform;
111
joshualitt249af152014-09-15 11:41:13 -0700112 typedef GrGLGeometryProcessor INHERITED;
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000113};
114
115///////////////////////////////////////////////////////////////////////////////
116
joshualitt2e3b3e32014-12-09 13:31:14 -0800117GrBitmapTextGeoProc::GrBitmapTextGeoProc(GrColor color, GrTexture* texture,
joshualitt02b05012015-02-11 06:56:30 -0800118 const GrTextureParams& params, GrMaskFormat format,
joshualittb8c241a2015-05-19 08:23:30 -0700119 const SkMatrix& localMatrix, bool usesLocalCoords)
joshualitte3ababe2015-05-15 07:56:07 -0700120 : fColor(color)
121 , fLocalMatrix(localMatrix)
joshualittb8c241a2015-05-19 08:23:30 -0700122 , fUsesLocalCoords(usesLocalCoords)
joshualitt8fc6c2d2014-12-22 15:27:05 -0800123 , fTextureAccess(texture, params)
joshualitt02b05012015-02-11 06:56:30 -0800124 , fInColor(NULL)
125 , fMaskFormat(format) {
egdaniel309e3462014-12-09 10:35:58 -0800126 this->initClassID<GrBitmapTextGeoProc>();
joshualitt71c92602015-01-14 08:12:47 -0800127 fInPosition = &this->addVertexAttrib(Attribute("inPosition", kVec2f_GrVertexAttribType));
joshualitt02b05012015-02-11 06:56:30 -0800128
joshualittb8c241a2015-05-19 08:23:30 -0700129 // TODO we could think about removing this attribute if color is ignored, but unfortunately
130 // we don't do text positioning in batch, so we can't quite do that yet.
joshualitt02b05012015-02-11 06:56:30 -0800131 bool hasVertexColor = kA8_GrMaskFormat == fMaskFormat;
132 if (hasVertexColor) {
joshualitt71c92602015-01-14 08:12:47 -0800133 fInColor = &this->addVertexAttrib(Attribute("inColor", kVec4ub_GrVertexAttribType));
joshualitt2dd1ae02014-12-03 06:24:10 -0800134 }
joshualitt71c92602015-01-14 08:12:47 -0800135 fInTextureCoords = &this->addVertexAttrib(Attribute("inTextureCoords",
jvanverth5a105ff2015-02-18 11:36:35 -0800136 kVec2s_GrVertexAttribType));
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000137 this->addTextureAccess(&fTextureAccess);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000138}
139
egdaniel309e3462014-12-09 10:35:58 -0800140void GrBitmapTextGeoProc::getGLProcessorKey(const GrBatchTracker& bt,
jvanverthcfc18862015-04-28 08:48:20 -0700141 const GrGLSLCaps& caps,
egdaniel309e3462014-12-09 10:35:58 -0800142 GrProcessorKeyBuilder* b) const {
143 GrGLBitmapTextGeoProc::GenKey(*this, bt, caps, b);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000144}
145
joshualittabb52a12015-01-13 15:02:10 -0800146GrGLPrimitiveProcessor*
147GrBitmapTextGeoProc::createGLInstance(const GrBatchTracker& bt,
jvanverthcfc18862015-04-28 08:48:20 -0700148 const GrGLSLCaps& caps) const {
egdaniel309e3462014-12-09 10:35:58 -0800149 return SkNEW_ARGS(GrGLBitmapTextGeoProc, (*this, bt));
joshualitteb2a6762014-12-04 11:35:33 -0800150}
joshualitt9b989322014-12-15 14:16:27 -0800151
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000152///////////////////////////////////////////////////////////////////////////////
153
egdaniel309e3462014-12-09 10:35:58 -0800154GR_DEFINE_GEOMETRY_PROCESSOR_TEST(GrBitmapTextGeoProc);
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000155
egdaniel309e3462014-12-09 10:35:58 -0800156GrGeometryProcessor* GrBitmapTextGeoProc::TestCreate(SkRandom* random,
157 GrContext*,
158 const GrDrawTargetCaps&,
159 GrTexture* textures[]) {
joshualittb0a8a372014-09-23 09:50:21 -0700160 int texIdx = random->nextBool() ? GrProcessorUnitTest::kSkiaPMTextureIdx :
161 GrProcessorUnitTest::kAlphaTextureIdx;
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000162 static const SkShader::TileMode kTileModes[] = {
163 SkShader::kClamp_TileMode,
164 SkShader::kRepeat_TileMode,
165 SkShader::kMirror_TileMode,
166 };
167 SkShader::TileMode tileModes[] = {
168 kTileModes[random->nextULessThan(SK_ARRAY_COUNT(kTileModes))],
169 kTileModes[random->nextULessThan(SK_ARRAY_COUNT(kTileModes))],
170 };
171 GrTextureParams params(tileModes, random->nextBool() ? GrTextureParams::kBilerp_FilterMode :
172 GrTextureParams::kNone_FilterMode);
173
joshualitt02b05012015-02-11 06:56:30 -0800174 GrMaskFormat format;
175 switch (random->nextULessThan(3)) {
176 default:
177 SkFAIL("Incomplete enum\n");
178 case 0:
179 format = kA8_GrMaskFormat;
180 break;
181 case 1:
182 format = kA565_GrMaskFormat;
183 break;
184 case 2:
185 format = kARGB_GrMaskFormat;
186 break;
187 }
188
joshualitt2e3b3e32014-12-09 13:31:14 -0800189 return GrBitmapTextGeoProc::Create(GrRandomColor(random), textures[texIdx], params,
joshualittb8c241a2015-05-19 08:23:30 -0700190 format, GrTest::TestMatrix(random), random->nextBool());
commit-bot@chromium.org76eaf742013-09-30 18:41:38 +0000191}