Retro Sun 2D

This shader is a canvas_item shader based on Overloaded’s Linear Gradient and my own spatial_shader version

It extends the basic functionality to include features like transparency, and the iconic outrun-style moving lines.

Features:

  • Gradient Color: Create a vertical gradient between two colors.
  • Emission Control: Set the intensity of the glow effect.
  • Transparency: Maintain the transparency of the original texture.
  • Moving Lines: Add multiple horizontal lines that move from the top to the bottom, with customizable height, speed and vertical origin.

Usage:

  1. Apply this shader to a 2D texture in Godot.
  2. Adjust the colors, emission intensity, number of lines, and speed to fit your aesthetic needs.
Shader code
shader_type canvas_item;

uniform sampler2D texture_albedo : source_color;
uniform vec4 color_top : source_color = vec4(1.0, 0.0, 0.0, 1.0);
uniform vec4 color_bottom : source_color = vec4(0.0, 0.0, 1.0, 1.0);
uniform float position : hint_range(-0.5, 0.5) = 0.0;
uniform float blend : hint_range(0.5, 2.0) = 0.5;
uniform float angle : hint_range(0.0, 360.0) = 90.0;

uniform float line_height_min : hint_range(0.0, 1.0) = 0.01;
uniform float line_height_max : hint_range(0.0, 1.0) = 0.1;
uniform int num_lines : hint_range(1, 10) = 6;
uniform float speed : hint_range(0.0, 1.0) = 0.1;
uniform float vertical_origin : hint_range(0.0, 1.0) = 0.0;

void fragment() {
    vec4 tex_color = texture(texture_albedo, UV);

    float pivot = position + 0.5;
    vec2 uv = UV - vec2(pivot);
    float radians_angle = radians(angle);
    float rotated = uv.x * cos(radians_angle) - uv.y * sin(radians_angle);
    float pos = smoothstep((1.0 - blend) + position, blend + 0.0001 + position, rotated + pivot);
    vec3 gradient_color = mix(color_bottom.rgb, color_top.rgb, pos);

    float alpha = tex_color.a;

    float moving_position = mod(TIME * speed, 1.0 + line_height_max);
    for (int i = 0; i < num_lines; i++) {
        float line_position = mod(moving_position + float(i) / float(num_lines), 1.0 + line_height_max) - line_height_max;
        float adjusted_position = vertical_origin + (1.0 - vertical_origin) * line_position;
        float line_height = mix(line_height_max, line_height_min, clamp(line_position, 0.0, 1.0));

        float line_alpha = smoothstep(adjusted_position - line_height / 2.0, adjusted_position + line_height / 2.0, UV.y) - smoothstep(adjusted_position + line_height / 2.0, adjusted_position + line_height / 2.0 + 0.01, UV.y);
        alpha *= (1.0 - line_alpha);
    }

    COLOR = vec4(mix(tex_color.rgb, gradient_color, alpha), alpha);
}
Tags
80s, Outrun, retro, Retrowave, Sun, Synthwave, vaporwave
The shader code and all code snippets in this post are under CC0 license and can be used freely without the author's permission. Images and videos, and assets depicted in those, do not fall under this license. For more info, see our License terms.

More from Modern Malick

Retro Sun

Related shaders

Retro Sun

3D – Sun

Shoji Shader (Translucency + Sun Spot)

Subscribe
Notify of
guest

3 Comments
Oldest
Newest Most Voted
Inline Feedbacks
View all comments
DJ_SIMULATOR
2 months ago

great shader! can i use this in my game? full credit given!

DJ_SIMULATOR
2 months ago
Reply to  DJ_SIMULATOR

just noticed the CC0 license, i’ll attribute you anyway, thanks!