]> git.smokeofanarchy.ru Git - space-station-14.git/commitdiff
Shader cleanup - applies DRY to various shaders in the game (#23294)
authordeathride58 <deathride58@users.noreply.github.com>
Wed, 3 Jan 2024 08:35:25 +0000 (03:35 -0500)
committerGitHub <noreply@github.com>
Wed, 3 Jan 2024 08:35:25 +0000 (19:35 +1100)
shader cleanup - applies DRY to various shaders in the game

Resources/Textures/Shaders/greyscale.swsl
Resources/Textures/Shaders/greyscale_fullscreen.swsl
Resources/Textures/Shaders/outline.swsl
Resources/Textures/Shaders/paperstamp.swsl
Resources/Textures/Shaders/radiation.swsl
Resources/Textures/Shaders/rainbow.swsl

index 918f86ae007f2af3337943fd62e855c140695810..4ffdb1334bf1fbb203919216829d622089e6155c 100644 (file)
@@ -1,6 +1,5 @@
 void fragment() {
     highp vec4 color = zTexture(UV);
-    highp float grey = dot(color.rgb, vec3(0.299, 0.587, 0.114));
 
-    COLOR = vec4(vec3(grey), color.a);
+    COLOR = vec4(vec3(zGrayscale(color.rgb)), color.a);
 }
index 40c0f72b5906344d634eb8357828b54447dacf41..1d43fef028c6164ba4a41cb947299f47b35db646 100644 (file)
@@ -3,7 +3,5 @@ uniform sampler2D SCREEN_TEXTURE;
 void fragment() {
     highp vec4 color = zTextureSpec(SCREEN_TEXTURE, UV);
 
-    highp float grey = dot(color.rgb, vec3(0.299, 0.587, 0.114));
-
-    COLOR = vec4(vec3(grey), color.a);
+    COLOR = vec4(vec3(zGrayscale(color.rgb)), color.a);
 }
index bef244555c07e2b351e2cd9fa5de0309fbbac31e..df031d7d6e785d1c86b2226f15950511e4150c49 100644 (file)
@@ -34,10 +34,6 @@ uniform highp float light_boost; // = 4.0;
 uniform highp float light_gamma; // = 1.0;
 uniform highp float light_whitepoint; // = 1.0;
 
-highp float grayscale(highp vec3 col) {
-       return mix(0.0, 1.0, (col.r * 0.299) + (col.g * 0.587) + (col.b * 0.114)); //These luminance values are taken from Rec. ITU-R BT.601-7. This isn't suitable for player-facing grayscaling due to SDTV having a funky colorspace, but it's perfect for outlines.
-}
-
 void fragment() {
        highp vec4 col = zTexture(UV);
        highp vec2 ps = TEXTURE_PIXEL_SIZE;
@@ -78,7 +74,7 @@ void fragment() {
     maxa = max(a, maxa);
     mina = min(a, mina);
 
-       lowp float sampledLight = outline_fullbright ? 1.0 : clamp( (pow( grayscale(lightSample.rgb) * light_whitepoint, light_gamma) / light_whitepoint ) * light_boost, 0.0, 1.0);
+       lowp float sampledLight = outline_fullbright ? 1.0 : clamp( (pow( zGrayscale_BT601(lightSample.rgb) * light_whitepoint, light_gamma) / light_whitepoint ) * light_boost, 0.0, 1.0);
        COLOR = mix(col, outline_color * vec4(vec3(1.0), sampledLight), maxa - col.a);
        lightSample = vec3(1.0);
 }
index 1f2349970fa5b9058d7df353541be9351b21fb2f..f50330c24c89efafa518af079b4a792b61473979 100644 (file)
@@ -3,30 +3,6 @@
 // affected by the widget layout/position.
 uniform highp vec2 objCoord;
 
-// Magic, well-known 2d random function; makes perlin-like noise
-highp vec2 random(highp vec2 uv){
-    uv = vec2( dot(uv, vec2(127.1,311.7) ),
-               dot(uv, vec2(269.5,183.3) ) );
-    return -1.0 + 2.0 * fract(sin(uv) * 43758.5453123);
-}
-
-highp float noise(highp vec2 uv) {
-    highp vec2 uv_i = floor(uv);
-    highp vec2 uv_f = fract(uv);
-
-    highp vec2 t = smoothstep(0.0, 1.0, uv_f);
-
-    // Sample the random function and run a bilinear filter to smooth it out
-    highp float tl = dot( random(uv_i + vec2(0.0,0.0) ), uv_f - vec2(0.0,0.0) );
-    highp float tr = dot( random(uv_i + vec2(1.0,0.0) ), uv_f - vec2(1.0,0.0) );
-    highp float bl = dot( random(uv_i + vec2(0.0,1.0) ), uv_f - vec2(0.0,1.0) );
-    highp float br = dot( random(uv_i + vec2(1.0,1.0) ), uv_f - vec2(1.0,1.0) );
-
-    highp float tA = mix( tl, tr, t.x );
-    highp float tB = mix( bl, br, t.x );
-    return mix( tA, tB, t.y ) + 0.5;
-}
-
 void fragment() {
     // Stamps have orientation, and the texture sampling is nearest
     // pixel, so run a bilinear filter to smooth out the edges.
@@ -45,8 +21,8 @@ void fragment() {
 
     // Add a bit of noise to mimic imperfect contact with the paper
     {
-        highp float stampNoise = noise((FRAGCOORD.xy - objCoord) * vec2(0.03, 0.03)) *
-                           noise((FRAGCOORD.xy - objCoord) * vec2(0.08, 0.08));
+        highp float stampNoise = zNoise((FRAGCOORD.xy - objCoord) * vec2(0.03, 0.03)) *
+                           zNoise((FRAGCOORD.xy - objCoord) * vec2(0.08, 0.08));
         COLOR.a *= min(0.9, 0.4 + smoothstep(0.05, 0.3, stampNoise));
     }
 }
index 0daf1c24dfe488cde76564dcddedd3de4a1a0585..0214b207a86128e269ee61adb1add48a4a4b53c0 100644 (file)
@@ -6,46 +6,14 @@ uniform highp vec2 renderScale;
 uniform highp float life;
 uniform highp float range;
 
-highp vec2 random(highp vec2 uv){
-    uv = vec2( dot(uv, vec2(127.1,311.7) ),
-               dot(uv, vec2(269.5,183.3) ) );
-    return -1.0 + 2.0 * fract(sin(uv) * 43758.5453123);
-}
-
-highp float noise(highp vec2 uv) {
-    highp vec2 uv_index = floor(uv);
-    highp vec2 uv_fract = fract(uv);
-
-    highp vec2 blur = smoothstep(0.0, 1.0, uv_fract);
-
-    return mix( mix( dot( random(uv_index + vec2(0.0,0.0) ), uv_fract - vec2(0.0,0.0) ),
-                     dot( random(uv_index + vec2(1.0,0.0) ), uv_fract - vec2(1.0,0.0) ), blur.x),
-                mix( dot( random(uv_index + vec2(0.0,1.0) ), uv_fract - vec2(0.0,1.0) ),
-                     dot( random(uv_index + vec2(1.0,1.0) ), uv_fract - vec2(1.0,1.0) ), blur.x), blur.y) * 0.5 + 0.5;
-}
-
-highp float fbm(highp vec2 uv) {
-    const int octaves = 6;
-    highp float amplitude = 0.5;
-    highp float frequency = 3.0;
-    highp float value = 0.0;
-
-    for(int i = 0; i < octaves; i++) {
-        value += amplitude * noise(frequency * uv);
-        amplitude *= 0.5;
-        frequency *= 2.0;
-    }
-    return value;
-}
-
 void fragment() {
        highp vec2 finalCoords = (FRAGCOORD.xy - positionInput) / (renderScale * 32.0);
        highp float distanceToCenter = length(finalCoords);
        highp float nlife = pow(sin(clamp(life, 0.0, 1.0) * 3.141592), 0.5);
        highp float on = ((range - distanceToCenter) / range);
        highp float n = on;
-       highp vec2 fcOffset = vec2(fbm(finalCoords.xy + life / 2.0),fbm(finalCoords.yx + life / 2.0));
-       n *= fbm((finalCoords + fcOffset) / (nlife / (n * 1.5))) * 1.1;
+       highp vec2 fcOffset = vec2(zFBM(finalCoords.xy + life / 2.0),zFBM(finalCoords.yx + life / 2.0));
+       n *= zFBM((finalCoords + fcOffset) / (nlife / (n * 1.5))) * 1.1;
        n *= clamp(nlife, 0.0, 1.0);
        highp float a = 0.0; // Alpha
        highp float p = 0.0; // Position between L and R stops
index 85c984ee12493c05198c7974be58e003572b9eef..6e474abb1aeb7aa32b014c8614100952e8578934 100644 (file)
@@ -14,48 +14,44 @@ const highp float CenterColorRadius = 250.0; // radius of the gradient used to t
 const highp float CenterColorMinDist = 0.2; // minimum distance from the center of the screen for the color to appear at all
 const highp float CenterColorPow = 1.25; // the exponent used for the color's center
 
-// hash(),  noise(), and hsv2rgb_smooth() were converted from shadertoy examples, which were released under the MIT License:
+// noise() and hsv2rgb_smooth() were converted from shadertoy examples, which were released under the MIT License:
 // The MIT License
 // Copyright © 2013 Inigo Quilez
 // Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 // https://www.youtube.com/c/InigoQuilez
 // https://iquilezles.org
-highp vec2 hash( highp vec2 p ) {
-       p = vec2( dot(p,vec2(127.1,311.7)), dot(p,vec2(269.5,183.3)) );
-       return -1.0 + 2.0*fract(sin(p)*43758.5453123);
-}
 
 highp float noise( highp vec2 p ) {
     const highp float K1 = 0.366025404;
     const highp float K2 = 0.211324865;
 
-       highp vec2  i = floor( p + (p.x+p.y)*K1 );
+    highp vec2  i = floor( p + (p.x+p.y)*K1 );
     highp vec2  a = p - i + (i.x+i.y)*K2;
     highp float m = step(a.y,a.x); 
     highp vec2  o = vec2(m,1.0-m);
     highp vec2  b = a - o + K2;
-       highp vec2  c = a - 1.0 + 2.0*K2;
+    highp vec2  c = a - 1.0 + 2.0*K2;
     highp vec3  h = max( 0.5-vec3(dot(a,a), dot(b,b), dot(c,c) ), 0.0 );
-       highp vec3  n = h*h*h*h*vec3( dot(a,hash(i+0.0)), dot(b,hash(i+o)), dot(c,hash(i+1.0)));
+    highp vec3  n = h*h*h*h*vec3( dot(a,zRandom(i+0.0)), dot(b,zRandom(i+o)), dot(c,zRandom(i+1.0)));
     return dot( n, vec3(70.0) );
 }
 
 highp vec3 hsv2rgb_smooth( highp vec3 c ) {
     highp vec3 rgb = clamp( abs(mod(c.x*6.0+vec3(0.0,4.0,2.0),6.0)-3.0)-1.0, 0.0, 1.0 );
-       rgb = rgb*rgb*(3.0-2.0*rgb);
-       return c.z * mix( vec3(1.0), rgb, c.y);
+    rgb = rgb*rgb*(3.0-2.0*rgb);
+    return c.z * mix( vec3(1.0), rgb, c.y);
 }
 
 
 highp float mixNoise(highp vec2 point, highp float phase) {
     highp float time = TIME * TimeScale + phase;
-       highp float a = noise( NoiseScale * point - time);
+    highp float a = noise( NoiseScale * point - time);
     highp float b = noise( NoiseScale * point + time );
     return mix(a,b,0.5);
 }
 
 highp float genGradient(highp vec2 center, highp vec2 coord, highp float radius, highp float dist, highp float power) {
-    return pow(min(max((length(center - coord) / radius) - dist, 0.0), 1.0), power);
+    return pow(clamp((length(center - coord) / radius) - dist, 0.0, 1.0), power);
 }
 
 void fragment() {