Struct bevy_transform::components::GlobalTransform  
source · pub struct GlobalTransform(/* private fields */);Expand description
Describe the position of an entity relative to the reference frame.
- To place or move an entity, you should set its Transform.
- GlobalTransformis fully managed by bevy, you cannot mutate it, use- Transforminstead.
- To get the global transform of an entity, you should get its GlobalTransform.
- For transform hierarchies to work correctly, you must have both a Transformand aGlobalTransform.- You may use the TransformBundleto guarantee this.
 
- You may use the 
§Transform and GlobalTransform
Transform is the position of an entity relative to its parent position, or the reference
frame if it doesn’t have a Parent.
GlobalTransform is the position of an entity relative to the reference frame.
GlobalTransform is updated from Transform by systems in the system set
TransformPropagate.
This system runs during PostUpdate. If you
update the Transform of an entity in this schedule or after, you will notice a 1 frame lag
before the GlobalTransform is updated.
§Examples
Implementations§
source§impl GlobalTransform
 
impl GlobalTransform
sourcepub const IDENTITY: Self = _
 
pub const IDENTITY: Self = _
An identity GlobalTransform that maps all points in space to themselves.
sourcepub fn compute_matrix(&self) -> Mat4
 
pub fn compute_matrix(&self) -> Mat4
Returns the 3d affine transformation matrix as a Mat4.
sourcepub fn compute_transform(&self) -> Transform
 
pub fn compute_transform(&self) -> Transform
Returns the transformation as a Transform.
The transform is expected to be non-degenerate and without shearing, or the output will be invalid.
sourcepub fn reparented_to(&self, parent: &GlobalTransform) -> Transform
 
pub fn reparented_to(&self, parent: &GlobalTransform) -> Transform
Returns the Transform self would have if it was a child of an entity
with the parent GlobalTransform.
This is useful if you want to “reparent” an Entity.
Say you have an entity e1 that you want to turn into a child of e2,
but you want e1 to keep the same global transform, even after re-parenting. You would use:
#[derive(Component)]
struct ToReparent {
    new_parent: Entity,
}
fn reparent_system(
    mut commands: Commands,
    mut targets: Query<(&mut Transform, Entity, &GlobalTransform, &ToReparent)>,
    transforms: Query<&GlobalTransform>,
) {
    for (mut transform, entity, initial, to_reparent) in targets.iter_mut() {
        if let Ok(parent_transform) = transforms.get(to_reparent.new_parent) {
            *transform = initial.reparented_to(parent_transform);
            commands.entity(entity)
                .remove::<ToReparent>()
                .set_parent(to_reparent.new_parent);
        }
    }
}The transform is expected to be non-degenerate and without shearing, or the output will be invalid.
sourcepub fn to_scale_rotation_translation(&self) -> (Vec3, Quat, Vec3)
 
pub fn to_scale_rotation_translation(&self) -> (Vec3, Quat, Vec3)
Extracts scale, rotation and translation from self.
The transform is expected to be non-degenerate and without shearing, or the output will be invalid.
sourcepub fn translation(&self) -> Vec3
 
pub fn translation(&self) -> Vec3
Get the translation as a Vec3.
sourcepub fn translation_vec3a(&self) -> Vec3A
 
pub fn translation_vec3a(&self) -> Vec3A
Get the translation as a Vec3A.
sourcepub fn radius_vec3a(&self, extents: Vec3A) -> f32
 
pub fn radius_vec3a(&self, extents: Vec3A) -> f32
Get an upper bound of the radius from the given extents.
sourcepub fn transform_point(&self, point: Vec3) -> Vec3
 
pub fn transform_point(&self, point: Vec3) -> Vec3
Transforms the given point, applying shear, scale, rotation and translation.
This moves point into the local space of this GlobalTransform.
sourcepub fn mul_transform(&self, transform: Transform) -> Self
 
pub fn mul_transform(&self, transform: Transform) -> Self
Multiplies self with transform component by component, returning the
resulting GlobalTransform
Trait Implementations§
source§impl Clone for GlobalTransform
 
impl Clone for GlobalTransform
source§fn clone(&self) -> GlobalTransform
 
fn clone(&self) -> GlobalTransform
1.0.0 · source§fn clone_from(&mut self, source: &Self)
 
fn clone_from(&mut self, source: &Self)
source. Read moresource§impl Component for GlobalTransform
 
impl Component for GlobalTransform
source§const STORAGE_TYPE: StorageType = bevy_ecs::component::StorageType::Table
 
const STORAGE_TYPE: StorageType = bevy_ecs::component::StorageType::Table
source§fn register_component_hooks(_hooks: &mut ComponentHooks)
 
fn register_component_hooks(_hooks: &mut ComponentHooks)
ComponentHooks.source§impl Debug for GlobalTransform
 
impl Debug for GlobalTransform
source§impl Default for GlobalTransform
 
impl Default for GlobalTransform
source§impl From<Affine3A> for GlobalTransform
 
impl From<Affine3A> for GlobalTransform
source§impl From<GlobalTransform> for Transform
 
impl From<GlobalTransform> for Transform
The transform is expected to be non-degenerate and without shearing, or the output will be invalid.
source§fn from(transform: GlobalTransform) -> Self
 
fn from(transform: GlobalTransform) -> Self
source§impl From<Mat4> for GlobalTransform
 
impl From<Mat4> for GlobalTransform
source§impl From<Transform> for GlobalTransform
 
impl From<Transform> for GlobalTransform
source§impl FromReflect for GlobalTransform
 
impl FromReflect for GlobalTransform
source§fn from_reflect(reflect: &dyn Reflect) -> Option<Self>
 
fn from_reflect(reflect: &dyn Reflect) -> Option<Self>
Self from a reflected value.source§fn take_from_reflect(
    reflect: Box<dyn Reflect>
) -> Result<Self, Box<dyn Reflect>>
 
fn take_from_reflect( reflect: Box<dyn Reflect> ) -> Result<Self, Box<dyn Reflect>>
Self using,
constructing the value using from_reflect if that fails. Read moresource§impl GetTypeRegistration for GlobalTransform
 
impl GetTypeRegistration for GlobalTransform
source§fn get_type_registration() -> TypeRegistration
 
fn get_type_registration() -> TypeRegistration
TypeRegistration for this type.source§fn register_type_dependencies(registry: &mut TypeRegistry)
 
fn register_type_dependencies(registry: &mut TypeRegistry)
source§impl Mul<GlobalTransform> for Transform
 
impl Mul<GlobalTransform> for Transform
§type Output = GlobalTransform
 
type Output = GlobalTransform
* operator.source§impl Mul<Transform> for GlobalTransform
 
impl Mul<Transform> for GlobalTransform
source§impl Mul<Vec3> for GlobalTransform
 
impl Mul<Vec3> for GlobalTransform
source§impl Mul for GlobalTransform
 
impl Mul for GlobalTransform
§type Output = GlobalTransform
 
type Output = GlobalTransform
* operator.source§impl PartialEq for GlobalTransform
 
impl PartialEq for GlobalTransform
source§fn eq(&self, other: &GlobalTransform) -> bool
 
fn eq(&self, other: &GlobalTransform) -> bool
self and other values to be equal, and is used
by ==.source§impl Reflect for GlobalTransform
 
impl Reflect for GlobalTransform
source§fn get_represented_type_info(&self) -> Option<&'static TypeInfo>
 
fn get_represented_type_info(&self) -> Option<&'static TypeInfo>
source§fn as_any_mut(&mut self) -> &mut dyn Any
 
fn as_any_mut(&mut self) -> &mut dyn Any
&mut dyn Any.source§fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>
 
fn into_reflect(self: Box<Self>) -> Box<dyn Reflect>
source§fn as_reflect(&self) -> &dyn Reflect
 
fn as_reflect(&self) -> &dyn Reflect
source§fn as_reflect_mut(&mut self) -> &mut dyn Reflect
 
fn as_reflect_mut(&mut self) -> &mut dyn Reflect
source§fn clone_value(&self) -> Box<dyn Reflect>
 
fn clone_value(&self) -> Box<dyn Reflect>
Reflect trait object. Read moresource§fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>
 
fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>
source§fn reflect_kind(&self) -> ReflectKind
 
fn reflect_kind(&self) -> ReflectKind
source§fn reflect_ref(&self) -> ReflectRef<'_>
 
fn reflect_ref(&self) -> ReflectRef<'_>
source§fn reflect_mut(&mut self) -> ReflectMut<'_>
 
fn reflect_mut(&mut self) -> ReflectMut<'_>
source§fn reflect_owned(self: Box<Self>) -> ReflectOwned
 
fn reflect_owned(self: Box<Self>) -> ReflectOwned
source§fn reflect_partial_eq(&self, value: &dyn Reflect) -> Option<bool>
 
fn reflect_partial_eq(&self, value: &dyn Reflect) -> Option<bool>
source§fn apply(&mut self, value: &(dyn Reflect + 'static))
 
fn apply(&mut self, value: &(dyn Reflect + 'static))
source§fn reflect_hash(&self) -> Option<u64>
 
fn reflect_hash(&self) -> Option<u64>
source§fn debug(&self, f: &mut Formatter<'_>) -> Result<(), Error>
 
fn debug(&self, f: &mut Formatter<'_>) -> Result<(), Error>
source§fn serializable(&self) -> Option<Serializable<'_>>
 
fn serializable(&self) -> Option<Serializable<'_>>
source§fn is_dynamic(&self) -> bool
 
fn is_dynamic(&self) -> bool
source§impl TransformPoint for GlobalTransform
 
impl TransformPoint for GlobalTransform
source§impl TupleStruct for GlobalTransform
 
impl TupleStruct for GlobalTransform
source§fn field(&self, index: usize) -> Option<&dyn Reflect>
 
fn field(&self, index: usize) -> Option<&dyn Reflect>
index as a
&dyn Reflect.source§fn field_mut(&mut self, index: usize) -> Option<&mut dyn Reflect>
 
fn field_mut(&mut self, index: usize) -> Option<&mut dyn Reflect>
index
as a &mut dyn Reflect.source§fn iter_fields(&self) -> TupleStructFieldIter<'_>
 
fn iter_fields(&self) -> TupleStructFieldIter<'_>
source§fn clone_dynamic(&self) -> DynamicTupleStruct
 
fn clone_dynamic(&self) -> DynamicTupleStruct
DynamicTupleStruct.source§impl TypePath for GlobalTransform
 
impl TypePath for GlobalTransform
source§fn type_path() -> &'static str
 
fn type_path() -> &'static str
source§fn short_type_path() -> &'static str
 
fn short_type_path() -> &'static str
source§fn type_ident() -> Option<&'static str>
 
fn type_ident() -> Option<&'static str>
source§fn crate_name() -> Option<&'static str>
 
fn crate_name() -> Option<&'static str>
source§impl Typed for GlobalTransform
 
impl Typed for GlobalTransform
impl Copy for GlobalTransform
impl StructuralPartialEq for GlobalTransform
Auto Trait Implementations§
impl Freeze for GlobalTransform
impl RefUnwindSafe for GlobalTransform
impl Send for GlobalTransform
impl Sync for GlobalTransform
impl Unpin for GlobalTransform
impl UnwindSafe for GlobalTransform
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
 
impl<T> BorrowMut<T> for Twhere
    T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
 
fn borrow_mut(&mut self) -> &mut T
source§impl<C> Bundle for Cwhere
    C: Component,
 
impl<C> Bundle for Cwhere
    C: Component,
fn component_ids( components: &mut Components, storages: &mut Storages, ids: &mut impl FnMut(ComponentId) )
unsafe fn from_components<T, F>(ctx: &mut T, func: &mut F) -> C
source§fn get_component_ids(
    components: &Components,
    ids: &mut impl FnMut(Option<ComponentId>)
)
 
fn get_component_ids( components: &Components, ids: &mut impl FnMut(Option<ComponentId>) )
source§impl<T> Downcast for Twhere
    T: Any,
 
impl<T> Downcast for Twhere
    T: Any,
source§fn into_any(self: Box<T>) -> Box<dyn Any>
 
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
 
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.source§fn as_any(&self) -> &(dyn Any + 'static)
 
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
 
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.source§impl<T> DowncastSync for T
 
impl<T> DowncastSync for T
source§impl<C> DynamicBundle for Cwhere
    C: Component,
 
impl<C> DynamicBundle for Cwhere
    C: Component,
fn get_components(self, func: &mut impl FnMut(StorageType, OwningPtr<'_>))
source§impl<T> DynamicTypePath for Twhere
    T: TypePath,
 
impl<T> DynamicTypePath for Twhere
    T: TypePath,
source§fn reflect_type_path(&self) -> &str
 
fn reflect_type_path(&self) -> &str
TypePath::type_path.source§fn reflect_short_type_path(&self) -> &str
 
fn reflect_short_type_path(&self) -> &str
source§fn reflect_type_ident(&self) -> Option<&str>
 
fn reflect_type_ident(&self) -> Option<&str>
TypePath::type_ident.source§fn reflect_crate_name(&self) -> Option<&str>
 
fn reflect_crate_name(&self) -> Option<&str>
TypePath::crate_name.source§fn reflect_module_path(&self) -> Option<&str>
 
fn reflect_module_path(&self) -> Option<&str>
source§impl<T> FromWorld for Twhere
    T: Default,
 
impl<T> FromWorld for Twhere
    T: Default,
source§fn from_world(_world: &mut World) -> T
 
fn from_world(_world: &mut World) -> T
Self using data from the given World.source§impl<T> GetPath for T
 
impl<T> GetPath for T
source§fn reflect_path<'p>(
    &self,
    path: impl ReflectPath<'p>
) -> Result<&(dyn Reflect + 'static), ReflectPathError<'p>>
 
fn reflect_path<'p>( &self, path: impl ReflectPath<'p> ) -> Result<&(dyn Reflect + 'static), ReflectPathError<'p>>
path. Read moresource§fn reflect_path_mut<'p>(
    &mut self,
    path: impl ReflectPath<'p>
) -> Result<&mut (dyn Reflect + 'static), ReflectPathError<'p>>
 
fn reflect_path_mut<'p>( &mut self, path: impl ReflectPath<'p> ) -> Result<&mut (dyn Reflect + 'static), ReflectPathError<'p>>
path. Read moresource§fn path<'p, T>(
    &self,
    path: impl ReflectPath<'p>
) -> Result<&T, ReflectPathError<'p>>where
    T: Reflect,
 
fn path<'p, T>(
    &self,
    path: impl ReflectPath<'p>
) -> Result<&T, ReflectPathError<'p>>where
    T: Reflect,
path. Read moresource§fn path_mut<'p, T>(
    &mut self,
    path: impl ReflectPath<'p>
) -> Result<&mut T, ReflectPathError<'p>>where
    T: Reflect,
 
fn path_mut<'p, T>(
    &mut self,
    path: impl ReflectPath<'p>
) -> Result<&mut T, ReflectPathError<'p>>where
    T: Reflect,
path. Read more