I wanted to test out WebGL's capabilities for path tracing after viewing Evan Wallace's path tracer, but with more features and corrected realism/gamma.
Rays are fired from the camera out into the scene, bounce around according to physical models, and record when they hit a light source. Whenever anything changes, the scene has to be re-traced (it starts out noisy, but converges to the correct image).
Try out the demo!
data:image/s3,"s3://crabby-images/89eb7/89eb70c50c29c7f768966dd004c6c52959f3b12c" alt="View of spheres of different materials, over a wooden floor"
It includes full fresnel simulation of dielectrics, depth of field tone mapping, and caustics, but not spectral or polarized light. Spectral is generally supported, but the environment maps don't have spectral data.
data:image/s3,"s3://crabby-images/5211e/5211e3efb39171850646c75f7f83d6c82494deed" alt="Caustics and tone mapping"
data:image/s3,"s3://crabby-images/65d9e/65d9e917fde6942fe1641b63a73df038e06e5aed" alt="Bump mapping and procedural BRDFs"
Projections
It is capable of different projections:
data:image/s3,"s3://crabby-images/1e07d/1e07dc484f6beb3b4e7386fff961c0db89bab5a6" alt="Stereographic projection"
data:image/s3,"s3://crabby-images/5e917/5e917a985dccbec475ba87a6273c43ee62108245" alt="Orthographic projection"
Signed Distance Fields (SDFs)
I also experimented with signed distance fields (SDFs) based on Inigo Quilez's work. It included modeling an IKEA Pokal glass as a single formula.
data:image/s3,"s3://crabby-images/c6a1e/c6a1e690d216bce8dd13a9ac8e9ee39d0541632f" alt="Cross section view of the glass SDF"
data:image/s3,"s3://crabby-images/f70da/f70da16e6b698ab2c8c67b60d71e5a8bb2921509" alt="Opaque black view of the glass"
data:image/s3,"s3://crabby-images/f740b/f740bca7526b70e170b70331313b1766d635b233" alt="Normal rendering of the glass"
Procedural Texturing
I also experimented with using the projection of a dodecahedron to bump-map/texture a soccer ball.
data:image/s3,"s3://crabby-images/76f85/76f858a807f768193a188e3a1274fe6ab83f2236" alt="Dodecahedron-based procedural bump mapping and texturing of a sphere to look like a soccer ball"