OLD | NEW |
1 | 1 |
2 /* | 2 /* |
3 * Copyright 2014 Google Inc. | 3 * Copyright 2014 Google Inc. |
4 * | 4 * |
5 * Use of this source code is governed by a BSD-style license that can be | 5 * Use of this source code is governed by a BSD-style license that can be |
6 * found in the LICENSE file. | 6 * found in the LICENSE file. |
7 */ | 7 */ |
8 | 8 |
9 #include "effects/GrCoverageSetOpXP.h" | 9 #include "effects/GrCoverageSetOpXP.h" |
10 #include "GrCaps.h" | 10 #include "GrCaps.h" |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
65 static void GenKey(const GrProcessor& processor, const GrGLSLCaps& caps, | 65 static void GenKey(const GrProcessor& processor, const GrGLSLCaps& caps, |
66 GrProcessorKeyBuilder* b) { | 66 GrProcessorKeyBuilder* b) { |
67 const CoverageSetOpXP& xp = processor.cast<CoverageSetOpXP>(); | 67 const CoverageSetOpXP& xp = processor.cast<CoverageSetOpXP>(); |
68 uint32_t key = xp.invertCoverage() ? 0x0 : 0x1; | 68 uint32_t key = xp.invertCoverage() ? 0x0 : 0x1; |
69 b->add32(key); | 69 b->add32(key); |
70 }; | 70 }; |
71 | 71 |
72 private: | 72 private: |
73 void emitOutputsForBlendState(const EmitArgs& args) override { | 73 void emitOutputsForBlendState(const EmitArgs& args) override { |
74 const CoverageSetOpXP& xp = args.fXP.cast<CoverageSetOpXP>(); | 74 const CoverageSetOpXP& xp = args.fXP.cast<CoverageSetOpXP>(); |
75 GrGLSLXPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder(
); | 75 GrGLSLXPFragmentBuilder* fragBuilder = args.fXPFragBuilder; |
76 | 76 |
77 if (xp.invertCoverage()) { | 77 if (xp.invertCoverage()) { |
78 fsBuilder->codeAppendf("%s = 1.0 - %s;", args.fOutputPrimary, args.f
InputCoverage); | 78 fragBuilder->codeAppendf("%s = 1.0 - %s;", args.fOutputPrimary, args
.fInputCoverage); |
79 } else { | 79 } else { |
80 fsBuilder->codeAppendf("%s = %s;", args.fOutputPrimary, args.fInputC
overage); | 80 fragBuilder->codeAppendf("%s = %s;", args.fOutputPrimary, args.fInpu
tCoverage); |
81 } | 81 } |
82 } | 82 } |
83 | 83 |
84 void onSetData(const GrGLSLProgramDataManager&, const GrXferProcessor&) over
ride {}; | 84 void onSetData(const GrGLSLProgramDataManager&, const GrXferProcessor&) over
ride {}; |
85 | 85 |
86 typedef GrGLSLXferProcessor INHERITED; | 86 typedef GrGLSLXferProcessor INHERITED; |
87 }; | 87 }; |
88 | 88 |
89 /////////////////////////////////////////////////////////////////////////////// | 89 /////////////////////////////////////////////////////////////////////////////// |
90 | 90 |
(...skipping 154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
245 } | 245 } |
246 | 246 |
247 GR_DEFINE_XP_FACTORY_TEST(GrCoverageSetOpXPFactory); | 247 GR_DEFINE_XP_FACTORY_TEST(GrCoverageSetOpXPFactory); |
248 | 248 |
249 const GrXPFactory* GrCoverageSetOpXPFactory::TestCreate(GrProcessorTestData* d)
{ | 249 const GrXPFactory* GrCoverageSetOpXPFactory::TestCreate(GrProcessorTestData* d)
{ |
250 SkRegion::Op regionOp = SkRegion::Op(d->fRandom->nextULessThan(SkRegion::kLa
stOp + 1)); | 250 SkRegion::Op regionOp = SkRegion::Op(d->fRandom->nextULessThan(SkRegion::kLa
stOp + 1)); |
251 bool invertCoverage = !d->fRenderTarget->hasMixedSamples() && d->fRandom->ne
xtBool(); | 251 bool invertCoverage = !d->fRenderTarget->hasMixedSamples() && d->fRandom->ne
xtBool(); |
252 return GrCoverageSetOpXPFactory::Create(regionOp, invertCoverage); | 252 return GrCoverageSetOpXPFactory::Create(regionOp, invertCoverage); |
253 } | 253 } |
254 | 254 |
OLD | NEW |