summaryrefslogtreecommitdiff
path: root/data/shaders/path-fill-frag.glsl
diff options
context:
space:
mode:
authorDavid Thompson <dthompson2@worcester.edu>2021-09-08 07:38:07 -0400
committerDavid Thompson <dthompson2@worcester.edu>2021-09-08 07:38:07 -0400
commit0c4a79dd8da6f002220533281abc3d45ebfd391d (patch)
tree08805c556fb4c8d6b9d80ab6206c3b1b30b68e39 /data/shaders/path-fill-frag.glsl
parent64869baaa000acc35a63862172d56cd5c65db573 (diff)
graphics: path: Move gradient matrix multiplication to vertex shader.
*Much* cheaper to do this per-vertex than per-fragment.
Diffstat (limited to 'data/shaders/path-fill-frag.glsl')
-rw-r--r--data/shaders/path-fill-frag.glsl8
1 files changed, 3 insertions, 5 deletions
diff --git a/data/shaders/path-fill-frag.glsl b/data/shaders/path-fill-frag.glsl
index e336e76..ba9c5a6 100644
--- a/data/shaders/path-fill-frag.glsl
+++ b/data/shaders/path-fill-frag.glsl
@@ -15,7 +15,6 @@ in vec2 fragPosition;
uniform int mode;
uniform vec4 color;
uniform vec4 endColor;
-uniform mat3 gradientMatrix;
uniform vec2 gradientRange;
uniform float radialGradientRatio;
@@ -34,10 +33,9 @@ void main(void) {
if(mode == 0) { // solid color
fragColor = color;
} else if(mode == 1) { // linear gradient
- float x = (gradientMatrix * vec3(fragPosition, 1.0)).x;
- fragColor = gradientMix(x);
+ fragColor = gradientMix(fragPosition.x);
} else if(mode == 2) { // radial gradient
- vec2 p = (gradientMatrix * vec3(fragPosition, 1.0)).xy;
- fragColor = gradientMix(length(p * vec2(1.0, radialGradientRatio)));
+ vec2 p = fragPosition * vec2(1.0, radialGradientRatio);
+ fragColor = gradientMix(length(p));
}
}