Caper

crates.io version Build status Documentation

Minimalist game framework using rust. Currently has systems for: - Rendering (glium) - Input (winit via volition) - Physics (nphysics) - Audio (rodio via impose)

Documentation

Setup

Linux

Due to the crate alsa-sys being use for linux the following packages are required:

Debian/Ubuntu etc

apt install libasound2-dev pkg-config

Fedora/RHEL/CentOS

dnf install alsa-lib-devel

Usage

Example of a basis for a game: ```rust extern crate caper;

use caper::game::*; use caper::imgui::Ui; use caper::input::Key; use caper::mesh::gencube; use caper::types::{DefaultTag, RenderItemBuilder, TransformBuilder}; use caper::utils::handlefp_inputs;

fn main() { // crate an instance of the game struct let (mut game, event_loop) = Game::::new();

// define some items to be rendered
game.add_render_item(
    RenderItemBuilder::default()
        .vertices(gen_cube())
        .instance_transforms(vec![TransformBuilder::default()
            .pos((-0.5, 0.0, -5.0))
            .build()
            .unwrap()])
        .build()
        .unwrap(),
);

event_loop.run(move |event, _, _control_flow| {
    // run the engine update
    game.update(
        |_: &Ui| {},
        |g: &mut Game<DefaultTag>| -> UpdateStatus {
            // update the first person inputs
            handle_fp_inputs(&mut g.input, &mut g.cams[0]);

            // quit
            if g.input.keys_down.contains(&Key::Escape) {
                return UpdateStatus::Finish;
            }

            UpdateStatus::Continue
        },
        event,
    );
});

} ```

Check out the examples and run with: cargo run --example transforms

License