euc

A 3D rendering crate that lets you write shaders in Rust.

Example rendering

Example

```rust struct Triangle;

impl Pipeline for Triangle { type Uniform = (); type Vertex = [f32; 2]; type VsOut = (); type Pixel = [u8; 4];

// Vertex shader
fn vert(_: &Self::Uniform, pos: &Self::Vertex) -> ([f32; 3], Self::VsOut) {
    ([pos[0], pos[1], 0.0], ())
}

// Fragment shader
fn frag(_: &Self::Uniform, _: &Self::VsOut) -> Self::Pixel {
    [255, 0, 0, 255] // Red
}

}

fn main() { let mut color = Buffer2d::new([640, 480], [0; 4]); let mut depth = Buffer2d::new([640, 480], 1.0);

Triangle::draw::<rasterizer::Triangles<_>, _>(
    &(),
    &[
        [-1.0, -1.0],
        [ 1.0, -1.0],
        [ 0.0,  1.0],
    ],
    &mut color,
    &mut depth,
);

} ```

See examples/ for more code example.

What is euc?

euc is a versatile, simple to use crate that allows 3D rendering on the CPU.

Why?

Release Mode

Cargo, by default, compiles Rust code in debug mode. In this mode, very few optimisations are made upon the code, and as a result the performance of software rendering tends to suffer. To experience this project with good performance, make sure to compile with the --release flag.

no_std

euc can be compiled on platforms that lack standard library supports. This makes it ideal for rendering 3D graphics on embedded devices. You can enable no_std support by enabling the nightly feature in your Cargo.toml file like so:

[dependencies] euc = { version = "x.y.z", features = ["nightly"] }

Goals

Non-Goals

License

euc is distributed under either of:

at the disgression of the user.