#bevy #graphics #gamedev #2d-3d #game-engine #2d-graphics #graphics-engine

bevy_vector_shapes

A library for rendering vector shapes using the Bevy game engine

22 unstable releases (6 breaking)

0.7.0 Feb 17, 2024
0.6.0 Nov 4, 2023
0.5.2 Sep 16, 2023
0.5.0 Jul 9, 2023

#180 in Game dev

Download history 77/week @ 2024-01-01 68/week @ 2024-01-08 57/week @ 2024-01-15 37/week @ 2024-01-22 23/week @ 2024-01-29 42/week @ 2024-02-05 143/week @ 2024-02-12 185/week @ 2024-02-19 115/week @ 2024-02-26 115/week @ 2024-03-04 99/week @ 2024-03-11 48/week @ 2024-03-18 13/week @ 2024-03-25 80/week @ 2024-04-01 84/week @ 2024-04-08 51/week @ 2024-04-15

235 downloads per month
Used in 2 crates

MIT/Apache

155KB
3.5K SLoC

Rust 3K SLoC // 0.0% comments WebGPU Shader Language 764 SLoC // 0.2% comments

Bevy Vector Shapes

crates.io docs.rs CI Bevy tracking

Bevy Vector Shapes

What is Bevy Vector Shapes?

Bevy Vector Shapes is a library for easily and ergonomically creating instanced vector shapes in Bevy.

WARNING

Bevy Vector Shapes is in the early stages of development. You may encounter issues, but feel free to report them.

Features

  • Variety of built in shape types: lines, rectangles, circles, arcs and regular polygons.
  • Traits to allow implementation of custom shape types.
  • Supports various bevy rendering features: 2D and 3D pipelines, transparency, alpha modes, render layers, bloom.
  • Canvas API for rendering shapes to a texture.
  • Ability to draw textures on shapes, including canvas textures.
  • Immediate and retained mode.
  • Local anti-aliasing for smoother looking shapes.
  • Optional billboarding for each shape type to ensure they are always facing the camera.
  • Shapes of the same type and rendering configuration are fully instanced together.
  • Compilation to wasm to run your projects in the browser.

Usage

See basic usage below and the examples for more details on all supported features.

use bevy::prelude::*;
// Import commonly used items
use bevy_vector_shapes::prelude::*;

fn main() {
    App::new()
        .add_plugins(DefaultPlugins)
        // Add the shape plugin:
        // - Shape2dPlugin for 2D cameras
        // - ShapePlugin for both 3D and 2D cameras
        .add_plugins(Shape2dPlugin::default())
        .add_systems(Startup, setup)
        .add_systems(Update, draw)
        .run();
}

fn setup(mut commands: Commands) {
    // Spawn the camera
    commands.spawn(Camera2dBundle::default());
}

fn draw(mut painter: ShapePainter) {
    // Draw a circle
    painter.circle(100.0);
}
bevy bevy_vector_shapes
0.13 0.7.0
0.12 0.6.0
0.11 0.5.2
0.10 0.4.6

Alternatives

  • bevy_smud: for generating custom sdf expressions at run time.
  • bevy_protoype_lyon: for generating meshes from 2D shapes and paths.
  • vello: for very efficient 2D shape rendering to images.

Dependencies

~43–83MB
~1.5M SLoC