mirror of
https://github.com/bevyengine/bevy
synced 2024-12-26 04:53:07 +00:00
60 lines
2.2 KiB
Rust
60 lines
2.2 KiB
Rust
|
use bevy_ecs::prelude::Bundle;
|
||
|
use bevy_transform::prelude::{GlobalTransform, Transform};
|
||
|
|
||
|
use crate::view::{ComputedVisibility, Visibility};
|
||
|
|
||
|
/// A [`Bundle`] with the following [`Component`](bevy_ecs::component::Component)s:
|
||
|
/// * [`Visibility`] and [`ComputedVisibility`], which describe the visibility of an entity
|
||
|
/// * [`Transform`] and [`GlobalTransform`], which describe the position of an entity
|
||
|
///
|
||
|
/// * To show or hide an entity, you should set its [`Visibility`].
|
||
|
/// * To get the computed visibility of an entity, you should get its [`ComputedVisibility`].
|
||
|
/// * To place or move an entity, you should set its [`Transform`].
|
||
|
/// * To get the global transform of an entity, you should get its [`GlobalTransform`].
|
||
|
/// * For hierarchies to work correctly, you must have all four components.
|
||
|
/// * You may use the [`SpatialBundle`] to guarantee this.
|
||
|
#[derive(Bundle, Debug, Default)]
|
||
|
pub struct SpatialBundle {
|
||
|
/// The visibility of the entity.
|
||
|
pub visibility: Visibility,
|
||
|
/// The computed visibility of the entity.
|
||
|
pub computed: ComputedVisibility,
|
||
|
/// The transform of the entity.
|
||
|
pub transform: Transform,
|
||
|
/// The global transform of the entity.
|
||
|
pub global_transform: GlobalTransform,
|
||
|
}
|
||
|
|
||
|
impl SpatialBundle {
|
||
|
/// Creates a new [`SpatialBundle`] from a [`Transform`].
|
||
|
///
|
||
|
/// This initializes [`GlobalTransform`] as identity, and visibility as visible
|
||
|
#[inline]
|
||
|
pub const fn from_transform(transform: Transform) -> Self {
|
||
|
SpatialBundle {
|
||
|
transform,
|
||
|
// Note: `..Default::default()` cannot be used here, because it isn't const
|
||
|
..Self::visible_identity()
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/// Creates a new identity [`SpatialBundle`], with no translation, rotation, and a scale of 1
|
||
|
/// on all axes.
|
||
|
#[inline]
|
||
|
pub const fn visible_identity() -> Self {
|
||
|
SpatialBundle {
|
||
|
transform: Transform::identity(),
|
||
|
global_transform: GlobalTransform::identity(),
|
||
|
visibility: Visibility::visible(),
|
||
|
computed: ComputedVisibility::not_visible(),
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
impl From<Transform> for SpatialBundle {
|
||
|
#[inline]
|
||
|
fn from(transform: Transform) -> Self {
|
||
|
Self::from_transform(transform)
|
||
|
}
|
||
|
}
|