hecs-hierarchy

hecs-hierarchy

Cargo Documentation LICENSE

Hierarchy implementation for hecs ECS.

Features

Getting Started

Include both hecs and hecs-hierarchy as dependencies in your Cargo.toml.

hecs-hierarchy does not re-export hecs

toml [dependencies] hecs = 0.5 hecs-hierarchy = 0.1

Motivation

An ECS is a fantastic design principle for designing software which allows a data oriented design. Most of the time, the ECS is flat with maybe a few components referencing each other via Entity ids. Sometimes however, the need to create and manage proper, well behaved graphs, arises.

This is were hecs-hierarchy comes in and gives the ability to manage directed graphs that can connect entities. This is very useful when developing a UI library using the ECS design pattern, or purely for grouping entities together from the same model.

Usage

Import the Hierarchy trait which extends hecs::World

The trait Hierarchy extends hecs::World with functions for manipulating and iterating the hierarchy tree.

The hierarchy uses a marker type which makes it possible for a single entity to belong to several hierarchy trees.

See the documentation, more specifically the Hierarchy trait

Example usage: ```rust use hecs_hierarchy::*;

// Marker type which allows several hierarchies. struct Tree;

let mut world = hecs::World::default();

// Create a root entity, there can be several. let root = world.spawn(("Root",));

// Create a loose entity let child = world.spawn(("Child 1",));

// Attaches the child to a parent, in this case root world.attach::(child, root).unwrap();

// Iterate children for child in world.children::(root) { let name = world.get::<&str>(child).unwrap(); println!("Child: {:?} {}", child, *name); }

// Add a grandchild world.attach_new::(child, ("Grandchild",)).unwrap();

// Iterate recursively for child in world.descendantsdepthfirst::(root) { let name = world.get::<&str>(child).unwrap(); println!("Child: {:?} {}", child, *name) }

// Detach child and grandchild world.detach::(child).unwrap();

let child2 = world.attach_new::(root, ("Child 2",)).unwrap();

// Reattach as a child of child2 world.attach::(child, child2).unwrap();

world.attach_new::(root, ("Child 3",)).unwrap();

// Hierarchy now looks like this: // Root // |-------- Child 3 // |-------- Child 2 // |-------- Child 1 // |-------- Grandchild

```

Inspiration

This project is heavily inspired by Shipyard's hierarchy implementation and exposes a similar API.