OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2014 Google Inc. | 2 * Copyright 2014 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 "GrGLFragmentShaderBuilder.h" | 8 #include "GrGLFragmentShaderBuilder.h" |
9 #include "GrGLShaderStringBuilder.h" | 9 #include "GrGLShaderStringBuilder.h" |
10 #include "GrGLProgramBuilder.h" | 10 #include "GrGLProgramBuilder.h" |
(...skipping 286 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
297 declared_color_output_name()); | 297 declared_color_output_name()); |
298 fHasCustomColorOutput = true; | 298 fHasCustomColorOutput = true; |
299 } | 299 } |
300 } | 300 } |
301 | 301 |
302 void GrGLFragmentShaderBuilder::emitCodeAfterEffects(const GrGLSLExpr4& inputCol
or, const GrGLSLExpr4& inputCoverage) { | 302 void GrGLFragmentShaderBuilder::emitCodeAfterEffects(const GrGLSLExpr4& inputCol
or, const GrGLSLExpr4& inputCoverage) { |
303 const GrGLProgramDesc::KeyHeader& header = fProgramBuilder->desc().getHeader
(); | 303 const GrGLProgramDesc::KeyHeader& header = fProgramBuilder->desc().getHeader
(); |
304 | 304 |
305 /////////////////////////////////////////////////////////////////////////// | 305 /////////////////////////////////////////////////////////////////////////// |
306 // write the secondary color output if necessary | 306 // write the secondary color output if necessary |
307 if (GrGLProgramDesc::CoverageOutputUsesSecondaryOutput(header.fCoverageOutpu
t)) { | 307 if (GrOptDrawState::kNone_SecondaryOutputType != header.fSecondaryOutputType
) { |
308 const char* secondaryOutputName = this->enableSecondaryOutput(); | 308 const char* secondaryOutputName = this->enableSecondaryOutput(); |
309 | |
310 // default coeff to ones for kCoverage_DualSrcOutput | |
311 GrGLSLExpr4 coeff(1); | 309 GrGLSLExpr4 coeff(1); |
312 if (GrGLProgramDesc::kSecondaryCoverageISA_CoverageOutput == header.fCov
erageOutput) { | 310 switch (header.fSecondaryOutputType) { |
313 // Get (1-A) into coeff | 311 case GrOptDrawState::kCoverage_SecondaryOutputType: |
314 coeff = GrGLSLExpr4::VectorCast(GrGLSLExpr1(1) - inputColor.a()); | 312 break; |
315 } else if (GrGLProgramDesc::kSecondaryCoverageISC_CoverageOutput == | 313 case GrOptDrawState::kCoverageISA_SecondaryOutputType: |
316 header.fCoverageOutput){ | 314 // Get (1-A) into coeff |
317 // Get (1-RGBA) into coeff | 315 coeff = GrGLSLExpr4::VectorCast(GrGLSLExpr1(1) - inputColor.a())
; |
318 coeff = GrGLSLExpr4(1) - inputColor; | 316 break; |
| 317 case GrOptDrawState::kCoverageISC_SecondaryOutputType: |
| 318 // Get (1-RGBA) into coeff |
| 319 coeff = GrGLSLExpr4(1) - inputColor; |
| 320 break; |
| 321 default: |
| 322 SkFAIL("Unexpected Secondary Output"); |
319 } | 323 } |
320 // Get coeff * coverage into modulate and then write that to the dual so
urce output. | 324 // Get coeff * coverage into modulate and then write that to the dual so
urce output. |
321 codeAppendf("\t%s = %s;\n", secondaryOutputName, (coeff * inputCoverage)
.c_str()); | 325 codeAppendf("\t%s = %s;\n", secondaryOutputName, (coeff * inputCoverage)
.c_str()); |
322 } | 326 } |
323 | 327 |
324 /////////////////////////////////////////////////////////////////////////// | 328 /////////////////////////////////////////////////////////////////////////// |
325 // combine color and coverage as frag color | 329 // combine color and coverage as frag color |
326 | 330 |
327 // Get "color * coverage" into fragColor | 331 // Get "color * coverage" into fragColor |
328 GrGLSLExpr4 fragColor = inputColor * inputCoverage; | 332 GrGLSLExpr4 fragColor = inputColor * inputCoverage; |
329 // Now tack on "+(1-coverage)dst onto the frag color if we were asked to do
so. | 333 switch (header.fPrimaryOutputType) { |
330 if (GrGLProgramDesc::kCombineWithDst_CoverageOutput == header.fCoverageOutpu
t) { | 334 case GrOptDrawState::kModulate_PrimaryOutputType: |
331 GrGLSLExpr4 dstCoeff = GrGLSLExpr4(1) - inputCoverage; | 335 break; |
332 | 336 case GrOptDrawState::kCombineWithDst_PrimaryOutputType: |
333 GrGLSLExpr4 dstContribution = dstCoeff * GrGLSLExpr4(dstColor()); | 337 { |
334 | 338 // Tack on "+(1-coverage)dst onto the frag color. |
335 fragColor = fragColor + dstContribution; | 339 GrGLSLExpr4 dstCoeff = GrGLSLExpr4(1) - inputCoverage; |
| 340 GrGLSLExpr4 dstContribution = dstCoeff * GrGLSLExpr4(dstColor())
; |
| 341 fragColor = fragColor + dstContribution; |
| 342 } |
| 343 break; |
| 344 default: |
| 345 SkFAIL("Unknown Primary Output"); |
336 } | 346 } |
337 codeAppendf("\t%s = %s;\n", this->getColorOutputName(), fragColor.c_str()); | 347 codeAppendf("\t%s = %s;\n", this->getColorOutputName(), fragColor.c_str()); |
338 } | 348 } |
339 | 349 |
340 const char* GrGLFragmentShaderBuilder::enableSecondaryOutput() { | 350 const char* GrGLFragmentShaderBuilder::enableSecondaryOutput() { |
341 if (!fHasSecondaryOutput) { | 351 if (!fHasSecondaryOutput) { |
342 fOutputs.push_back().set(kVec4f_GrSLType, | 352 fOutputs.push_back().set(kVec4f_GrSLType, |
343 GrGLShaderVar::kOut_TypeModifier, | 353 GrGLShaderVar::kOut_TypeModifier, |
344 dual_source_output_name()); | 354 dual_source_output_name()); |
345 fHasSecondaryOutput = true; | 355 fHasSecondaryOutput = true; |
346 } | 356 } |
347 return dual_source_output_name(); | 357 return dual_source_output_name(); |
348 } | 358 } |
349 | 359 |
350 const char* GrGLFragmentShaderBuilder::getColorOutputName() const { | 360 const char* GrGLFragmentShaderBuilder::getColorOutputName() const { |
351 return fHasCustomColorOutput ? declared_color_output_name() : "gl_FragColor"
; | 361 return fHasCustomColorOutput ? declared_color_output_name() : "gl_FragColor"
; |
352 } | 362 } |
353 | 363 |
OLD | NEW |