Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/ten3roberts/hecs-hierarchy

Hierarchy implementation for hecs ECS
https://github.com/ten3roberts/hecs-hierarchy

Last synced: 6 days ago
JSON representation

Hierarchy implementation for hecs ECS

Awesome Lists containing this project

README

        

# hecs-hierarchy

## hecs-hierarchy

[![Cargo](https://img.shields.io/crates/v/hecs-hierarchy.svg)](https://crates.io/crates/hecs-hierarchy)
[![Documentation](https://docs.rs/hecs-hierarchy/badge.svg)](https://docs.rs/hecs-hierarchy)
[![LICENSE](https://img.shields.io/badge/license-MIT-blue.svg)](LICENSE-MIT)

Hierarchy implementation for use with the *hecs* ECS.

### Features
- [X] Iterate children of parent
- [X] Lookup parent of child
- [X] Traverse hierarchy depth first
- [X] Traverse hierarchy breadth first
- [X] Traverse ancestors
- [X] Detach child from hierarchy
- [X] Ergonomic tree building
- [ ] Reverse iteration
- [ ] Sorting
- [ ] (Optional) associated data to relation

### 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](crate::Hierarchy) trait which extends [hecs::World](hecs::World)

The trait [Hierarchy](crate::Hierarchy) extends [hecs::World](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](https://docs.rs/hecs-hierarchy), more specifically the
[Hierarchy](https://docs.rs/hecs-hierarchy/0.1.7/hecs_hierarchy/trait.Hierarchy.html)
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.descendants_depth_first::(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.

- [shipyard-hierarchy](https://github.com/dakom/shipyard-hierarchy)