pub struct Physics {Show 17 fields
    pub velocity: Vec3,
    pub vec_delta_codec: VecDeltaCodec,
    pub old_position: Vec3,
    pub x_acceleration: f32,
    pub y_acceleration: f32,
    pub z_acceleration: f32,
    pub no_jump_delay: u32,
    pub bounding_box: Aabb,
    pub has_impulse: bool,
    pub horizontal_collision: bool,
    pub minor_horizontal_collision: bool,
    pub vertical_collision: bool,
    pub water_fluid_height: f64,
    pub lava_fluid_height: f64,
    pub was_touching_water: bool,
    pub fall_distance: f64,
    pub remaining_fire_ticks: i32,
    /* private fields */
}Expand description
The physics data relating to the entity, such as position, velocity, and bounding box.
Fields§
§velocity: Vec3How fast the entity is moving. Sometimes referred to as the delta movement.
Note that our Y velocity will be approximately -0.0784 when we’re on the ground due to how Minecraft applies gravity.
vec_delta_codec: VecDeltaCodec§old_position: Vec3The position of the entity before it moved this tick.
This is set immediately before physics is done.
x_acceleration: f32The acceleration here is the force that will be attempted to be added to the entity’s velocity next tick.
You should typically not set this yourself, since it’s controlled by how the entity is trying to move.
y_acceleration: f32§z_acceleration: f32§no_jump_delay: u32The number of ticks until we jump again, if the jump key is being held.
This must be 0 for us to be able to jump. Sets to 10 when we do a jump and sets to 0 if we’re not trying to jump.
bounding_box: AabbThe bounding box of the entity.
This is more than just width and height, unlike dimensions.
has_impulse: bool§horizontal_collision: bool§minor_horizontal_collision: bool§vertical_collision: bool§water_fluid_height: f64§lava_fluid_height: f64§was_touching_water: bool§fall_distance: f64§remaining_fire_ticks: i32Implementations§
Source§impl Physics
 
impl Physics
pub fn new(dimensions: &EntityDimensions, pos: Vec3) -> Self
pub fn on_ground(&self) -> bool
Sourcepub fn set_on_ground(&mut self, on_ground: bool)
 
pub fn set_on_ground(&mut self, on_ground: bool)
Updates Self::on_ground and Self::last_on_ground.
Sourcepub fn last_on_ground(&self) -> bool
 
pub fn last_on_ground(&self) -> bool
The last value of the on_ground value.
This is used by Azalea internally for physics, it might not work as you expect since it can be influenced by packets sent by the server.
pub fn set_last_on_ground(&mut self, last_on_ground: bool)
pub fn reset_fall_distance(&mut self)
pub fn clear_fire(&mut self)
pub fn is_in_water(&self) -> bool
pub fn is_in_lava(&self) -> bool
pub fn set_old_pos(&mut self, pos: Position)
Trait Implementations§
Source§impl Component for Physics
 
impl Component for Physics
Source§const STORAGE_TYPE: StorageType = bevy_ecs::component::StorageType::Table
 
const STORAGE_TYPE: StorageType = bevy_ecs::component::StorageType::Table
Source§type Mutability = Mutable
 
type Mutability = Mutable
Component<Mutability = Mutable>],
while immutable components will instead have [Component<Mutability = Immutable>]. Read moreSource§fn register_required_components(
    _requiree: ComponentId,
    required_components: &mut RequiredComponentsRegistrator<'_, '_>,
)
 
fn register_required_components( _requiree: ComponentId, required_components: &mut RequiredComponentsRegistrator<'_, '_>, )
Source§fn clone_behavior() -> ComponentCloneBehavior
 
fn clone_behavior() -> ComponentCloneBehavior
§fn on_add() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
 
fn on_add() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
on_add [ComponentHook] for this [Component] if one is defined.§fn on_insert() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
 
fn on_insert() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
on_insert [ComponentHook] for this [Component] if one is defined.§fn on_replace() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
 
fn on_replace() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
on_replace [ComponentHook] for this [Component] if one is defined.§fn on_remove() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
 
fn on_remove() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
on_remove [ComponentHook] for this [Component] if one is defined.§fn on_despawn() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
 
fn on_despawn() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>
on_despawn [ComponentHook] for this [Component] if one is defined.§fn map_entities<E>(_this: &mut Self, _mapper: &mut E)where
    E: EntityMapper,
 
fn map_entities<E>(_this: &mut Self, _mapper: &mut E)where
    E: EntityMapper,
EntityMapper]. This is used to remap entities in contexts like scenes and entity cloning.
When deriving [Component], this is populated by annotating fields containing entities with #[entities] Read moreAuto Trait Implementations§
impl Freeze for Physics
impl RefUnwindSafe for Physics
impl Send for Physics
impl Sync for Physics
impl Unpin for Physics
impl UnwindSafe for Physics
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
§impl<C> Bundle for Cwhere
    C: Component,
 
impl<C> Bundle for Cwhere
    C: Component,
fn component_ids( components: &mut ComponentsRegistrator<'_>, ids: &mut impl FnMut(ComponentId), )
§fn get_component_ids(
    components: &Components,
    ids: &mut impl FnMut(Option<ComponentId>),
)
 
fn get_component_ids( components: &Components, ids: &mut impl FnMut(Option<ComponentId>), )
Bundle]’s component ids. This will be None if the component has not been registered.§impl<C> BundleFromComponents for Cwhere
    C: Component,
 
impl<C> BundleFromComponents for Cwhere
    C: Component,
Source§impl<T> CloneToUninit for Twhere
    T: Clone,
 
impl<T> CloneToUninit for Twhere
    T: Clone,
§impl<T> Downcast for Twhere
    T: Any,
 
impl<T> Downcast for Twhere
    T: Any,
§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>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.§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>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.§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.§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.§impl<T> DowncastSend for T
 
impl<T> DowncastSend for T
§impl<C> DynamicBundle for Cwhere
    C: Component,
 
impl<C> DynamicBundle for Cwhere
    C: Component,
§unsafe fn get_components(
    ptr: MovingPtr<'_, C>,
    func: &mut impl FnMut(StorageType, OwningPtr<'_>),
) -> <C as DynamicBundle>::Effect
 
unsafe fn get_components( ptr: MovingPtr<'_, C>, func: &mut impl FnMut(StorageType, OwningPtr<'_>), ) -> <C as DynamicBundle>::Effect
§unsafe fn apply_effect(
    _ptr: MovingPtr<'_, MaybeUninit<C>>,
    _entity: &mut EntityWorldMut<'_>,
)
 
unsafe fn apply_effect( _ptr: MovingPtr<'_, MaybeUninit<C>>, _entity: &mut EntityWorldMut<'_>, )
§impl<T> FromWorld for Twhere
    T: Default,
 
impl<T> FromWorld for Twhere
    T: Default,
§fn from_world(_world: &mut World) -> T
 
fn from_world(_world: &mut World) -> T
Creates Self using default().