Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(366)

Side by Side Diff: src/gpu/effects/GrBitmapTextGeoProc.cpp

Issue 1885863004: Refactor how we store and use samplers in Ganesh (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: Created 4 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * Copyright 2013 Google Inc. 2 * Copyright 2013 Google Inc.
3 * 3 *
4 * Use of this source code is governed by a BSD-style license that can be 4 * Use of this source code is governed by a BSD-style license that can be
5 * found in the LICENSE file. 5 * found in the LICENSE file.
6 */ 6 */
7 7
8 #include "GrBitmapTextGeoProc.h" 8 #include "GrBitmapTextGeoProc.h"
9 #include "GrInvariantOutput.h" 9 #include "GrInvariantOutput.h"
10 #include "GrTexture.h" 10 #include "GrTexture.h"
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
56 // emit transforms 56 // emit transforms
57 this->emitTransforms(vertBuilder, 57 this->emitTransforms(vertBuilder,
58 varyingHandler, 58 varyingHandler,
59 uniformHandler, 59 uniformHandler,
60 gpArgs->fPositionVar, 60 gpArgs->fPositionVar,
61 cte.inPosition()->fName, 61 cte.inPosition()->fName,
62 cte.localMatrix(), 62 cte.localMatrix(),
63 args.fTransformsIn, 63 args.fTransformsIn,
64 args.fTransformsOut); 64 args.fTransformsOut);
65 65
66 const GrGLSLSampler& sampler = uniformHandler->getSampler(args.fTexSampl ers[0]);
66 if (cte.maskFormat() == kARGB_GrMaskFormat) { 67 if (cte.maskFormat() == kARGB_GrMaskFormat) {
67 fragBuilder->codeAppendf("%s = ", args.fOutputColor); 68 fragBuilder->codeAppendf("%s = ", args.fOutputColor);
68 fragBuilder->appendTextureLookupAndModulate(args.fOutputColor, 69 fragBuilder->appendTextureLookupAndModulate(args.fOutputColor,
69 args.fTexSamplers[0], 70 sampler,
70 v.fsIn(), 71 v.fsIn(),
71 kVec2f_GrSLType); 72 kVec2f_GrSLType);
72 fragBuilder->codeAppend(";"); 73 fragBuilder->codeAppend(";");
73 fragBuilder->codeAppendf("%s = vec4(1);", args.fOutputCoverage); 74 fragBuilder->codeAppendf("%s = vec4(1);", args.fOutputCoverage);
74 } else { 75 } else {
75 fragBuilder->codeAppendf("%s = ", args.fOutputCoverage); 76 fragBuilder->codeAppendf("%s = ", args.fOutputCoverage);
76 fragBuilder->appendTextureLookup(args.fTexSamplers[0], v.fsIn(), kVe c2f_GrSLType); 77 fragBuilder->appendTextureLookup(sampler, v.fsIn(), kVec2f_GrSLType) ;
77 fragBuilder->codeAppend(";"); 78 fragBuilder->codeAppend(";");
78 if (cte.maskFormat() == kA565_GrMaskFormat) { 79 if (cte.maskFormat() == kA565_GrMaskFormat) {
79 // set alpha to be max of rgb coverage 80 // set alpha to be max of rgb coverage
80 fragBuilder->codeAppendf("%s.a = max(max(%s.r, %s.g), %s.b);", 81 fragBuilder->codeAppendf("%s.a = max(max(%s.r, %s.g), %s.b);",
81 args.fOutputCoverage, args.fOutputCover age, 82 args.fOutputCoverage, args.fOutputCover age,
82 args.fOutputCoverage, args.fOutputCover age); 83 args.fOutputCoverage, args.fOutputCover age);
83 } 84 }
84 } 85 }
85 } 86 }
86 87
(...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after
189 break; 190 break;
190 case 2: 191 case 2:
191 format = kARGB_GrMaskFormat; 192 format = kARGB_GrMaskFormat;
192 break; 193 break;
193 } 194 }
194 195
195 return GrBitmapTextGeoProc::Create(GrRandomColor(d->fRandom), d->fTextures[t exIdx], params, 196 return GrBitmapTextGeoProc::Create(GrRandomColor(d->fRandom), d->fTextures[t exIdx], params,
196 format, GrTest::TestMatrix(d->fRandom), 197 format, GrTest::TestMatrix(d->fRandom),
197 d->fRandom->nextBool()); 198 d->fRandom->nextBool());
198 } 199 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698