pub struct Trigger<'w, E, B = ()>where
    B: Bundle,{ /* private fields */ }Expand description
Type containing triggered Event information for a given run of an Observer. This contains the
Event data itself. If it was triggered for a specific Entity, it includes that as well. It also
contains event propagation information. See Trigger::propagate for more information.
Implementations§
Source§impl<'w, E, B> Trigger<'w, E, B>where
    B: Bundle,
 
impl<'w, E, B> Trigger<'w, E, B>where
    B: Bundle,
Sourcepub fn new(
    event: &'w mut E,
    propagate: &'w mut bool,
    trigger: ObserverTrigger,
) -> Trigger<'w, E, B>
 
pub fn new( event: &'w mut E, propagate: &'w mut bool, trigger: ObserverTrigger, ) -> Trigger<'w, E, B>
Creates a new trigger for the given event and observer information.
Sourcepub fn event_type(&self) -> ComponentId
 
pub fn event_type(&self) -> ComponentId
Returns the event type of this trigger.
Sourcepub fn target(&self) -> Entity
 
pub fn target(&self) -> Entity
Returns the Entity that was targeted by the event that triggered this observer. It may
be Entity::PLACEHOLDER.
Observable events can target specific entities. When those events fire, they will trigger
any observers on the targeted entities. In this case, the target() and observer() are
the same, because the observer that was triggered is attached to the entity that was
targeted by the event.
However, it is also possible for those events to bubble up the entity hierarchy and trigger observers on different entities, or trigger a global observer. In these cases, the observing entity is different from the entity being targeted by the event.
This is an important distinction: the entity reacting to an event is not always the same as the entity triggered by the event.
Sourcepub fn components(&self) -> &[ComponentId]
 
pub fn components(&self) -> &[ComponentId]
Returns the components that triggered the observer, out of the
components defined in B. Does not necessarily include all of them as
B acts like an OR filter rather than an AND filter.
Sourcepub fn observer(&self) -> Entity
 
pub fn observer(&self) -> Entity
Returns the Entity that observed the triggered event.
This allows you to despawn the observer, ceasing observation.
§Examples
/// Handle `MyEvent` and if it is done, stop observation.
fn my_observer(trigger: Trigger<MyEvent>, mut commands: Commands) {
    if trigger.event().done {
        commands.entity(trigger.observer()).despawn();
        return;
    }
    // ...
}Sourcepub fn propagate(&mut self, should_propagate: bool)
 
pub fn propagate(&mut self, should_propagate: bool)
Enables or disables event propagation, allowing the same event to trigger observers on a chain of different entities.
The path an event will propagate along is specified by its associated Traversal component. By default, events
use () which ends the path immediately and prevents propagation.
To enable propagation, you must:
- Set Event::Traversalto the component you want to propagate along.
- Either call propagate(true)in the first observer or setEvent::AUTO_PROPAGATEtotrue.
You can prevent an event from propagating further using propagate(false).
Sourcepub fn get_propagate(&self) -> bool
 
pub fn get_propagate(&self) -> bool
Returns the value of the flag that controls event propagation. See propagate for more information.
Sourcepub fn caller(&self) -> MaybeLocation
 
pub fn caller(&self) -> MaybeLocation
Returns the source code location that triggered this observer.
Trait Implementations§
Source§impl<E, B> SystemInput for Trigger<'_, E, B>where
    E: 'static,
    B: Bundle,
Used for ObserverSystems.
 
impl<E, B> SystemInput for Trigger<'_, E, B>where
    E: 'static,
    B: Bundle,
Used for ObserverSystems.
Source§type Param<'i> = Trigger<'i, E, B>
 
type Param<'i> = Trigger<'i, E, B>
FunctionSystems.Source§type Inner<'i> = Trigger<'i, E, B>
 
type Inner<'i> = Trigger<'i, E, B>
System::run.Source§fn wrap(
    this: <Trigger<'_, E, B> as SystemInput>::Inner<'_>,
) -> <Trigger<'_, E, B> as SystemInput>::Param<'_>
 
fn wrap( this: <Trigger<'_, E, B> as SystemInput>::Inner<'_>, ) -> <Trigger<'_, E, B> as SystemInput>::Param<'_>
SystemInput::Inner into a SystemInput::Param.Auto Trait Implementations§
impl<'w, E, B> Freeze for Trigger<'w, E, B>
impl<'w, E, B> RefUnwindSafe for Trigger<'w, E, B>where
    E: RefUnwindSafe,
    B: RefUnwindSafe,
impl<'w, E, B> Send for Trigger<'w, E, B>where
    E: Send,
impl<'w, E, B> Sync for Trigger<'w, E, B>where
    E: Sync,
impl<'w, E, B> Unpin for Trigger<'w, E, B>where
    B: Unpin,
impl<'w, E, B = ()> !UnwindSafe for Trigger<'w, E, B>
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, C, D> Curve<T> for D
 
impl<T, C, D> Curve<T> for D
Source§fn sample_unchecked(&self, t: f32) -> T
 
fn sample_unchecked(&self, t: f32) -> T
t, extracting the associated value.
This is the unchecked version of sampling, which should only be used if the sample time t
is already known to lie within the curve’s domain. Read moreSource§fn sample(&self, t: f32) -> Option<T>
 
fn sample(&self, t: f32) -> Option<T>
t, returning None if the point is
outside of the curve’s domain.Source§fn sample_clamped(&self, t: f32) -> T
 
fn sample_clamped(&self, t: f32) -> T
t, clamping t to lie inside the
domain of the curve.Source§impl<C, T> CurveExt<T> for Cwhere
    C: Curve<T>,
 
impl<C, T> CurveExt<T> for Cwhere
    C: Curve<T>,
Source§fn sample_iter(
    &self,
    iter: impl IntoIterator<Item = f32>,
) -> impl Iterator<Item = Option<T>>
 
fn sample_iter( &self, iter: impl IntoIterator<Item = f32>, ) -> impl Iterator<Item = Option<T>>
n >= 0 points on this curve at the parameter values t_n,
returning None if the point is outside of the curve’s domain. Read moreSource§fn sample_iter_unchecked(
    &self,
    iter: impl IntoIterator<Item = f32>,
) -> impl Iterator<Item = T>
 
fn sample_iter_unchecked( &self, iter: impl IntoIterator<Item = f32>, ) -> impl Iterator<Item = T>
n >= 0 points on this curve at the parameter values t_n,
extracting the associated values. This is the unchecked version of sampling, which should
only be used if the sample times t_n are already known to lie within the curve’s domain. Read moreSource§fn sample_iter_clamped(
    &self,
    iter: impl IntoIterator<Item = f32>,
) -> impl Iterator<Item = T>
 
fn sample_iter_clamped( &self, iter: impl IntoIterator<Item = f32>, ) -> impl Iterator<Item = T>
n >= 0 points on this curve at the parameter values t_n,
clamping t_n to lie inside the domain of the curve. Read moreSource§fn map<S, F>(self, f: F) -> MapCurve<T, S, Self, F>where
    F: Fn(T) -> S,
 
fn map<S, F>(self, f: F) -> MapCurve<T, S, Self, F>where
    F: Fn(T) -> S,
f; i.e., if the
sample at time t for this curve is x, the value at time t on the new curve will be
f(x).Source§fn reparametrize<F>(self, domain: Interval, f: F) -> ReparamCurve<T, Self, F>
 
fn reparametrize<F>(self, domain: Interval, f: F) -> ReparamCurve<T, Self, F>
Curve whose parameter space is related to the parameter space of this curve
by f. For each time t, the sample from the new curve at time t is the sample from
this curve at time f(t). The given domain will be the domain of the new curve. The
function f is expected to take domain into self.domain(). Read moreSource§fn reparametrize_linear(
    self,
    domain: Interval,
) -> Result<LinearReparamCurve<T, Self>, LinearReparamError>
 
fn reparametrize_linear( self, domain: Interval, ) -> Result<LinearReparamCurve<T, Self>, LinearReparamError>
Source§fn reparametrize_by_curve<C>(self, other: C) -> CurveReparamCurve<T, Self, C>
 
fn reparametrize_by_curve<C>(self, other: C) -> CurveReparamCurve<T, Self, C>
Source§fn graph(self) -> GraphCurve<T, Self>
 
fn graph(self) -> GraphCurve<T, Self>
Source§fn zip<S, C>(
    self,
    other: C,
) -> Result<ZipCurve<T, S, Self, C>, InvalidIntervalError>where
    C: Curve<S>,
 
fn zip<S, C>(
    self,
    other: C,
) -> Result<ZipCurve<T, S, Self, C>, InvalidIntervalError>where
    C: Curve<S>,
Source§fn chain<C>(self, other: C) -> Result<ChainCurve<T, Self, C>, ChainError>where
    C: Curve<T>,
 
fn chain<C>(self, other: C) -> Result<ChainCurve<T, Self, C>, ChainError>where
    C: Curve<T>,
Source§fn reverse(self) -> Result<ReverseCurve<T, Self>, ReverseError>
 
fn reverse(self) -> Result<ReverseCurve<T, Self>, ReverseError>
Source§fn repeat(self, count: usize) -> Result<RepeatCurve<T, Self>, RepeatError>
 
fn repeat(self, count: usize) -> Result<RepeatCurve<T, Self>, RepeatError>
Source§fn forever(self) -> Result<ForeverCurve<T, Self>, RepeatError>
 
fn forever(self) -> Result<ForeverCurve<T, Self>, RepeatError>
Source§fn ping_pong(self) -> Result<PingPongCurve<T, Self>, PingPongError>
 
fn ping_pong(self) -> Result<PingPongCurve<T, Self>, PingPongError>
Source§fn chain_continue<C>(
    self,
    other: C,
) -> Result<ContinuationCurve<T, Self, C>, ChainError>where
    T: VectorSpace,
    C: Curve<T>,
 
fn chain_continue<C>(
    self,
    other: C,
) -> Result<ContinuationCurve<T, Self, C>, ChainError>where
    T: VectorSpace,
    C: Curve<T>,
Source§fn samples(
    &self,
    samples: usize,
) -> Result<impl Iterator<Item = T>, ResamplingError>
 
fn samples( &self, samples: usize, ) -> Result<impl Iterator<Item = T>, ResamplingError>
Source§impl<C, T> CurveResampleExt<T> for C
 
impl<C, T> CurveResampleExt<T> for C
Source§fn resample<I>(
    &self,
    segments: usize,
    interpolation: I,
) -> Result<SampleCurve<T, I>, ResamplingError>
 
fn resample<I>( &self, segments: usize, interpolation: I, ) -> Result<SampleCurve<T, I>, ResamplingError>
Curve to produce a new one that is defined by interpolation over equally
spaced sample values, using the provided interpolation to interpolate between adjacent samples.
The curve is interpolated on segments segments between samples. For example, if segments is 1,
only the start and end points of the curve are used as samples; if segments is 2, a sample at
the midpoint is taken as well, and so on. Read moreSource§fn resample_auto(
    &self,
    segments: usize,
) -> Result<SampleAutoCurve<T>, ResamplingError>where
    T: StableInterpolate,
 
fn resample_auto(
    &self,
    segments: usize,
) -> Result<SampleAutoCurve<T>, ResamplingError>where
    T: StableInterpolate,
Curve to produce a new one that is defined by interpolation over equally
spaced sample values, using automatic interpolation to interpolate between adjacent samples.
The curve is interpolated on segments segments between samples. For example, if segments is 1,
only the start and end points of the curve are used as samples; if segments is 2, a sample at
the midpoint is taken as well, and so on. Read moreSource§fn resample_uneven<I>(
    &self,
    sample_times: impl IntoIterator<Item = f32>,
    interpolation: I,
) -> Result<UnevenSampleCurve<T, I>, ResamplingError>
 
fn resample_uneven<I>( &self, sample_times: impl IntoIterator<Item = f32>, interpolation: I, ) -> Result<UnevenSampleCurve<T, I>, ResamplingError>
Source§fn resample_uneven_auto(
    &self,
    sample_times: impl IntoIterator<Item = f32>,
) -> Result<UnevenSampleAutoCurve<T>, ResamplingError>where
    T: StableInterpolate,
 
fn resample_uneven_auto(
    &self,
    sample_times: impl IntoIterator<Item = f32>,
) -> Result<UnevenSampleAutoCurve<T>, ResamplingError>where
    T: StableInterpolate,
Curve to produce a new one that is defined by automatic interpolation over
samples taken at the given set of times. The given sample_times are expected to contain at least
two valid times within the curve’s domain interval. Read moreSource§impl<T, C> CurveWithDerivative<T> for Cwhere
    T: HasTangent,
    C: SampleDerivative<T>,
 
impl<T, C> CurveWithDerivative<T> for Cwhere
    T: HasTangent,
    C: SampleDerivative<T>,
Source§fn with_derivative(self) -> SampleDerivativeWrapper<C>
 
fn with_derivative(self) -> SampleDerivativeWrapper<C>
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 moreSource§impl<T, C, D> SampleDerivative<T> for D
 
impl<T, C, D> SampleDerivative<T> for D
Source§fn sample_with_derivative_unchecked(&self, t: f32) -> WithDerivative<T>
 
fn sample_with_derivative_unchecked(&self, t: f32) -> WithDerivative<T>
t, extracting the associated value
in addition to its derivative. This is the unchecked version of sampling, which
should only be used if the sample time t is already known to lie within the
curve’s domain. Read moreSource§fn sample_with_derivative(&self, t: f32) -> Option<WithDerivative<T>>
 
fn sample_with_derivative(&self, t: f32) -> Option<WithDerivative<T>>
t, returning
None if the point is outside of the curve’s domain.Source§fn sample_with_derivative_clamped(&self, t: f32) -> WithDerivative<T>
 
fn sample_with_derivative_clamped(&self, t: f32) -> WithDerivative<T>
t, clamping t
to lie inside the domain of the curve.