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 "SkTwoPointConicalGradient_gpu.h" | 9 #include "SkTwoPointConicalGradient_gpu.h" |
10 | 10 |
(...skipping 206 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
217 | 217 |
218 GLEdge2PtConicalEffect::GLEdge2PtConicalEffect(const GrBackendProcessorFactory&
factory, | 218 GLEdge2PtConicalEffect::GLEdge2PtConicalEffect(const GrBackendProcessorFactory&
factory, |
219 const GrProcessor&) | 219 const GrProcessor&) |
220 : INHERITED(factory) | 220 : INHERITED(factory) |
221 , fVSVaryingName(NULL) | 221 , fVSVaryingName(NULL) |
222 , fFSVaryingName(NULL) | 222 , fFSVaryingName(NULL) |
223 , fCachedRadius(-SK_ScalarMax) | 223 , fCachedRadius(-SK_ScalarMax) |
224 , fCachedDiffRadius(-SK_ScalarMax) {} | 224 , fCachedDiffRadius(-SK_ScalarMax) {} |
225 | 225 |
226 void GLEdge2PtConicalEffect::emitCode(GrGLFPBuilder* builder, | 226 void GLEdge2PtConicalEffect::emitCode(GrGLFPBuilder* builder, |
227 const GrFragmentProcessor&, | 227 const GrFragmentProcessor& fp, |
228 const GrProcessorKey& key, | 228 const GrProcessorKey& key, |
229 const char* outputColor, | 229 const char* outputColor, |
230 const char* inputColor, | 230 const char* inputColor, |
231 const TransformedCoordsArray& coords, | 231 const TransformedCoordsArray& coords, |
232 const TextureSamplerArray& samplers) { | 232 const TextureSamplerArray& samplers) { |
233 uint32_t baseKey = key.get32(0); | 233 const GrGradientEffect& ge = fp.cast<GrGradientEffect>(); |
234 this->emitUniforms(builder, baseKey); | 234 this->emitUniforms(builder, ge); |
235 fParamUni = builder->addUniformArray(GrGLProgramBuilder::kFragment_Visibilit
y, | 235 fParamUni = builder->addUniformArray(GrGLProgramBuilder::kFragment_Visibilit
y, |
236 kFloat_GrSLType, "Conical2FSParams", 3)
; | 236 kFloat_GrSLType, "Conical2FSParams", 3)
; |
237 | 237 |
238 SkString cName("c"); | 238 SkString cName("c"); |
239 SkString tName("t"); | 239 SkString tName("t"); |
240 SkString p0; // start radius | 240 SkString p0; // start radius |
241 SkString p1; // start radius squared | 241 SkString p1; // start radius squared |
242 SkString p2; // difference in radii (r1 - r0) | 242 SkString p2; // difference in radii (r1 - r0) |
243 | 243 |
244 builder->getUniformVariable(fParamUni).appendArrayAccess(0, &p0); | 244 builder->getUniformVariable(fParamUni).appendArrayAccess(0, &p0); |
(...skipping 25 matching lines...) Expand all Loading... |
270 cName.c_str(), coords2D, coords2D, p1.c_str()); | 270 cName.c_str(), coords2D, coords2D, p1.c_str()); |
271 | 271 |
272 // linear case: t = -c/b | 272 // linear case: t = -c/b |
273 fsBuilder->codeAppendf("\tfloat %s = -(%s / %s);\n", tName.c_str(), | 273 fsBuilder->codeAppendf("\tfloat %s = -(%s / %s);\n", tName.c_str(), |
274 cName.c_str(), bVar.c_str()); | 274 cName.c_str(), bVar.c_str()); |
275 | 275 |
276 // if r(t) > 0, then t will be the x coordinate | 276 // if r(t) > 0, then t will be the x coordinate |
277 fsBuilder->codeAppendf("\tif (%s * %s + %s > 0.0) {\n", tName.c_str(), | 277 fsBuilder->codeAppendf("\tif (%s * %s + %s > 0.0) {\n", tName.c_str(), |
278 p2.c_str(), p0.c_str()); | 278 p2.c_str(), p0.c_str()); |
279 fsBuilder->codeAppend("\t"); | 279 fsBuilder->codeAppend("\t"); |
280 this->emitColor(builder, tName.c_str(), baseKey, outputColor, inputColor, sa
mplers); | 280 this->emitColor(builder, ge, tName.c_str(), outputColor, inputColor, sampler
s); |
281 fsBuilder->codeAppend("\t}\n"); | 281 fsBuilder->codeAppend("\t}\n"); |
282 } | 282 } |
283 | 283 |
284 void GLEdge2PtConicalEffect::setData(const GrGLProgramDataManager& pdman, | 284 void GLEdge2PtConicalEffect::setData(const GrGLProgramDataManager& pdman, |
285 const GrProcessor& processor) { | 285 const GrProcessor& processor) { |
286 INHERITED::setData(pdman, processor); | 286 INHERITED::setData(pdman, processor); |
287 const Edge2PtConicalEffect& data = processor.cast<Edge2PtConicalEffect>(); | 287 const Edge2PtConicalEffect& data = processor.cast<Edge2PtConicalEffect>(); |
288 SkScalar radius0 = data.radius(); | 288 SkScalar radius0 = data.radius(); |
289 SkScalar diffRadius = data.diffRadius(); | 289 SkScalar diffRadius = data.diffRadius(); |
290 | 290 |
(...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
498 const GrProcessor
& processor) | 498 const GrProcessor
& processor) |
499 : INHERITED(factory) | 499 : INHERITED(factory) |
500 , fVSVaryingName(NULL) | 500 , fVSVaryingName(NULL) |
501 , fFSVaryingName(NULL) | 501 , fFSVaryingName(NULL) |
502 , fCachedFocal(SK_ScalarMax) { | 502 , fCachedFocal(SK_ScalarMax) { |
503 const FocalOutside2PtConicalEffect& data = processor.cast<FocalOutside2PtCon
icalEffect>(); | 503 const FocalOutside2PtConicalEffect& data = processor.cast<FocalOutside2PtCon
icalEffect>(); |
504 fIsFlipped = data.isFlipped(); | 504 fIsFlipped = data.isFlipped(); |
505 } | 505 } |
506 | 506 |
507 void GLFocalOutside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, | 507 void GLFocalOutside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, |
508 const GrFragmentProcessor&, | 508 const GrFragmentProcessor& fp, |
509 const GrProcessorKey& key, | 509 const GrProcessorKey& key, |
510 const char* outputColor, | 510 const char* outputColor, |
511 const char* inputColor, | 511 const char* inputColor, |
512 const TransformedCoordsArray& coor
ds, | 512 const TransformedCoordsArray& coor
ds, |
513 const TextureSamplerArray& sampler
s) { | 513 const TextureSamplerArray& sampler
s) { |
514 uint32_t baseKey = key.get32(0); | 514 const GrGradientEffect& ge = fp.cast<GrGradientEffect>(); |
515 this->emitUniforms(builder, baseKey); | 515 this->emitUniforms(builder, ge); |
516 fParamUni = builder->addUniformArray(GrGLProgramBuilder::kFragment_Visibilit
y, | 516 fParamUni = builder->addUniformArray(GrGLProgramBuilder::kFragment_Visibilit
y, |
517 kFloat_GrSLType, "Conical2FSParams", 2)
; | 517 kFloat_GrSLType, "Conical2FSParams", 2)
; |
518 SkString tName("t"); | 518 SkString tName("t"); |
519 SkString p0; // focalX | 519 SkString p0; // focalX |
520 SkString p1; // 1 - focalX * focalX | 520 SkString p1; // 1 - focalX * focalX |
521 | 521 |
522 builder->getUniformVariable(fParamUni).appendArrayAccess(0, &p0); | 522 builder->getUniformVariable(fParamUni).appendArrayAccess(0, &p0); |
523 builder->getUniformVariable(fParamUni).appendArrayAccess(1, &p1); | 523 builder->getUniformVariable(fParamUni).appendArrayAccess(1, &p1); |
524 | 524 |
525 // if we have a vec3 from being in perspective, convert it to a vec2 first | 525 // if we have a vec3 from being in perspective, convert it to a vec2 first |
(...skipping 16 matching lines...) Expand all Loading... |
542 if (!fIsFlipped) { | 542 if (!fIsFlipped) { |
543 fsBuilder->codeAppendf("\tfloat %s = %s.x * %s + sqrt(d);\n", tName.c_s
tr(), | 543 fsBuilder->codeAppendf("\tfloat %s = %s.x * %s + sqrt(d);\n", tName.c_s
tr(), |
544 coords2D, p0.c_str()); | 544 coords2D, p0.c_str()); |
545 } else { | 545 } else { |
546 fsBuilder->codeAppendf("\tfloat %s = %s.x * %s - sqrt(d);\n", tName.c_s
tr(), | 546 fsBuilder->codeAppendf("\tfloat %s = %s.x * %s - sqrt(d);\n", tName.c_s
tr(), |
547 coords2D, p0.c_str()); | 547 coords2D, p0.c_str()); |
548 } | 548 } |
549 | 549 |
550 fsBuilder->codeAppendf("\tif (%s >= 0.0 && d >= 0.0) {\n", tName.c_str()); | 550 fsBuilder->codeAppendf("\tif (%s >= 0.0 && d >= 0.0) {\n", tName.c_str()); |
551 fsBuilder->codeAppend("\t\t"); | 551 fsBuilder->codeAppend("\t\t"); |
552 this->emitColor(builder, tName.c_str(), baseKey, outputColor, inputColor, sa
mplers); | 552 this->emitColor(builder, ge, tName.c_str(), outputColor, inputColor, sampler
s); |
553 fsBuilder->codeAppend("\t}\n"); | 553 fsBuilder->codeAppend("\t}\n"); |
554 } | 554 } |
555 | 555 |
556 void GLFocalOutside2PtConicalEffect::setData(const GrGLProgramDataManager& pdman
, | 556 void GLFocalOutside2PtConicalEffect::setData(const GrGLProgramDataManager& pdman
, |
557 const GrProcessor& processor) { | 557 const GrProcessor& processor) { |
558 INHERITED::setData(pdman, processor); | 558 INHERITED::setData(pdman, processor); |
559 const FocalOutside2PtConicalEffect& data = processor.cast<FocalOutside2PtCon
icalEffect>(); | 559 const FocalOutside2PtConicalEffect& data = processor.cast<FocalOutside2PtCon
icalEffect>(); |
560 SkASSERT(data.isFlipped() == fIsFlipped); | 560 SkASSERT(data.isFlipped() == fIsFlipped); |
561 SkScalar focal = data.focal(); | 561 SkScalar focal = data.focal(); |
562 | 562 |
(...skipping 141 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
704 } | 704 } |
705 | 705 |
706 GLFocalInside2PtConicalEffect::GLFocalInside2PtConicalEffect(const GrBackendProc
essorFactory& factory, | 706 GLFocalInside2PtConicalEffect::GLFocalInside2PtConicalEffect(const GrBackendProc
essorFactory& factory, |
707 const GrProcessor&) | 707 const GrProcessor&) |
708 : INHERITED(factory) | 708 : INHERITED(factory) |
709 , fVSVaryingName(NULL) | 709 , fVSVaryingName(NULL) |
710 , fFSVaryingName(NULL) | 710 , fFSVaryingName(NULL) |
711 , fCachedFocal(SK_ScalarMax) {} | 711 , fCachedFocal(SK_ScalarMax) {} |
712 | 712 |
713 void GLFocalInside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, | 713 void GLFocalInside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, |
714 const GrFragmentProcessor&, | 714 const GrFragmentProcessor& fp, |
715 const GrProcessorKey& key, | 715 const GrProcessorKey& key, |
716 const char* outputColor, | 716 const char* outputColor, |
717 const char* inputColor, | 717 const char* inputColor, |
718 const TransformedCoordsArray& coord
s, | 718 const TransformedCoordsArray& coord
s, |
719 const TextureSamplerArray& samplers
) { | 719 const TextureSamplerArray& samplers
) { |
720 uint32_t baseKey = key.get32(0); | 720 const GrGradientEffect& ge = fp.cast<GrGradientEffect>(); |
721 this->emitUniforms(builder, baseKey); | 721 this->emitUniforms(builder, ge); |
722 fFocalUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, | 722 fFocalUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, |
723 kFloat_GrSLType, "Conical2FSParams"); | 723 kFloat_GrSLType, "Conical2FSParams"); |
724 SkString tName("t"); | 724 SkString tName("t"); |
725 | 725 |
726 // this is the distance along x-axis from the end center to focal point in | 726 // this is the distance along x-axis from the end center to focal point in |
727 // transformed coordinates | 727 // transformed coordinates |
728 GrGLShaderVar focal = builder->getUniformVariable(fFocalUni); | 728 GrGLShaderVar focal = builder->getUniformVariable(fFocalUni); |
729 | 729 |
730 // if we have a vec3 from being in perspective, convert it to a vec2 first | 730 // if we have a vec3 from being in perspective, convert it to a vec2 first |
731 GrGLFPFragmentBuilder* fsBuilder = builder->getFragmentShaderBuilder(); | 731 GrGLFPFragmentBuilder* fsBuilder = builder->getFragmentShaderBuilder(); |
732 SkString coords2DString = fsBuilder->ensureFSCoords2D(coords, 0); | 732 SkString coords2DString = fsBuilder->ensureFSCoords2D(coords, 0); |
733 const char* coords2D = coords2DString.c_str(); | 733 const char* coords2D = coords2DString.c_str(); |
734 | 734 |
735 // t = p.x * focalX + length(p) | 735 // t = p.x * focalX + length(p) |
736 fsBuilder->codeAppendf("\tfloat %s = %s.x * %s + length(%s);\n", tName.c_st
r(), | 736 fsBuilder->codeAppendf("\tfloat %s = %s.x * %s + length(%s);\n", tName.c_st
r(), |
737 coords2D, focal.c_str(), coords2D); | 737 coords2D, focal.c_str(), coords2D); |
738 | 738 |
739 this->emitColor(builder, tName.c_str(), baseKey, outputColor, inputColor, sa
mplers); | 739 this->emitColor(builder, ge, tName.c_str(), outputColor, inputColor, sampler
s); |
740 } | 740 } |
741 | 741 |
742 void GLFocalInside2PtConicalEffect::setData(const GrGLProgramDataManager& pdman, | 742 void GLFocalInside2PtConicalEffect::setData(const GrGLProgramDataManager& pdman, |
743 const GrProcessor& processor) { | 743 const GrProcessor& processor) { |
744 INHERITED::setData(pdman, processor); | 744 INHERITED::setData(pdman, processor); |
745 const FocalInside2PtConicalEffect& data = processor.cast<FocalInside2PtConic
alEffect>(); | 745 const FocalInside2PtConicalEffect& data = processor.cast<FocalInside2PtConic
alEffect>(); |
746 SkScalar focal = data.focal(); | 746 SkScalar focal = data.focal(); |
747 | 747 |
748 if (fCachedFocal != focal) { | 748 if (fCachedFocal != focal) { |
749 pdman.set1f(fFocalUni, SkScalarToFloat(focal)); | 749 pdman.set1f(fFocalUni, SkScalarToFloat(focal)); |
(...skipping 207 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
957 : INHERITED(factory) | 957 : INHERITED(factory) |
958 , fVSVaryingName(NULL) | 958 , fVSVaryingName(NULL) |
959 , fFSVaryingName(NULL) | 959 , fFSVaryingName(NULL) |
960 , fCachedCenterX(SK_ScalarMax) | 960 , fCachedCenterX(SK_ScalarMax) |
961 , fCachedCenterY(SK_ScalarMax) | 961 , fCachedCenterY(SK_ScalarMax) |
962 , fCachedA(SK_ScalarMax) | 962 , fCachedA(SK_ScalarMax) |
963 , fCachedB(SK_ScalarMax) | 963 , fCachedB(SK_ScalarMax) |
964 , fCachedC(SK_ScalarMax) {} | 964 , fCachedC(SK_ScalarMax) {} |
965 | 965 |
966 void GLCircleInside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, | 966 void GLCircleInside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, |
967 const GrFragmentProcessor&, | 967 const GrFragmentProcessor& fp, |
968 const GrProcessorKey& key, | 968 const GrProcessorKey& key, |
969 const char* outputColor, | 969 const char* outputColor, |
970 const char* inputColor, | 970 const char* inputColor, |
971 const TransformedCoordsArray& coor
ds, | 971 const TransformedCoordsArray& coor
ds, |
972 const TextureSamplerArray& sampler
s) { | 972 const TextureSamplerArray& sampler
s) { |
973 uint32_t baseKey = key.get32(0); | 973 const GrGradientEffect& ge = fp.cast<GrGradientEffect>(); |
974 this->emitUniforms(builder, baseKey); | 974 this->emitUniforms(builder, ge); |
975 fCenterUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, | 975 fCenterUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, |
976 kVec2f_GrSLType, "Conical2FSCenter"); | 976 kVec2f_GrSLType, "Conical2FSCenter"); |
977 fParamUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, | 977 fParamUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, |
978 kVec3f_GrSLType, "Conical2FSParams"); | 978 kVec3f_GrSLType, "Conical2FSParams"); |
979 SkString tName("t"); | 979 SkString tName("t"); |
980 | 980 |
981 GrGLShaderVar center = builder->getUniformVariable(fCenterUni); | 981 GrGLShaderVar center = builder->getUniformVariable(fCenterUni); |
982 // params.x = A | 982 // params.x = A |
983 // params.y = B | 983 // params.y = B |
984 // params.z = C | 984 // params.z = C |
(...skipping 11 matching lines...) Expand all Loading... |
996 // B = (r -1) / A | 996 // B = (r -1) / A |
997 // C = 1 / A | 997 // C = 1 / A |
998 // d = dot(e, p) + B | 998 // d = dot(e, p) + B |
999 // t = d +/- sqrt(d^2 - A * dot(p, p) + C) | 999 // t = d +/- sqrt(d^2 - A * dot(p, p) + C) |
1000 fsBuilder->codeAppendf("\tfloat pDotp = dot(%s, %s);\n", coords2D, coords2D
); | 1000 fsBuilder->codeAppendf("\tfloat pDotp = dot(%s, %s);\n", coords2D, coords2D
); |
1001 fsBuilder->codeAppendf("\tfloat d = dot(%s, %s) + %s.y;\n", coords2D, cente
r.c_str(), | 1001 fsBuilder->codeAppendf("\tfloat d = dot(%s, %s) + %s.y;\n", coords2D, cente
r.c_str(), |
1002 params.c_str()); | 1002 params.c_str()); |
1003 fsBuilder->codeAppendf("\tfloat %s = d + sqrt(d * d - %s.x * pDotp + %s.z);\
n", | 1003 fsBuilder->codeAppendf("\tfloat %s = d + sqrt(d * d - %s.x * pDotp + %s.z);\
n", |
1004 tName.c_str(), params.c_str(), params.c_str()); | 1004 tName.c_str(), params.c_str(), params.c_str()); |
1005 | 1005 |
1006 this->emitColor(builder, tName.c_str(), baseKey, outputColor, inputColor, sa
mplers); | 1006 this->emitColor(builder, ge, tName.c_str(), outputColor, inputColor, sampler
s); |
1007 } | 1007 } |
1008 | 1008 |
1009 void GLCircleInside2PtConicalEffect::setData(const GrGLProgramDataManager& pdman
, | 1009 void GLCircleInside2PtConicalEffect::setData(const GrGLProgramDataManager& pdman
, |
1010 const GrProcessor& processor) { | 1010 const GrProcessor& processor) { |
1011 INHERITED::setData(pdman, processor); | 1011 INHERITED::setData(pdman, processor); |
1012 const CircleInside2PtConicalEffect& data = processor.cast<CircleInside2PtCon
icalEffect>(); | 1012 const CircleInside2PtConicalEffect& data = processor.cast<CircleInside2PtCon
icalEffect>(); |
1013 SkScalar centerX = data.centerX(); | 1013 SkScalar centerX = data.centerX(); |
1014 SkScalar centerY = data.centerY(); | 1014 SkScalar centerY = data.centerY(); |
1015 SkScalar A = data.A(); | 1015 SkScalar A = data.A(); |
1016 SkScalar B = data.B(); | 1016 SkScalar B = data.B(); |
(...skipping 180 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1197 , fCachedCenterY(SK_ScalarMax) | 1197 , fCachedCenterY(SK_ScalarMax) |
1198 , fCachedA(SK_ScalarMax) | 1198 , fCachedA(SK_ScalarMax) |
1199 , fCachedB(SK_ScalarMax) | 1199 , fCachedB(SK_ScalarMax) |
1200 , fCachedC(SK_ScalarMax) | 1200 , fCachedC(SK_ScalarMax) |
1201 , fCachedTLimit(SK_ScalarMax) { | 1201 , fCachedTLimit(SK_ScalarMax) { |
1202 const CircleOutside2PtConicalEffect& data = processor.cast<CircleOutside2PtC
onicalEffect>(); | 1202 const CircleOutside2PtConicalEffect& data = processor.cast<CircleOutside2PtC
onicalEffect>(); |
1203 fIsFlipped = data.isFlipped(); | 1203 fIsFlipped = data.isFlipped(); |
1204 } | 1204 } |
1205 | 1205 |
1206 void GLCircleOutside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, | 1206 void GLCircleOutside2PtConicalEffect::emitCode(GrGLFPBuilder* builder, |
1207 const GrFragmentProcessor&, | 1207 const GrFragmentProcessor& fp, |
1208 const GrProcessorKey& key, | 1208 const GrProcessorKey& key, |
1209 const char* outputColor, | 1209 const char* outputColor, |
1210 const char* inputColor, | 1210 const char* inputColor, |
1211 const TransformedCoordsArray& coo
rds, | 1211 const TransformedCoordsArray& coo
rds, |
1212 const TextureSamplerArray& sample
rs) { | 1212 const TextureSamplerArray& sample
rs) { |
1213 uint32_t baseKey = key.get32(0); | 1213 const GrGradientEffect& ge = fp.cast<GrGradientEffect>(); |
1214 this->emitUniforms(builder, baseKey); | 1214 this->emitUniforms(builder, ge); |
1215 fCenterUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, | 1215 fCenterUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, |
1216 kVec2f_GrSLType, "Conical2FSCenter"); | 1216 kVec2f_GrSLType, "Conical2FSCenter"); |
1217 fParamUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, | 1217 fParamUni = builder->addUniform(GrGLProgramBuilder::kFragment_Visibility, |
1218 kVec4f_GrSLType, "Conical2FSParams"); | 1218 kVec4f_GrSLType, "Conical2FSParams"); |
1219 SkString tName("t"); | 1219 SkString tName("t"); |
1220 | 1220 |
1221 GrGLShaderVar center = builder->getUniformVariable(fCenterUni); | 1221 GrGLShaderVar center = builder->getUniformVariable(fCenterUni); |
1222 // params.x = A | 1222 // params.x = A |
1223 // params.y = B | 1223 // params.y = B |
1224 // params.z = C | 1224 // params.z = C |
(...skipping 26 matching lines...) Expand all Loading... |
1251 // Must check to see if we flipped the circle order (to make sure start radi
us < end radius) | 1251 // Must check to see if we flipped the circle order (to make sure start radi
us < end radius) |
1252 // If so we must also flip sign on sqrt | 1252 // If so we must also flip sign on sqrt |
1253 if (!fIsFlipped) { | 1253 if (!fIsFlipped) { |
1254 fsBuilder->codeAppendf("\tfloat %s = d + sqrt(deter);\n", tName.c_str())
; | 1254 fsBuilder->codeAppendf("\tfloat %s = d + sqrt(deter);\n", tName.c_str())
; |
1255 } else { | 1255 } else { |
1256 fsBuilder->codeAppendf("\tfloat %s = d - sqrt(deter);\n", tName.c_str())
; | 1256 fsBuilder->codeAppendf("\tfloat %s = d - sqrt(deter);\n", tName.c_str())
; |
1257 } | 1257 } |
1258 | 1258 |
1259 fsBuilder->codeAppendf("\tif (%s >= %s.w && deter >= 0.0) {\n", tName.c_str(
), params.c_str()); | 1259 fsBuilder->codeAppendf("\tif (%s >= %s.w && deter >= 0.0) {\n", tName.c_str(
), params.c_str()); |
1260 fsBuilder->codeAppend("\t\t"); | 1260 fsBuilder->codeAppend("\t\t"); |
1261 this->emitColor(builder, tName.c_str(), baseKey, outputColor, inputColor, sa
mplers); | 1261 this->emitColor(builder, ge, tName.c_str(), outputColor, inputColor, sampler
s); |
1262 fsBuilder->codeAppend("\t}\n"); | 1262 fsBuilder->codeAppend("\t}\n"); |
1263 } | 1263 } |
1264 | 1264 |
1265 void GLCircleOutside2PtConicalEffect::setData(const GrGLProgramDataManager& pdma
n, | 1265 void GLCircleOutside2PtConicalEffect::setData(const GrGLProgramDataManager& pdma
n, |
1266 const GrProcessor& processor) { | 1266 const GrProcessor& processor) { |
1267 INHERITED::setData(pdman, processor); | 1267 INHERITED::setData(pdman, processor); |
1268 const CircleOutside2PtConicalEffect& data = processor.cast<CircleOutside2PtC
onicalEffect>(); | 1268 const CircleOutside2PtConicalEffect& data = processor.cast<CircleOutside2PtC
onicalEffect>(); |
1269 SkASSERT(data.isFlipped() == fIsFlipped); | 1269 SkASSERT(data.isFlipped() == fIsFlipped); |
1270 SkScalar centerX = data.centerX(); | 1270 SkScalar centerX = data.centerX(); |
1271 SkScalar centerY = data.centerY(); | 1271 SkScalar centerY = data.centerY(); |
(...skipping 63 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1335 return CircleInside2PtConicalEffect::Create(ctx, shader, matrix, tm, inf
o); | 1335 return CircleInside2PtConicalEffect::Create(ctx, shader, matrix, tm, inf
o); |
1336 } else if (type == kEdge_ConicalType) { | 1336 } else if (type == kEdge_ConicalType) { |
1337 set_matrix_edge_conical(shader, &matrix); | 1337 set_matrix_edge_conical(shader, &matrix); |
1338 return Edge2PtConicalEffect::Create(ctx, shader, matrix, tm); | 1338 return Edge2PtConicalEffect::Create(ctx, shader, matrix, tm); |
1339 } else { | 1339 } else { |
1340 return CircleOutside2PtConicalEffect::Create(ctx, shader, matrix, tm, in
fo); | 1340 return CircleOutside2PtConicalEffect::Create(ctx, shader, matrix, tm, in
fo); |
1341 } | 1341 } |
1342 } | 1342 } |
1343 | 1343 |
1344 #endif | 1344 #endif |
OLD | NEW |