pub struct Changed<T>(/* private fields */);Expand description
A filter on a component that only retains results the first time after they have been added or mutably dereferenced.
A common use for this filter is avoiding redundant work when values have not changed.
Note that simply mutably dereferencing a component is considered a change (DerefMut).
Bevy does not compare components to their previous values.
To retain all results without filtering but still check whether they were changed after the
system last ran, use Ref<T>.
Note that this includes changes that happened before the first time this Query was run.
§Deferred
Note, that entity modifications issued with Commands
(like entity creation or entity component addition or removal)
are visible only after deferred operations are applied,
typically at the end of the schedule iteration.
§Time complexity
Changed is not ArchetypeFilter, which practically means that
if query (with T component filter) matches million entities,
Changed<T> filter will iterate over all of them even if none of them were changed.
For example, these two systems are roughly equivalent in terms of performance:
fn system1(q: Query<&MyComponent, Changed<Transform>>) {
    for item in &q { /* component changed */ }
}
fn system2(q: Query<(&MyComponent, Ref<Transform>)>) {
    for item in &q {
        if item.1.is_changed() { /* component changed */ }
    }
}§Examples
fn print_moving_objects_system(query: Query<&Name, Changed<Transform>>) {
    for name in &query {
        println!("Entity Moved: {:?}", name);
    }
}
Trait Implementations§
Source§impl<T> QueryFilter for Changed<T>where
    T: Component,
 
impl<T> QueryFilter for Changed<T>where
    T: Component,
Source§const IS_ARCHETYPAL: bool = false
 
const IS_ARCHETYPAL: bool = false
Source§impl<T> WorldQuery for Changed<T>where
    T: Component,
SAFETY:
fetch accesses a single component in a readonly way.
This is sound because update_component_access add read access for that component and panics when appropriate.
update_component_access adds a With filter for a component.
This is sound because matches_component_set returns whether the set contains that component.
 
impl<T> WorldQuery for Changed<T>where
    T: Component,
SAFETY:
fetch accesses a single component in a readonly way.
This is sound because update_component_access add read access for that component and panics when appropriate.
update_component_access adds a With filter for a component.
This is sound because matches_component_set returns whether the set contains that component.
Source§const IS_DENSE: bool
 
const IS_DENSE: bool
Source§type Fetch<'w> = ChangedFetch<'w, T>
 
type Fetch<'w> = ChangedFetch<'w, T>
WorldQuery to compute Self::Item for each entity.Source§type State = ComponentId
 
type State = ComponentId
Self::Fetch. This will be cached inside QueryState,
so it is best to move as much data / computation here as possible to reduce the cost of
constructing Self::Fetch.Source§fn shrink_fetch<'wlong, 'wshort>(
    fetch: <Changed<T> as WorldQuery>::Fetch<'wlong>,
) -> <Changed<T> as WorldQuery>::Fetch<'wshort>where
    'wlong: 'wshort,
 
fn shrink_fetch<'wlong, 'wshort>(
    fetch: <Changed<T> as WorldQuery>::Fetch<'wlong>,
) -> <Changed<T> as WorldQuery>::Fetch<'wshort>where
    'wlong: 'wshort,
Source§unsafe fn init_fetch<'w>(
    world: UnsafeWorldCell<'w>,
    _: &ComponentId,
    last_run: Tick,
    this_run: Tick,
) -> <Changed<T> as WorldQuery>::Fetch<'w>
 
unsafe fn init_fetch<'w>( world: UnsafeWorldCell<'w>, _: &ComponentId, last_run: Tick, this_run: Tick, ) -> <Changed<T> as WorldQuery>::Fetch<'w>
Self::Fetch,
by combining data from the World with the cached Self::State.
Readonly accesses resources registered in WorldQuery::update_component_access. Read moreSource§unsafe fn set_archetype<'w>(
    fetch: &mut <Changed<T> as WorldQuery>::Fetch<'w>,
    component_id: &ComponentId,
    _archetype: &'w Archetype,
    table: &'w Table,
)
 
unsafe fn set_archetype<'w>( fetch: &mut <Changed<T> as WorldQuery>::Fetch<'w>, component_id: &ComponentId, _archetype: &'w Archetype, table: &'w Table, )
Archetype. This will always be called on
archetypes that match this WorldQuery. Read moreSource§unsafe fn set_table<'w>(
    fetch: &mut <Changed<T> as WorldQuery>::Fetch<'w>,
    _: &ComponentId,
    table: &'w Table,
)
 
unsafe fn set_table<'w>( fetch: &mut <Changed<T> as WorldQuery>::Fetch<'w>, _: &ComponentId, table: &'w Table, )
Table. This will always be called on tables
that match this WorldQuery. Read moreSource§fn update_component_access(
    _: &ComponentId,
    access: &mut FilteredAccess<ComponentId>,
)
 
fn update_component_access( _: &ComponentId, access: &mut FilteredAccess<ComponentId>, )
Source§fn init_state(world: &mut World) -> ComponentId
 
fn init_state(world: &mut World) -> ComponentId
State for this WorldQuery type.Source§fn get_state(components: &Components) -> Option<ComponentId>
 
fn get_state(components: &Components) -> Option<ComponentId>
Source§fn matches_component_set(
    _: &ComponentId,
    set_contains_id: &impl Fn(ComponentId) -> bool,
) -> bool
 
fn matches_component_set( _: &ComponentId, set_contains_id: &impl Fn(ComponentId) -> bool, ) -> bool
Source§fn set_access(_state: &mut Self::State, _access: &FilteredAccess<ComponentId>)
 
fn set_access(_state: &mut Self::State, _access: &FilteredAccess<ComponentId>)
FilteredEntityRef
or FilteredEntityMut. Read moreAuto Trait Implementations§
impl<T> Freeze for Changed<T>
impl<T> RefUnwindSafe for Changed<T>where
    T: RefUnwindSafe,
impl<T> Send for Changed<T>where
    T: Send,
impl<T> Sync for Changed<T>where
    T: Sync,
impl<T> Unpin for Changed<T>where
    T: Unpin,
impl<T> UnwindSafe for Changed<T>where
    T: UnwindSafe,
Blanket Implementations§
Source§impl<T, U> AsBindGroupShaderType<U> for T
 
impl<T, U> AsBindGroupShaderType<U> for T
Source§fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
 
fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U
T ShaderType for self. When used in AsBindGroup
derives, it is safe to assume that all images in self exist.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<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>, which can then be
downcast into Box<dyn 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>, which 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> DowncastSend for T
 
impl<T> DowncastSend for T
Source§impl<S> FromSample<S> for S
 
impl<S> FromSample<S> for S
fn from_sample_(s: S) -> S
Source§impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
 
impl<T, W> HasTypeWitness<W> for Twhere
    W: MakeTypeWitness<Arg = T>,
    T: ?Sized,
Source§impl<T> Identity for Twhere
    T: ?Sized,
 
impl<T> Identity for Twhere
    T: ?Sized,
Source§impl<T> Instrument for T
 
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
 
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
 
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
 
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
 
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
 
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more