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