baked in a few more precision modifiers
BUG=skia: GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=5146 Change-Id: If824ddd3551fd50b66e98edc39f10fa60a0560dc Reviewed-on: https://skia-review.googlesource.com/5146 Reviewed-by: Brian Salomon <bsalomon@google.com> Commit-Queue: Ethan Nicholas <ethannicholas@google.com>
This commit is contained in:
parent
d5de013643
commit
6762dd6f73
@ -167,10 +167,9 @@ const char* GrGLSLFragmentShaderBuilder::fragmentPosition() {
|
|||||||
// depending on the surrounding code, accessing .xy with a uniform involved can
|
// depending on the surrounding code, accessing .xy with a uniform involved can
|
||||||
// do the same thing. Copying gl_FragCoord.xy into a temp vec2 beforehand
|
// do the same thing. Copying gl_FragCoord.xy into a temp vec2 beforehand
|
||||||
// (and only accessing .xy) seems to "fix" things.
|
// (and only accessing .xy) seems to "fix" things.
|
||||||
const char* precision = glslCaps->usesPrecisionModifiers() ? "highp " : "";
|
this->codePrependf("\thighp vec4 %s = vec4(%s.x, %s - %s.y, 1.0, 1.0);\n", kCoordName,
|
||||||
this->codePrependf("\t%svec4 %s = vec4(%s.x, %s - %s.y, 1.0, 1.0);\n",
|
kTempName, rtHeightName, kTempName);
|
||||||
precision, kCoordName, kTempName, rtHeightName, kTempName);
|
this->codePrependf("highp vec2 %s = gl_FragCoord.xy;", kTempName);
|
||||||
this->codePrependf("%svec2 %s = gl_FragCoord.xy;", precision, kTempName);
|
|
||||||
fSetupFragPosition = true;
|
fSetupFragPosition = true;
|
||||||
}
|
}
|
||||||
SkASSERT(fProgramBuilder->fUniformHandles.fRTHeightUni.isValid());
|
SkASSERT(fProgramBuilder->fUniformHandles.fRTHeightUni.isValid());
|
||||||
@ -359,11 +358,7 @@ void GrGLSLFragmentShaderBuilder::defineSampleOffsetArray(const char* name, cons
|
|||||||
SkSTArray<16, SkPoint, true> offsets;
|
SkSTArray<16, SkPoint, true> offsets;
|
||||||
offsets.push_back_n(specs.fEffectiveSampleCnt);
|
offsets.push_back_n(specs.fEffectiveSampleCnt);
|
||||||
m.mapPoints(offsets.begin(), specs.fSampleLocations, specs.fEffectiveSampleCnt);
|
m.mapPoints(offsets.begin(), specs.fSampleLocations, specs.fEffectiveSampleCnt);
|
||||||
this->definitions().append("const ");
|
this->definitions().appendf("const highp vec2 %s[] = vec2[](", name);
|
||||||
if (fProgramBuilder->glslCaps()->usesPrecisionModifiers()) {
|
|
||||||
this->definitions().append("highp ");
|
|
||||||
}
|
|
||||||
this->definitions().appendf("vec2 %s[] = vec2[](", name);
|
|
||||||
for (int i = 0; i < specs.fEffectiveSampleCnt; ++i) {
|
for (int i = 0; i < specs.fEffectiveSampleCnt; ++i) {
|
||||||
this->definitions().appendf("vec2(%f, %f)", offsets[i].x(), offsets[i].y());
|
this->definitions().appendf("vec2(%f, %f)", offsets[i].x(), offsets[i].y());
|
||||||
this->definitions().append(i + 1 != specs.fEffectiveSampleCnt ? ", " : ");\n");
|
this->definitions().append(i + 1 != specs.fEffectiveSampleCnt ? ", " : ");\n");
|
||||||
|
@ -925,10 +925,7 @@ void GLSLInstanceProcessor::BackendCoverage::onEmitCode(GrGLSLVertexBuilder* v,
|
|||||||
v->codeAppendf("%s = rectCoverage;", fRectCoverage.vsOut());
|
v->codeAppendf("%s = rectCoverage;", fRectCoverage.vsOut());
|
||||||
}
|
}
|
||||||
|
|
||||||
SkString coverage("float coverage");
|
SkString coverage("lowp float coverage");
|
||||||
if (f->getProgramBuilder()->glslCaps()->usesPrecisionModifiers()) {
|
|
||||||
coverage.prependf("lowp ");
|
|
||||||
}
|
|
||||||
if (fBatchInfo.fInnerShapeTypes || (!fTweakAlphaForCoverage && fTriangleIsArc.fsIn())) {
|
if (fBatchInfo.fInnerShapeTypes || (!fTweakAlphaForCoverage && fTriangleIsArc.fsIn())) {
|
||||||
f->codeAppendf("%s;", coverage.c_str());
|
f->codeAppendf("%s;", coverage.c_str());
|
||||||
coverage = "coverage";
|
coverage = "coverage";
|
||||||
@ -955,10 +952,7 @@ void GLSLInstanceProcessor::BackendCoverage::onEmitCode(GrGLSLVertexBuilder* v,
|
|||||||
|
|
||||||
if (fBatchInfo.fInnerShapeTypes) {
|
if (fBatchInfo.fInnerShapeTypes) {
|
||||||
f->codeAppendf("// Inner shape.\n");
|
f->codeAppendf("// Inner shape.\n");
|
||||||
SkString innerCoverageDecl("float innerCoverage");
|
SkString innerCoverageDecl("lowp float innerCoverage");
|
||||||
if (f->getProgramBuilder()->glslCaps()->usesPrecisionModifiers()) {
|
|
||||||
innerCoverageDecl.prependf("lowp ");
|
|
||||||
}
|
|
||||||
if (kOval_ShapeFlag == fBatchInfo.fInnerShapeTypes) {
|
if (kOval_ShapeFlag == fBatchInfo.fInnerShapeTypes) {
|
||||||
this->emitArc(f, fInnerEllipseCoords.fsIn(), fInnerEllipseName.fsIn(),
|
this->emitArc(f, fInnerEllipseCoords.fsIn(), fInnerEllipseName.fsIn(),
|
||||||
true /*ellipseCoordsNeedClamp*/, true /*ellipseCoordsMayBeNegative*/,
|
true /*ellipseCoordsNeedClamp*/, true /*ellipseCoordsMayBeNegative*/,
|
||||||
|
Loading…
Reference in New Issue
Block a user