Shadertoy
Shadertoy is an online community and tool for creating and sharing shaders through WebGL, used for both learning and teaching 3D computer graphics in a web browser. OverviewShadertoy is an online community and platform for computer graphics professionals, academics[1] and enthusiasts who share, learn and experiment with rendering techniques and procedural art through GLSL code. There are more than 52 thousand public contributions as of mid-2021 coming from thousands of users. WebGL[2] allows Shadertoy to access the compute power of the GPU to generate procedural art, animation, models, lighting, state based logic and sound. HistoryShadertoy was created by Pol Jeremias and Inigo Quilez in January 2013 and came online in February the same year. The roots of the effort are in Inigo's "Shadertoy" section [3] in his computer graphics educational website.[4] With the arrival of the initial WebGL implementation by Mozilla's Firefox in 2009, Quilez created the first online live coding environment and curated repository of procedural shaders. This content was donated by 18 authors from the Demoscene and showcased advanced real-time and interactive animations never seen in the Web before, such as raymarched metaballs, fractals and tunnel effects. After having worked together in several real-time rendering projects together for years, in December 2012 Quilez and Pol decided to create a new Shadertoy site that would follow the tradition of the original Shadertoy page with its demoscene flavored resource and size constrained real-time graphics content, but would add social and community features and embrace an open-source attitude. The page came out with the live editor, real-time playback, browsing and searching capabilities, tagging and commenting features. Content wise, Shadertoy provided a fixed and limited set of textures for its users to utilize in creative ways. Over the years Shadertoy added extra features, such as webcam and microphone input support, video, music, Virtual Reality rendering and multi-pass rendering. There are over 31 thousand contributions in total from thousands of users, several of which are referenced in academic papers. Shadertoy also hosts annual competitions and events for its community to enjoy, such as the Siggraph 2015 Shadertoy Competition[5] Features
Usage
An example of a procedural animation created in Shadertoy could be the following square tunnel: void mainImage(out vec4 fragColor, in vec2 fragCoord)
{
// input: pixel coordinates
vec2 p = (-iResolution.xy + 2.0 * fragCoord) / iResolution.y;
// angle of each pixel to the center of the screen
float a = atan(p.y, p.x);
// modified distance metric
float r = pow(pow(p.x * p.x, 4.0) + pow(p.y * p.y, 4.0), 1.0/8.0);
// index texture by (animated inverse) radius and angle
vec2 uv = vec2(1.0 / r + 0.2 * iTime, a);
// pattern: cosines
float f = cos(12.0 * uv.x) * cos(6.0 * uv.y);
// color fetch: palette
vec3 col = 0.5 + 0.5 * sin(3.1416 * f + vec3(0.0, 0.5, 1.0));
// lighting: darken at the center
col = col * r;
// output: pixel color
fragColor = vec4(col, 1.0);
}
The code above generates the following image: MentionsShadertoy is referenced in several sources:
References
External links |