lygia
/v1.1.6
/distort
/barrel
)Barrel distortion
Dependencies:
Use:
barrel(SAMPLER_TYPE tex, <vec2> st [, <vec2|float> sdf])
#ifndef BARREL_DISTANCE
#define BARREL_DISTANCE dist
#endif
#ifndef BARREL_TYPE
#define BARREL_TYPE vec3
#endif
#ifndef BARREL_SAMPLER_FNC
#define BARREL_SAMPLER_FNC(TEX, UV) SAMPLER_FNC(TEX, UV).rgb
#endif
#ifndef FNC_BARREL
#define FNC_BARREL
vec2 barrel(vec2 st, float amt, float dist) {
return st + (st-.5) * (BARREL_DISTANCE) * amt;
}
vec2 barrel(vec2 st, float amt) {
return barrel(st, amt, lengthSq(st-.5));
}
BARREL_TYPE barrel(in SAMPLER_TYPE tex, in vec2 st, float dist) {
BARREL_TYPE a1 = BARREL_SAMPLER_FNC(tex, barrel(st, .0, dist));
BARREL_TYPE a2 = BARREL_SAMPLER_FNC(tex, barrel(st, .2, dist));
BARREL_TYPE a3 = BARREL_SAMPLER_FNC(tex, barrel(st, .4, dist));
BARREL_TYPE a4 = BARREL_SAMPLER_FNC(tex, barrel(st, .6, dist));
#ifdef BARREL_OCT_1
return (a1+a2+a3+a4)/4.;
#endif
BARREL_TYPE a5 = BARREL_SAMPLER_FNC(tex, barrel(st, .8, dist));
BARREL_TYPE a6 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.0, dist));
BARREL_TYPE a7 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.2, dist));
BARREL_TYPE a8 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.4, dist));
#ifdef BARREL_OCT_2
return (a1+a2+a3+a4+a5+a6+a7+a8)/8.;
#endif
BARREL_TYPE a9 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.6, dist));
BARREL_TYPE a10 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.8, dist));
BARREL_TYPE a11 = BARREL_SAMPLER_FNC(tex, barrel(st, 2.0, dist));
BARREL_TYPE a12 = BARREL_SAMPLER_FNC(tex, barrel(st, 2.2, dist));
return (a1+a2+a3+a4+a5+a6+a7+a8+a9+a10+a11+a12)/12.;
}
BARREL_TYPE barrel(in SAMPLER_TYPE tex, in vec2 st, in vec2 dist) {
return barrel(tex, st, dot(vec2(.5), dist));
}
BARREL_TYPE barrel(in SAMPLER_TYPE tex, in vec2 st) {
return barrel(tex, st, lengthSq(st-.5));
}
#endif
Dependencies:
Use:
barrel(SAMPLER_TYPE tex, <float2> st, [, <float2|float> sdf])
#ifndef BARREL_DISTANCE
#define BARREL_DISTANCE dist
#endif
#ifndef BARREL_TYPE
#define BARREL_TYPE float3
#endif
#ifndef BARREL_SAMPLER_FNC
#define BARREL_SAMPLER_FNC(TEX, UV) SAMPLER_FNC(TEX, UV).rgb
#endif
#ifndef FNC_BARREL
#define FNC_BARREL
float2 barrel(float2 st, float amt, float dist) {
return st + (st-.5) * (BARREL_DISTANCE) * amt;
}
float2 barrel(float2 st, float amt) {
return barrel(st, amt, lengthSq(st-.5));
}
BARREL_TYPE barrel(in SAMPLER_TYPE tex, in float2 st, float offset) {
BARREL_TYPE a1 = BARREL_SAMPLER_FNC(tex, barrel(st, .0, offset));
BARREL_TYPE a2 = BARREL_SAMPLER_FNC(tex, barrel(st, .2, offset));
BARREL_TYPE a3 = BARREL_SAMPLER_FNC(tex, barrel(st, .4, offset));
BARREL_TYPE a4 = BARREL_SAMPLER_FNC(tex, barrel(st, .6, offset));
#ifdef BARREL_OCT_1
return (a1+a2+a3+a4)/4.;
#endif
BARREL_TYPE a5 = BARREL_SAMPLER_FNC(tex, barrel(st, .8, offset) );
BARREL_TYPE a6 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.0, offset) );
BARREL_TYPE a7 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.2, offset) );
BARREL_TYPE a8 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.4, offset) );
#ifdef BARREL_OCT_2
return (a1+a2+a3+a4+a5+a6+a7+a8)/8.;
#endif
BARREL_TYPE a9 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.6, offset));
BARREL_TYPE a10 = BARREL_SAMPLER_FNC(tex, barrel(st, 1.8, offset));
BARREL_TYPE a11 = BARREL_SAMPLER_FNC(tex, barrel(st, 2.0, offset));
BARREL_TYPE a12 = BARREL_SAMPLER_FNC(tex, barrel(st, 2.2, offset));
return (a1+a2+a3+a4+a5+a6+a7+a8+a9+a10+a11+a12)/12.;
}
BARREL_TYPE barrel(in SAMPLER_TYPE tex, in float2 st, in float2 offset) {
return barrel(tex, st, dot(float2(.5, .5), offset));
}
BARREL_TYPE barrel(in SAMPLER_TYPE tex, in float2 st) {
return barrel(tex, st, lengthSq(st-.5));
}
#endif
LYGIA is dual-licensed under the Prosperity License and the Patron License for sponsors and contributors.
Sponsors and contributors are automatically added to the Patron License and they can ignore the any non-commercial rule of the Prosperity Licensed software (please take a look to the exception).
It's also possible to get a permanent comercial license hook to a single and specific version of LYGIA.
Sign up for the news letter bellow, joing the LYGIA's channel on Discord or follow the Github repository