Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(215)

Side by Side Diff: src/gpu/effects/GrDashingEffect.cpp

Issue 678953002: Default geometry processor (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: fix dm bug Created 6 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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 "GrDashingEffect.h" 8 #include "GrDashingEffect.h"
9 9
10 #include "../GrAARectRenderer.h" 10 #include "../GrAARectRenderer.h"
(...skipping 502 matching lines...) Expand 10 before | Expand all | Expand 10 after
513 kVec3f_GrSLType, 513 kVec3f_GrSLType,
514 "params", 514 "params",
515 &paramName); 515 &paramName);
516 516
517 GrGLVertToFrag v(kVec2f_GrSLType); 517 GrGLVertToFrag v(kVec2f_GrSLType);
518 args.fPB->addVarying("Coord", &v); 518 args.fPB->addVarying("Coord", &v);
519 519
520 GrGLVertexBuilder* vsBuilder = args.fPB->getVertexShaderBuilder(); 520 GrGLVertexBuilder* vsBuilder = args.fPB->getVertexShaderBuilder();
521 vsBuilder->codeAppendf("\t%s = %s;\n", v.vsOut(), dce.inCoord().c_str()); 521 vsBuilder->codeAppendf("\t%s = %s;\n", v.vsOut(), dce.inCoord().c_str());
522 522
523 // setup position varying
524 vsBuilder->codeAppendf("vec3 pos3 = %s * vec3(%s, 1);", args.fGP.uViewM(),
525 args.fGP.inPosition());
526 vsBuilder->transformPositionToDeviceSpace("pos3");
527
523 // transforms all points so that we can compare them to our test circle 528 // transforms all points so that we can compare them to our test circle
524 GrGLGPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder(); 529 GrGLGPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder();
525 fsBuilder->codeAppendf("\t\tfloat xShifted = %s.x - floor(%s.x / %s.z) * %s. z;\n", 530 fsBuilder->codeAppendf("\t\tfloat xShifted = %s.x - floor(%s.x / %s.z) * %s. z;\n",
526 v.fsIn(), v.fsIn(), paramName, paramName); 531 v.fsIn(), v.fsIn(), paramName, paramName);
527 fsBuilder->codeAppendf("\t\tvec2 fragPosShifted = vec2(xShifted, %s.y);\n", v.fsIn()); 532 fsBuilder->codeAppendf("\t\tvec2 fragPosShifted = vec2(xShifted, %s.y);\n", v.fsIn());
528 fsBuilder->codeAppendf("\t\tvec2 center = vec2(%s.y, 0.0);\n", paramName); 533 fsBuilder->codeAppendf("\t\tvec2 center = vec2(%s.y, 0.0);\n", paramName);
529 fsBuilder->codeAppend("\t\tfloat dist = length(center - fragPosShifted);\n") ; 534 fsBuilder->codeAppend("\t\tfloat dist = length(center - fragPosShifted);\n") ;
530 if (GrProcessorEdgeTypeIsAA(dce.getEdgeType())) { 535 if (GrProcessorEdgeTypeIsAA(dce.getEdgeType())) {
531 fsBuilder->codeAppendf("\t\tfloat diff = dist - %s.x;\n", paramName); 536 fsBuilder->codeAppendf("\t\tfloat diff = dist - %s.x;\n", paramName);
532 fsBuilder->codeAppend("\t\tdiff = 1.0 - diff;\n"); 537 fsBuilder->codeAppend("\t\tdiff = 1.0 - diff;\n");
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after
716 fIntervalUniform = args.fPB->addUniform(GrGLProgramBuilder::kFragment_Visibi lity, 721 fIntervalUniform = args.fPB->addUniform(GrGLProgramBuilder::kFragment_Visibi lity,
717 kFloat_GrSLType, 722 kFloat_GrSLType,
718 "interval", 723 "interval",
719 &intervalName); 724 &intervalName);
720 725
721 GrGLVertToFrag v(kVec2f_GrSLType); 726 GrGLVertToFrag v(kVec2f_GrSLType);
722 args.fPB->addVarying("Coord", &v); 727 args.fPB->addVarying("Coord", &v);
723 GrGLVertexBuilder* vsBuilder = args.fPB->getVertexShaderBuilder(); 728 GrGLVertexBuilder* vsBuilder = args.fPB->getVertexShaderBuilder();
724 vsBuilder->codeAppendf("\t%s = %s;\n", v.vsOut(), de.inCoord().c_str()); 729 vsBuilder->codeAppendf("\t%s = %s;\n", v.vsOut(), de.inCoord().c_str());
725 730
731 // setup position varying
732 vsBuilder->codeAppendf("vec3 pos3 = %s * vec3(%s, 1);", args.fGP.uViewM(),
733 args.fGP.inPosition());
734 vsBuilder->transformPositionToDeviceSpace("pos3");
735
726 // transforms all points so that we can compare them to our test rect 736 // transforms all points so that we can compare them to our test rect
727 GrGLGPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder(); 737 GrGLGPFragmentBuilder* fsBuilder = args.fPB->getFragmentShaderBuilder();
728 fsBuilder->codeAppendf("\t\tfloat xShifted = %s.x - floor(%s.x / %s) * %s;\n ", 738 fsBuilder->codeAppendf("\t\tfloat xShifted = %s.x - floor(%s.x / %s) * %s;\n ",
729 v.fsIn(), v.fsIn(), intervalName, intervalName); 739 v.fsIn(), v.fsIn(), intervalName, intervalName);
730 fsBuilder->codeAppendf("\t\tvec2 fragPosShifted = vec2(xShifted, %s.y);\n", v.fsIn()); 740 fsBuilder->codeAppendf("\t\tvec2 fragPosShifted = vec2(xShifted, %s.y);\n", v.fsIn());
731 if (GrProcessorEdgeTypeIsAA(de.getEdgeType())) { 741 if (GrProcessorEdgeTypeIsAA(de.getEdgeType())) {
732 // The amount of coverage removed in x and y by the edges is computed as a pair of negative 742 // The amount of coverage removed in x and y by the edges is computed as a pair of negative
733 // numbers, xSub and ySub. 743 // numbers, xSub and ySub.
734 fsBuilder->codeAppend("\t\tfloat xSub, ySub;\n"); 744 fsBuilder->codeAppend("\t\tfloat xSub, ySub;\n");
735 fsBuilder->codeAppendf("\t\txSub = min(fragPosShifted.x - %s.x, 0.0);\n" , rectName); 745 fsBuilder->codeAppendf("\t\txSub = min(fragPosShifted.x - %s.x, 0.0);\n" , rectName);
(...skipping 105 matching lines...) Expand 10 before | Expand all | Expand 10 after
841 switch (cap) { 851 switch (cap) {
842 case GrDashingEffect::kRound_DashCap: 852 case GrDashingEffect::kRound_DashCap:
843 return DashingCircleEffect::Create(edgeType, info, SkScalarHalf(stro keWidth)); 853 return DashingCircleEffect::Create(edgeType, info, SkScalarHalf(stro keWidth));
844 case GrDashingEffect::kNonRound_DashCap: 854 case GrDashingEffect::kNonRound_DashCap:
845 return DashingLineEffect::Create(edgeType, info, strokeWidth); 855 return DashingLineEffect::Create(edgeType, info, strokeWidth);
846 default: 856 default:
847 SkFAIL("Unexpected dashed cap."); 857 SkFAIL("Unexpected dashed cap.");
848 } 858 }
849 return NULL; 859 return NULL;
850 } 860 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698