OLD | NEW |
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 "GrGLProgramDesc.h" | 8 #include "GrGLProgramDesc.h" |
9 #include "GrBackendEffectFactory.h" | 9 #include "GrBackendEffectFactory.h" |
10 #include "GrDrawEffect.h" | 10 #include "GrDrawEffect.h" |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
69 desc->fCoverageInput = kTransBlack_ColorInput; | 69 desc->fCoverageInput = kTransBlack_ColorInput; |
70 } else if (covIsSolidWhite) { | 70 } else if (covIsSolidWhite) { |
71 desc->fCoverageInput = kSolidWhite_ColorInput; | 71 desc->fCoverageInput = kSolidWhite_ColorInput; |
72 } else if (GR_GL_NO_CONSTANT_ATTRIBUTES && !requiresCoverageAttrib) { | 72 } else if (GR_GL_NO_CONSTANT_ATTRIBUTES && !requiresCoverageAttrib) { |
73 desc->fCoverageInput = kUniform_ColorInput; | 73 desc->fCoverageInput = kUniform_ColorInput; |
74 } else { | 74 } else { |
75 desc->fCoverageInput = kAttribute_ColorInput; | 75 desc->fCoverageInput = kAttribute_ColorInput; |
76 } | 76 } |
77 | 77 |
78 bool readsDst = false; | 78 bool readsDst = false; |
| 79 bool readFragPosition = false; |
79 int lastEnabledStage = -1; | 80 int lastEnabledStage = -1; |
80 | 81 |
81 for (int s = 0; s < GrDrawState::kNumStages; ++s) { | 82 for (int s = 0; s < GrDrawState::kNumStages; ++s) { |
82 | 83 |
83 bool skip = s < drawState.getFirstCoverageStage() ? skipColor : skipCove
rage; | 84 bool skip = s < drawState.getFirstCoverageStage() ? skipColor : skipCove
rage; |
84 if (!skip && drawState.isStageEnabled(s)) { | 85 if (!skip && drawState.isStageEnabled(s)) { |
85 lastEnabledStage = s; | 86 lastEnabledStage = s; |
86 const GrEffectRef& effect = *drawState.getStage(s).getEffect(); | 87 const GrEffectRef& effect = *drawState.getStage(s).getEffect(); |
87 const GrBackendEffectFactory& factory = effect->getFactory(); | 88 const GrBackendEffectFactory& factory = effect->getFactory(); |
88 GrDrawEffect drawEffect(drawState.getStage(s), requiresLocalCoordAtt
rib); | 89 GrDrawEffect drawEffect(drawState.getStage(s), requiresLocalCoordAtt
rib); |
89 desc->fEffectKeys[s] = factory.glEffectKey(drawEffect, gpu->glCaps()
); | 90 desc->fEffectKeys[s] = factory.glEffectKey(drawEffect, gpu->glCaps()
); |
90 if (effect->willReadDstColor()) { | 91 if (effect->willReadDstColor()) { |
91 readsDst = true; | 92 readsDst = true; |
92 } | 93 } |
| 94 if (effect->willReadFragmentPosition()) { |
| 95 readFragPosition = true; |
| 96 } |
93 } else { | 97 } else { |
94 desc->fEffectKeys[s] = 0; | 98 desc->fEffectKeys[s] = 0; |
95 } | 99 } |
96 } | 100 } |
97 | 101 |
98 if (readsDst) { | 102 if (readsDst) { |
99 GrAssert(NULL != dstCopy || gpu->caps()->dstReadInShaderSupport()); | 103 GrAssert(NULL != dstCopy || gpu->caps()->dstReadInShaderSupport()); |
100 const GrTexture* dstCopyTexture = NULL; | 104 const GrTexture* dstCopyTexture = NULL; |
101 if (NULL != dstCopy) { | 105 if (NULL != dstCopy) { |
102 dstCopyTexture = dstCopy->texture(); | 106 dstCopyTexture = dstCopy->texture(); |
103 } | 107 } |
104 desc->fDstRead = GrGLShaderBuilder::KeyForDstRead(dstCopyTexture, gpu->g
lCaps()); | 108 desc->fDstReadKey = GrGLShaderBuilder::KeyForDstRead(dstCopyTexture, gpu
->glCaps()); |
105 GrAssert(0 != desc->fDstRead); | 109 GrAssert(0 != desc->fDstReadKey); |
106 } else { | 110 } else { |
107 desc->fDstRead = 0; | 111 desc->fDstReadKey = 0; |
| 112 } |
| 113 |
| 114 if (readFragPosition) { |
| 115 desc->fFragPosKey = GrGLShaderBuilder::KeyForFragmentPosition(drawState.
getRenderTarget(), |
| 116 gpu->glCap
s()); |
| 117 } else { |
| 118 desc->fFragPosKey = 0; |
108 } | 119 } |
109 | 120 |
110 desc->fCoverageOutput = kModulate_CoverageOutput; | 121 desc->fCoverageOutput = kModulate_CoverageOutput; |
111 | 122 |
112 // Currently the experimental GS will only work with triangle prims (and it
doesn't do anything | 123 // Currently the experimental GS will only work with triangle prims (and it
doesn't do anything |
113 // other than pass through values from the VS to the FS anyway). | 124 // other than pass through values from the VS to the FS anyway). |
114 #if GR_GL_EXPERIMENTAL_GS | 125 #if GR_GL_EXPERIMENTAL_GS |
115 #if 0 | 126 #if 0 |
116 desc->fExperimentalGS = gpu->caps().geometryShaderSupport(); | 127 desc->fExperimentalGS = gpu->caps().geometryShaderSupport(); |
117 #else | 128 #else |
(...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
191 | 202 |
192 if (requiresCoverageAttrib) { | 203 if (requiresCoverageAttrib) { |
193 desc->fCoverageAttributeIndex = drawState.coverageVertexAttributeIndex()
; | 204 desc->fCoverageAttributeIndex = drawState.coverageVertexAttributeIndex()
; |
194 } else if (GrGLProgramDesc::kAttribute_ColorInput == desc->fCoverageInput) { | 205 } else if (GrGLProgramDesc::kAttribute_ColorInput == desc->fCoverageInput) { |
195 GrAssert(availableAttributeIndex < GrDrawState::kMaxVertexAttribCnt); | 206 GrAssert(availableAttributeIndex < GrDrawState::kMaxVertexAttribCnt); |
196 desc->fCoverageAttributeIndex = availableAttributeIndex; | 207 desc->fCoverageAttributeIndex = availableAttributeIndex; |
197 } else { | 208 } else { |
198 desc->fCoverageAttributeIndex = -1; | 209 desc->fCoverageAttributeIndex = -1; |
199 } | 210 } |
200 } | 211 } |
OLD | NEW |