#material #refraction #ferox

app ferox

Ferox is a ray-tracing renderer written in Rust

12 unstable releases (3 breaking)

Uses new Rust 2024

new 0.5.0 Apr 6, 2025
0.4.8 Apr 4, 2025
0.3.2 Apr 1, 2025
0.2.0 Apr 1, 2025

#49 in Graphics APIs

Download history 1027/week @ 2025-03-30

1,027 downloads per month

CC0 license

4MB
455 lines

Overview

Ferox is a ray-tracing renderer written in Rust.

Currently, it is capable of detecting ray intersections with simple spheres and displaying those calculations in PNG form.

This project is made possible with the help of assets like https://www.scratchapixel.com and ssloy's tiny ray tracer (https://github.com/ssloy/tinyraytracer).

Usage

The crate can be installed using cargo install ferox.

In its current state, running ferox will just render and output the default scene as specified in main.rs in whatever directory ferox is called from.

To experiment with the engine, it is recommended to download the source code and adjust the scene parameters manually.

I am planning on adding support for JSON-based scene loading and overrideable output settings, but those will be secondary to the core raytracing features that remain to be implemented.

Roadmap

  • Image output
  • Sphere outlines
  • Sphere materials
  • Lighting
  • Specularity
  • Shadows
  • Reflections
  • Refraction
  • Environment map support
  • Additional object types and meshes
  • Refactor codebase for readability
  • Loadable scene configurations
  • CLI image generation and output options
  • GUI with parametric support
  • Real-time calculations and camera movement

Dependencies

~10MB
~247K SLoC