blob: 5277d31611678f6e9da12841fb80ee25756fca05 [file] [log] [blame]
Jim Van Verth6a7a7042017-09-11 11:04:10 -04001/*
2 * Copyright 2017 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
8#ifndef GrAtlasedShaderHelpers_DEFINED
9#define GrAtlasedShaderHelpers_DEFINED
10
11#include "glsl/GrGLSLPrimitiveProcessor.h"
12#include "glsl/GrGLSLFragmentShaderBuilder.h"
13#include "glsl/GrGLSLVarying.h"
14#include "glsl/GrGLSLVertexShaderBuilder.h"
15
16static void append_index_uv_varyings(GrGLSLPrimitiveProcessor::EmitArgs& args,
17 const char* inTexCoordsName,
18 const char* atlasSizeInvName,
19 GrGLSLVertToFrag *uv,
20 GrGLSLVertToFrag *texIdx,
21 GrGLSLVertToFrag *st) {
22 // This extracts the texture index and texel coordinates from the same variable
23 // Packing structure: texel coordinates are multiplied by 2 (or shifted left 1)
24 // texture index is stored as lower bits of both x and y
Ethan Nicholasf7b88202017-09-18 14:10:39 -040025 args.fVertBuilder->codeAppendf("half2 indexTexCoords = half2(%s.x, %s.y);",
Jim Van Verth6a7a7042017-09-11 11:04:10 -040026 inTexCoordsName, inTexCoordsName);
Ethan Nicholasf7b88202017-09-18 14:10:39 -040027 args.fVertBuilder->codeAppend("half2 intCoords = floor(0.5*indexTexCoords);");
28 args.fVertBuilder->codeAppend("half2 diff = indexTexCoords - 2.0*intCoords;");
29 args.fVertBuilder->codeAppend("half texIdx = 2.0*diff.x + diff.y;");
Jim Van Verth6a7a7042017-09-11 11:04:10 -040030
31 // Multiply by 1/atlasSize to get normalized texture coordinates
Chris Daltonfdde34e2017-10-16 14:15:26 -060032 args.fVaryingHandler->addVarying("TextureCoords", uv);
Jim Van Verth6a7a7042017-09-11 11:04:10 -040033 args.fVertBuilder->codeAppendf("%s = intCoords * %s;", uv->vsOut(), atlasSizeInvName);
34
35 args.fVaryingHandler->addVarying("TexIndex", texIdx);
36 args.fVertBuilder->codeAppendf("%s = texIdx;", texIdx->vsOut());
37
38 if (st) {
Chris Daltonfdde34e2017-10-16 14:15:26 -060039 args.fVaryingHandler->addVarying("IntTextureCoords", st);
Jim Van Verth6a7a7042017-09-11 11:04:10 -040040 args.fVertBuilder->codeAppendf("%s = intCoords;", st->vsOut());
41 }
42}
43
44static void append_multitexture_lookup(GrGLSLPrimitiveProcessor::EmitArgs& args,
45 int numTextureSamplers,
46 const GrGLSLVertToFrag &texIdx,
47 const char* coordName,
48 const char* colorName) {
49 // conditionally load from the indexed texture sampler
Jim Van Vertheafa64b2017-09-18 10:05:00 -040050 for (int i = 0; i < numTextureSamplers-1; ++i) {
51 args.fFragBuilder->codeAppendf("if (%s == %d) { %s = ", texIdx.fsIn(), i, colorName);
Ethan Nicholasf7b88202017-09-18 14:10:39 -040052 args.fFragBuilder->appendTextureLookup(args.fTexSamplers[i], coordName,
Ethan Nicholas8aa45692017-09-20 11:24:15 -040053 kFloat2_GrSLType);
Jim Van Vertheafa64b2017-09-18 10:05:00 -040054 args.fFragBuilder->codeAppend("; } else ");
Jim Van Verth6a7a7042017-09-11 11:04:10 -040055 }
56 args.fFragBuilder->codeAppendf("{ %s = ", colorName);
Jim Van Vertheafa64b2017-09-18 10:05:00 -040057 args.fFragBuilder->appendTextureLookup(args.fTexSamplers[numTextureSamplers-1], coordName,
Ethan Nicholas8aa45692017-09-20 11:24:15 -040058 kFloat2_GrSLType);
Jim Van Verth6a7a7042017-09-11 11:04:10 -040059 args.fFragBuilder->codeAppend("; }");
Jim Van Verth6a7a7042017-09-11 11:04:10 -040060}
61
62#endif