Dev Log: Distortion Shaders
I should be working on this example game for my framework, but instead I'm extending my stay in shader town to try and figure out some other stuff. I managed to get a basic distortion map going which looked like this:
data:image/s3,"s3://crabby-images/3753b/3753bbd056dc2ae0dec5b4d4545e9893b2bf4984" alt="Image"
And then after that I played around with my old friends sine and cosine and was able to make a cool animated wave effect on the screen:
data:image/s3,"s3://crabby-images/d5cda/d5cdad85bae387e42468628fca69027610c9b8c2" alt="Image"
Here's the code for the first shader:
And the second:
data:image/s3,"s3://crabby-images/3753b/3753bbd056dc2ae0dec5b4d4545e9893b2bf4984" alt="Image"
And then after that I played around with my old friends sine and cosine and was able to make a cool animated wave effect on the screen:
data:image/s3,"s3://crabby-images/d5cda/d5cdad85bae387e42468628fca69027610c9b8c2" alt="Image"
Here's the code for the first shader:
uniform sampler2D texture;
uniform sampler2D anothertexture;
void main() {
vec2 coord = gl_TexCoord[0].xy;
vec4 other_color = texture2D(anothertexture, coord);
vec4 pixel_color = texture2D(texture, coord + other_color.rg - 0.5);
vec4 final_color = pixel_color;
final_color.rgb += other_color.rgb;
final_color.rgb /= 2;
gl_FragColor = pixel_color;
}
uniform sampler2D texture;
uniform float timer;
void main() {
vec2 coord = gl_TexCoord[0].xy;
coord.x += sin(radians(timer + coord.y * 500)) * 0.07;
coord.y += cos(radians(timer + coord.x * 250)) * 0.03;
vec4 pixel_color = texture2D(texture, coord);
gl_FragColor = pixel_color;
}
Comments
Post your comment!