Introduction
Have you ever visited ShaderToy? Most ShaderToy demos use a technique called ray marching. Ray marching is a graphical technique which, like its more well known sibling ray tracing, renders an image by casting rays into a scene filled with objects.
Who's this guide for?โ
Anyone interested in ray marching and the demoscene. You need some background in programming, vector math, and trigonometry to follow along. The more you know, the easier it'll be.
What's this guide for?โ
This tutorial introduces you to some key ray marching techniques. With each technique, you'll add to a basic "Hello World" raymarching program. By the end of the process, you'll have recreated this looping animation:
Ray tracingโ
Imagine shooting a ray out from your eyes towards each pixel on your computer screen. Your mind "renders" this pixel as a color. Now imagine, instead, that your computer screen is transparent. Each ray continues through your screen until it intersects with whatever object lies behind the screen. Pretend the color visible at this position on the object corresponds to the original pixel. The color your mind "renders" this new "pixel" as is going to depend on:
- The position of intersection: is the object in fog, or in a shadow?
- The object's material: is the object metallic and shiny, or soft and diffuse?
- The kind of light source in the scene: is the light an overhead light, or more like a flashlight?
- The angle between the object's surface and the viewer: is the ray grazing the surface, or hitting the surface head-on?
And so on.
In reality, rays of light travel from light sources, to objects, until finally hitting your eye's retina. But ray tracing works in this backwards way--by shooting rays into a scene through an imaginary grid in front of an imaginary "camera." In our analogy, we used your computer screen itself, with its existing grid of pixels, as the imaginary grid we shot our rays through, while your eyes corresponded to the "camera."
Ray tracing requires that objects in the scene have well defined geometries, like triangle meshes, which have closed solution ray intersection tests. Using these tests, you can determine the nearest position of intersection for each ray.
Ray marching iteratively steps each ray into the scene until it detects an intersection. All you need to do ray marching is a function which returns the distance to each object in the scene. When the distance is negative, or close to zero, you know when to stop.
Ray marching possesses one unique advantage: since distance functions are mathematically defined, you can procedurally generate all kinds of distance functions to render all kinds of cool, abstract shapes.
New to ray marching? This guide briefly covers the basics. Here are some great resources in case you're ever feeling lost or in need of inspiration:
- ๐ Check out this introduction to ray marching from Jamie Wong
- ๐ Check out some videos by Inigo Quelez
- ๐ Check out some videos by The Art of Code
- ๐ Check out the wonderful WebGL fundamentals guide
If you're feeling good, tread on. Code samples are abundant. You may be able to figure out what you need from this guide alone. If not, come back here after following some more basic tutorials.
Inigo Quelez has a useful list of signed distance functions on his website. Bookmark it.