MiniRT is a simple ray tracer built using minilibx that is capable of rendering planes, spheres, cylinders (mandatory part), and cones (bonus part) to generate a 2D image representing the 3D scene. The ray tracer features light management, including spot brightness, hard shadows, and ambiance lighting (objects are never completely in the dark). It implements ambient and diffuse lighting in the mandatory part, and ambient, diffuse, and specular lighting in the bonus part.
composition.rt1
The ray tracing technique used in MiniRT consists of the following steps:
- Ray Construction: For each pixel on the screen, a ray is constructed based on the camera's position, look direction, and the normal of the pixel.
- Intersection Tests: The ray is tested for intersections with each object in the scene. The intersection tests are handled by specific functions for each geometric primitive, such as
hit_plane
,hit_sphere
,hit_cone
, andhit_cylinder
. - Color Calculation: If the ray intersects an object, the color of the intersection point is calculated based on the object's material and the light sources in the scene. Shadows are also taken into account by checking if there are any objects blocking the light from reaching the intersection point.
- Rendering: The color of the intersection point is used to set the color of the corresponding pixel in the final 2D image.
The ray tracing technique used here is simple but effective for rendering scenes with basic geometric primitives and lighting.
- Render planes, spheres, cylinders, and cones
- Light management: spot brightness, hard shadows, and ambiance lighting
- Ambient and diffuse lighting (mandatory part)
- Ambient, diffuse, and specular lighting (bonus part)
- Resize objects by changing the
.rt
scene content - Correctly handles all possible intersections and the inside of objects
- Built-in parser to ensure
.rt
files have no invalid entries
git clone https://github.com/42Paris/minilibx-linux
cd minilibx-linux
apt-get install libxext-dev libxrandr-dev libx11-dev libbsd-dev libssl-dev
mv minilibx-linux/man/man1 to /usr/local/man/
mv minilibx-linux/libmlx.a to /usr/local/lib/
mv minilibx-linux/mlx.h to /usr/local/include/
Clone the repository using:
git clone git@github.com:Guiribei/minirt.git
Compile the project:
make
After compile the project (make bonus for bonus part), you can run the executable using one scene as parameter.
./miniRT scenes/[scene_file.rt]
To render a scene, provide a valid .rt
. The ray tracer will resize objects based on its unique properties defined in the file.
A valid scene file with the .rt
extension must (at least) contain:
- A camera definition
- A light definition
- An ambient light definition
Additional objects and settings can be included in the scene file to customize the scene.
Here is a brief excerpt of the code:
void render_scene(t_minirt *minirt, t_hittable_list *world)
{
t_vector normal;
t_vector loop;
t_ray ray;
t_color color;
t_light point_light;
turn_on_camera(&minirt->camera, (WIDTH / HEIGHT));
point_light = minirt->light;
loop.x = 0;
while (loop.x < WIDTH)
{
loop.y = 0;
while (loop.y < HEIGHT)
{
normal.x = (double)loop.x / (WIDTH - 1);
normal.y = (double)loop.y / (HEIGHT - 1);
ray = ray_constructor(&minirt->camera, normal);
color = ray_color(ray, world, point_light);
mlx_pixel_draw(&minirt->img, loop.x, loop.y,
color_create_rgb(&color));
loop.y++;
}
loop.x++;
}
}
This is a basic implementation of a ray tracing renderer, and improvements can be made in various aspects, such as performance optimization, support for more complex materials and lighting models, and the addition of more geometric primitives.
For a more in-depth look at the code, see the full implementation.
Footnotes
-
Scene created by @sgkhusal, avaliable at: https://github.com/sgkhusal/42-miniRT/blob/main/scenes/composition.rt ↩