mirror of
https://github.com/DigvijaysinhGohil/Godot-Shader-Lib.git
synced 2025-01-08 10:23:24 +08:00
Artistic nodes code refactored
This commit is contained in:
parent
578a78df0b
commit
088c80aa2b
@ -1,4 +1,4 @@
|
|||||||
vec3 contrast(vec3 input, float contrast){
|
vec3 contrast(vec3 input, float contrast){
|
||||||
float midpoint = pow(0.5, 2.2);
|
float midpoint = pow(0.5, 2.2);
|
||||||
return (input - midpoint) * contrast + midpoint;
|
return (input - midpoint) * contrast + midpoint;
|
||||||
}
|
}
|
@ -1,14 +1,14 @@
|
|||||||
vec3 hue(vec3 input, float offset, int range_index){
|
vec3 hue(vec3 input, float offset, int range_index){
|
||||||
// RGB to HSV
|
// RGB to HSV
|
||||||
vec4 k = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);
|
vec4 k = vec4(0.0, -1.0 / 3.0, 2.0 / 3.0, -1.0);
|
||||||
vec4 p = mix(vec4(input.bg, k.wz), vec4(input.gb, k.xy), step(input.b, input.g));
|
vec4 p = mix(vec4(input.bg, k.wz), vec4(input.gb, k.xy), step(input.b, input.g));
|
||||||
vec4 q = mix(vec4(p.xyw, input.r), vec4(input.r, p.yzx), step(p.x, input.r));
|
vec4 q = mix(vec4(p.xyw, input.r), vec4(input.r, p.yzx), step(p.x, input.r));
|
||||||
float d = q.x - min(q.w, q.y);
|
float d = q.x - min(q.w, q.y);
|
||||||
float e = 1.0e-10;
|
float e = 1.0e-10;
|
||||||
vec3 hsv = vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);
|
vec3 hsv = vec3(abs(q.z + (q.w - q.y) / (6.0 * d + e)), d / (q.x + e), q.x);
|
||||||
|
|
||||||
offset = (range_index == 0) ? offset / 360.0 : offset;
|
offset = (range_index == 0) ? offset / 360.0 : offset;
|
||||||
float hue = hsv.x + offset;
|
float hue = hsv.x + offset;
|
||||||
if(hue < 0.0){
|
if(hue < 0.0){
|
||||||
hsv.x = hue + 1.;
|
hsv.x = hue + 1.;
|
||||||
}
|
}
|
||||||
@ -20,8 +20,8 @@ vec3 hue(vec3 input, float offset, int range_index){
|
|||||||
}
|
}
|
||||||
|
|
||||||
// HSV to RGB
|
// HSV to RGB
|
||||||
vec4 k2 = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);
|
vec4 k2 = vec4(1.0, 2.0 / 3.0, 1.0 / 3.0, 3.0);
|
||||||
vec3 p2 = abs(fract(hsv.xxx + k2.xyz) * 6.0 - k2.www);
|
vec3 p2 = abs(fract(hsv.xxx + k2.xyz) * 6.0 - k2.www);
|
||||||
vec3 rgb = hsv.z * mix(k2.xxx, clamp(p2 - k2.xxx, 0.0, 1.0), hsv.y);
|
vec3 rgb = hsv.z * mix(k2.xxx, clamp(p2 - k2.xxx, 0.0, 1.0), hsv.y);
|
||||||
return rgb;
|
return rgb;
|
||||||
}
|
}
|
@ -1,4 +1,4 @@
|
|||||||
vec3 replace_color(vec3 input, vec3 from, vec3 to, float range, float fuzziness){
|
vec3 replace_color(vec3 input, vec3 from, vec3 to, float range, float fuzziness){
|
||||||
float dist = distance(from, input);
|
float dist = distance(from, input);
|
||||||
return mix(to, input, clamp((dist - range) / max(fuzziness, 1.0e-5), 0.0, 1.0));
|
return mix(to, input, clamp((dist - range) / max(fuzziness, 1.0e-5), 0.0, 1.0));
|
||||||
}
|
}
|
@ -1,4 +1,4 @@
|
|||||||
vec3 saturation(vec3 input, float saturation){
|
vec3 saturation(vec3 input, float saturation){
|
||||||
float luma = dot(input, vec3(0.2126729, 0.7151522, 0.0721750));
|
float luma = dot(input, vec3(0.2126729, 0.7151522, 0.0721750));
|
||||||
return luma + saturation * (input - vec3(luma));
|
return luma + saturation * (input - vec3(luma));
|
||||||
}
|
}
|
Loading…
x
Reference in New Issue
Block a user