glsl-barrel-pincushion
data:image/s3,"s3://crabby-images/9cb3b/9cb3b2d817a68cad072c075d591ac68c5f50b503" alt="stable"
Distort the UV with barrel or pincushion effect.
Adapted from this shadertoy.
data:image/s3,"s3://crabby-images/2e7c9/2e7c9b4d8be1d81b426700c5fc09a3b0f366490f" alt="glsl-barrel-pincushion"
Installation :package:
npm i glsl-barrel-pincushion -S
Usage :book:
barrelPincushion(vec2 st, float strength)
strength > 0 for barrel distortion, strength < 0 for pincushion.
Example :floppy_disk:
uniform float uTime;
#pragma glslify: barrelPincushion = require(glsl-barrel-pincushion)
#pragma glslify: rectangle = require(glsl-2d-primitives/rectangle)
attribute vec2 vUv;
void main() {
vec2 st = barrelPincushion(vUv, sin(uTime));
float shape = rectangle(st, vec2(0.5));
gl_FragColor = vec4(color, shape);
}
Demo
License :pencil:
MIT. See LICENSE for details.