mirror of
https://github.com/scratchfoundation/bgfx.git
synced 2024-12-11 16:51:32 -05:00
97 lines
2.3 KiB
Text
97 lines
2.3 KiB
Text
#version 300 es
|
|
float xll_mod( float x, float y ) {
|
|
float d = x / y;
|
|
float f = fract (abs(d)) * y;
|
|
return d >= 0.0 ? f : -f;
|
|
}
|
|
vec2 xll_mod( vec2 x, vec2 y ) {
|
|
vec2 d = x / y;
|
|
vec2 f = fract (abs(d)) * y;
|
|
return vec2 (d.x >= 0.0 ? f.x : -f.x, d.y >= 0.0 ? f.y : -f.y);
|
|
}
|
|
vec3 xll_mod( vec3 x, vec3 y ) {
|
|
vec3 d = x / y;
|
|
vec3 f = fract (abs(d)) * y;
|
|
return vec3 (d.x >= 0.0 ? f.x : -f.x, d.y >= 0.0 ? f.y : -f.y, d.z >= 0.0 ? f.z : -f.z);
|
|
}
|
|
vec4 xll_mod( vec4 x, vec4 y ) {
|
|
vec4 d = x / y;
|
|
vec4 f = fract (abs(d)) * y;
|
|
return vec4 (d.x >= 0.0 ? f.x : -f.x, d.y >= 0.0 ? f.y : -f.y, d.z >= 0.0 ? f.z : -f.z, d.w >= 0.0 ? f.w : -f.w);
|
|
}
|
|
float xll_modf( float x, out int ip) {
|
|
ip = int (x);
|
|
return x-float(ip);
|
|
}
|
|
float xll_modf( float x, out float ip) {
|
|
int i = int (x);
|
|
ip = float(i);
|
|
return x-ip;
|
|
}
|
|
vec2 xll_modf( vec2 x, out ivec2 ip) {
|
|
ip = ivec2 (x);
|
|
return x-vec2(ip);
|
|
}
|
|
vec2 xll_modf( vec2 x, out vec2 ip) {
|
|
ivec2 i = ivec2 (x);
|
|
ip = vec2(i);
|
|
return x-ip;
|
|
}
|
|
vec3 xll_modf( vec3 x, out ivec3 ip) {
|
|
ip = ivec3 (x);
|
|
return x-vec3(ip);
|
|
}
|
|
vec3 xll_modf( vec3 x, out vec3 ip) {
|
|
ivec3 i = ivec3 (x);
|
|
ip = vec3(i);
|
|
return x-ip;
|
|
}
|
|
vec4 xll_modf( vec4 x, out ivec4 ip) {
|
|
ip = ivec4 (x);
|
|
return x-vec4(ip);
|
|
}
|
|
vec4 xll_modf( vec4 x, out vec4 ip) {
|
|
ivec4 i = ivec4 (x);
|
|
ip = vec4(i);
|
|
return x-ip;
|
|
}
|
|
|
|
mediump vec4 xlat_main (in highp vec4 uv)
|
|
{
|
|
mediump vec4 c;
|
|
mediump vec4 d;
|
|
c = vec4( 0.000000);
|
|
c.x += xll_mod( uv.x , 2.00000);
|
|
c.xy += xll_mod( uv.xy , vec2( 2.00000));
|
|
c.xyz += xll_mod( uv.xyz , vec3( 2.00000));
|
|
c.xyzw += xll_mod( uv.xyzw , vec4( 2.00000));
|
|
c.x += xll_modf( uv.x , d.x );
|
|
c.xy += xll_modf( uv.xy , d.xy );
|
|
c.xyz += xll_modf( uv.xyz , d.xyz );
|
|
c.xyzw += xll_modf( uv.xyzw , d.xyzw );
|
|
|
|
// GLSL mod function
|
|
c.x += mod(uv.x, d.x);
|
|
c.xy += mod(uv.xy, d.xy);
|
|
c.xyz += mod(uv.xyz, d.xyz);
|
|
|
|
// inverse
|
|
c.x += 1.0/uv.x; // float
|
|
c.x += max(0.0, 1.0/uv.x);
|
|
|
|
c.y += 1.0/c.z; // half
|
|
c.y += max(0.0, 1.0/c.w);
|
|
|
|
// max with different precision arguments
|
|
c.x += max(uv.x, c.z);
|
|
|
|
return c;
|
|
}
|
|
|
|
in highp vec4 xlv_TEXCOORD0;
|
|
out mediump vec4 _fragData;
|
|
void main() {
|
|
mediump vec4 xl_retval;
|
|
xl_retval = xlat_main( vec4(xlv_TEXCOORD0));
|
|
_fragData = vec4( xl_retval);
|
|
}
|