bevy_hierarchy

Trait BuildChildren

Source
pub trait BuildChildren {
    type Builder<'a>: ChildBuild;

    // Required methods
    fn with_children(
        &mut self,
        f: impl FnOnce(&mut Self::Builder<'_>),
    ) -> &mut Self;
    fn with_child<B: Bundle>(&mut self, bundle: B) -> &mut Self;
    fn add_children(&mut self, children: &[Entity]) -> &mut Self;
    fn insert_children(
        &mut self,
        index: usize,
        children: &[Entity],
    ) -> &mut Self;
    fn remove_children(&mut self, children: &[Entity]) -> &mut Self;
    fn add_child(&mut self, child: Entity) -> &mut Self;
    fn clear_children(&mut self) -> &mut Self;
    fn replace_children(&mut self, children: &[Entity]) -> &mut Self;
    fn set_parent(&mut self, parent: Entity) -> &mut Self;
    fn remove_parent(&mut self) -> &mut Self;
}
Expand description

Trait for removing, adding and replacing children and parents of an entity.

Required Associated Types§

Source

type Builder<'a>: ChildBuild

Child builder type.

Required Methods§

Source

fn with_children(&mut self, f: impl FnOnce(&mut Self::Builder<'_>)) -> &mut Self

Takes a closure which builds children for this entity using ChildBuild.

For convenient spawning of a single child, you can use with_child.

Source

fn with_child<B: Bundle>(&mut self, bundle: B) -> &mut Self

Spawns the passed bundle and adds it to this entity as a child.

For efficient spawning of multiple children, use with_children.

Source

fn add_children(&mut self, children: &[Entity]) -> &mut Self

Pushes children to the back of the builder’s children. For any entities that are already a child of this one, this method does nothing.

If the children were previously children of another parent, that parent’s Children component will have those children removed from its list. Removing all children from a parent causes its Children component to be removed from the entity.

§Panics

Panics if any of the children are the same as the parent.

Source

fn insert_children(&mut self, index: usize, children: &[Entity]) -> &mut Self

Inserts children at the given index.

If the children were previously children of another parent, that parent’s Children component will have those children removed from its list. Removing all children from a parent causes its Children component to be removed from the entity.

§Panics

Panics if any of the children are the same as the parent.

Source

fn remove_children(&mut self, children: &[Entity]) -> &mut Self

Removes the given children

Removing all children from a parent causes its Children component to be removed from the entity.

Source

fn add_child(&mut self, child: Entity) -> &mut Self

Adds a single child.

If the children were previously children of another parent, that parent’s Children component will have those children removed from its list. Removing all children from a parent causes its Children component to be removed from the entity.

§Panics

Panics if the child is the same as the parent.

Source

fn clear_children(&mut self) -> &mut Self

Removes all children from this entity. The Children component will be removed if it exists, otherwise this does nothing.

Source

fn replace_children(&mut self, children: &[Entity]) -> &mut Self

Removes all current children from this entity, replacing them with the specified list of entities.

The removed children will have their Parent component removed.

§Panics

Panics if any of the children are the same as the parent.

Source

fn set_parent(&mut self, parent: Entity) -> &mut Self

Sets the parent of this entity.

If this entity already had a parent, the parent’s Children component will have this child removed from its list. Removing all children from a parent causes its Children component to be removed from the entity.

§Panics

Panics if the parent is the same as the child.

Source

fn remove_parent(&mut self) -> &mut Self

Removes the Parent of this entity.

Also removes this entity from its parent’s Children component. Removing all children from a parent causes its Children component to be removed from the entity.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementations on Foreign Types§

Source§

impl BuildChildren for EntityCommands<'_>

Source§

type Builder<'a> = ChildBuilder<'a>

Source§

fn with_children( &mut self, spawn_children: impl FnOnce(&mut Self::Builder<'_>), ) -> &mut Self

Source§

fn with_child<B: Bundle>(&mut self, bundle: B) -> &mut Self

Source§

fn add_children(&mut self, children: &[Entity]) -> &mut Self

Source§

fn insert_children(&mut self, index: usize, children: &[Entity]) -> &mut Self

Source§

fn remove_children(&mut self, children: &[Entity]) -> &mut Self

Source§

fn add_child(&mut self, child: Entity) -> &mut Self

Source§

fn clear_children(&mut self) -> &mut Self

Source§

fn replace_children(&mut self, children: &[Entity]) -> &mut Self

Source§

fn set_parent(&mut self, parent: Entity) -> &mut Self

Source§

fn remove_parent(&mut self) -> &mut Self

Source§

impl BuildChildren for EntityWorldMut<'_>

Source§

type Builder<'a> = WorldChildBuilder<'a>

Source§

fn with_children( &mut self, spawn_children: impl FnOnce(&mut WorldChildBuilder<'_>), ) -> &mut Self

Source§

fn with_child<B: Bundle>(&mut self, bundle: B) -> &mut Self

Source§

fn add_child(&mut self, child: Entity) -> &mut Self

Source§

fn add_children(&mut self, children: &[Entity]) -> &mut Self

Source§

fn insert_children(&mut self, index: usize, children: &[Entity]) -> &mut Self

Source§

fn remove_children(&mut self, children: &[Entity]) -> &mut Self

Source§

fn set_parent(&mut self, parent: Entity) -> &mut Self

Source§

fn remove_parent(&mut self) -> &mut Self

Source§

fn clear_children(&mut self) -> &mut Self

Source§

fn replace_children(&mut self, children: &[Entity]) -> &mut Self

Implementors§