#debug #debugging #physics #bevy #collision #shapes #api

heron_debug

Rendering of Heron’s collision shapes for debugging purposes

7 releases (4 breaking)

new 0.5.1 May 1, 2021
0.5.0 Apr 18, 2021
0.4.0 Apr 17, 2021
0.3.0 Mar 21, 2021
0.1.0-alpha.1 Jan 30, 2021

#141 in Games

Download history 18/week @ 2021-01-30 2/week @ 2021-02-06 60/week @ 2021-02-13 5/week @ 2021-02-20 12/week @ 2021-02-27 32/week @ 2021-03-06 11/week @ 2021-03-13 37/week @ 2021-03-20 20/week @ 2021-03-27 21/week @ 2021-04-03 27/week @ 2021-04-10 70/week @ 2021-04-17 31/week @ 2021-04-24 59/week @ 2021-05-01

112 downloads per month
Used in heron

MIT license

71KB
2K SLoC

Heron

License Crates.io Docs dependency status Bevy tracking Build Zenhub

An ergonomic physics API for 2d and 3d bevy games. (powered by rapier)

How it looks like

use bevy::prelude::*;
use heron::prelude::*;

fn main() {
  App::build()
    .add_plugins(DefaultPlugins)
    .add_plugin(PhysicsPlugin::default()) // Add the plugin
    .insert_resource(Gravity::from(Vec3::new(0.0, -9.81, 0.0))) // Optionally define gravity
    .add_startup_system(spawn.system())
    .run();
}

fn spawn(mut commands: Commands) {
    commands

        // Spawn any bundle of your choice. Only make sure there is a `GlobalTransform`
        .spawn_bundle(SpriteBundle::default())

        // Make it a physics body, by attaching a collision shape
        .insert(Body::Sphere { radius: 10.0 })

        // Optionally define a type (if absent, the body will be *dynamic*)
        .insert(BodyType::Kinematic)
        
        // Optionally define the velocity (works only with dynamic and kinematic bodies)
        .insert(Velocity::from(Vec2::X * 2.0));
}

Installation

For a 3d game:

bevy = "^0.5.0"
heron = "0.4.0"

For a 2d game:

bevy = "^0.5.0"
heron = { version = "0.4.0", default-features = false, features = ["2d"] }

Bevy Version Supported

bevy heron
0.5 >= 0.4
0.4 < 0.4

Design principles

  • Use bevy types, resources and components when possible (Vec3, Quat, Transform, Events, etc.)
  • Provide a single API that works for both 2d and 3d. (Like bevy does)
  • Data oriented. Using this library should look like it is part of bevy.
  • Avoid asking the user to lookup in resources via handles. Data should be accessible and modifiable directly in components.
  • Hide the actual physics engine. This is an implementation detail the user shouldn't have to care about.
    • But, allow advanced users to access the underlying rapier resources, so a user is never blocked by a missing element in the API of heron.

Feature flags

One must choose to use either 2d or 3d (but not both). If none of theses two features is enabled, the PhysicsPlugin won't be available.

Enabled by Default

  • 3d Enable simulation on the 3 axes x, y, and z. Incompatible with the feature 2d.

Optional

  • 2d Enable simulation only on the first 2 axes x and y. Incompatible with the feature 3d, therefore require to disable the default features.
  • debug Render collision shapes. Works only in 2d, support for 3d will be added later.

Motivation

I think rapier is very powerful as a physics engine. But using it directly or via bevy_rapier in a bevy game is not ergonomic enough for my taste.

Ideally I would like to have the power of rapier accessible behind an API focused on bevy games.

Contribute / Contact

You can open issues/discussions here or you can discuss with me (Jomag#2675) in the bevy discord

See how to contribute

Dependencies

~11–24MB
~386K SLoC