pub struct YoleckEdit<'w, 's, Q: 'static + QueryData, F: 'static + QueryFilter = ()> { /* private fields */ }
Expand description
Wrapper for writing queries in edit systems.
To future-proof for the multi-entity editing feature, use this instead of
regular queries with With<YoleckEditMarker>
.
The methods of YoleckEdit
that have the same name as methods of a regular Bevy Query
delegate to them, but if there are edited entities that do not fit the query they will act as
if they found no match.
Implementations§
Source§impl<Q: 'static + QueryData, F: 'static + QueryFilter> YoleckEdit<'_, '_, Q, F>
impl<Q: 'static + QueryData, F: 'static + QueryFilter> YoleckEdit<'_, '_, Q, F>
pub fn single( &self, ) -> Result<<<Q as QueryData>::ReadOnly as QueryData>::Item<'_>, QuerySingleError>
pub fn single_mut( &mut self, ) -> Result<<Q as QueryData>::Item<'_>, QuerySingleError>
pub fn is_empty(&self) -> bool
Sourcepub fn has_nonmatching(&self) -> bool
pub fn has_nonmatching(&self) -> bool
Check if some non-matching entities are selected for editing.
Use this, together with is_empty
for systems that can edit multiple
entities but want to not show their UI when some irrelevant entities are selected as well.
Sourcepub fn iter_matching(
&mut self,
) -> QueryIter<'_, '_, <Q as QueryData>::ReadOnly, (With<YoleckEditMarker>, F)>
pub fn iter_matching( &mut self, ) -> QueryIter<'_, '_, <Q as QueryData>::ReadOnly, (With<YoleckEditMarker>, F)>
Iterate over all the matching entities, even if some selected entities do not match.
If both matching and non-matching entities are selected, this will iterate over the
matching entities only. If it is not desired to iterate at all in such cases,
check has_nonmatching
must be checked manually.
Sourcepub fn iter_matching_mut(
&mut self,
) -> QueryIter<'_, '_, Q, (With<YoleckEditMarker>, F)>
pub fn iter_matching_mut( &mut self, ) -> QueryIter<'_, '_, Q, (With<YoleckEditMarker>, F)>
Iterate mutably over all the matching entities, even if some selected entities do not match.
If both matching and non-matching entities are selected, this will iterate over the
matching entities only. If it is not desired to iterate at all in such cases,
check has_nonmatching
must be checked manually.
Trait Implementations§
Source§impl<Q: 'static + QueryData, F: 'static + QueryFilter> SystemParam for YoleckEdit<'_, '_, Q, F>
impl<Q: 'static + QueryData, F: 'static + QueryFilter> SystemParam for YoleckEdit<'_, '_, Q, F>
Source§type State = FetchState<Q, F>
type State = FetchState<Q, F>
Source§type Item<'w, 's> = YoleckEdit<'w, 's, Q, F>
type Item<'w, 's> = YoleckEdit<'w, 's, Q, F>
Self
, instantiated with new lifetimes. Read moreSource§fn init_state(world: &mut World, system_meta: &mut SystemMeta) -> Self::State
fn init_state(world: &mut World, system_meta: &mut SystemMeta) -> Self::State
World
] access used by this [SystemParam
]
and creates a new instance of this param’s State
.Source§unsafe fn new_archetype(
state: &mut Self::State,
archetype: &Archetype,
system_meta: &mut SystemMeta,
)
unsafe fn new_archetype( state: &mut Self::State, archetype: &Archetype, system_meta: &mut SystemMeta, )
Archetype
], registers the components accessed by this [SystemParam
] (if applicable).a Read moreSource§fn apply(state: &mut Self::State, system_meta: &SystemMeta, world: &mut World)
fn apply(state: &mut Self::State, system_meta: &SystemMeta, world: &mut World)
SystemParam
]’s state.
This is used to apply Commands
during ApplyDeferred
.Source§fn queue(
state: &mut Self::State,
system_meta: &SystemMeta,
world: DeferredWorld<'_>,
)
fn queue( state: &mut Self::State, system_meta: &SystemMeta, world: DeferredWorld<'_>, )
ApplyDeferred
.Source§unsafe fn validate_param<'w, 's>(
state: &'s Self::State,
_system_meta: &SystemMeta,
_world: UnsafeWorldCell<'w>,
) -> Result<(), SystemParamValidationError>
unsafe fn validate_param<'w, 's>( state: &'s Self::State, _system_meta: &SystemMeta, _world: UnsafeWorldCell<'w>, ) -> Result<(), SystemParamValidationError>
Source§unsafe fn get_param<'w, 's>(
state: &'s mut Self::State,
system_meta: &SystemMeta,
world: UnsafeWorldCell<'w>,
change_tick: Tick,
) -> Self::Item<'w, 's>
unsafe fn get_param<'w, 's>( state: &'s mut Self::State, system_meta: &SystemMeta, world: UnsafeWorldCell<'w>, change_tick: Tick, ) -> Self::Item<'w, 's>
SystemParamFunction
. Read moreimpl<'w, 's, Q: 'static + QueryData, F: 'static + QueryFilter> ReadOnlySystemParam for YoleckEdit<'w, 's, Q, F>where
Query<'w, 's, Q, (With<YoleckEditMarker>, F)>: ReadOnlySystemParam,
Query<'w, 's, (), With<YoleckEditMarker>>: ReadOnlySystemParam,
Auto Trait Implementations§
impl<'w, 's, Q, F> Freeze for YoleckEdit<'w, 's, Q, F>
impl<'w, 's, Q, F = ()> !RefUnwindSafe for YoleckEdit<'w, 's, Q, F>
impl<'w, 's, Q, F> Send for YoleckEdit<'w, 's, Q, F>
impl<'w, 's, Q, F> Sync for YoleckEdit<'w, 's, Q, F>
impl<'w, 's, Q, F> Unpin for YoleckEdit<'w, 's, Q, F>
impl<'w, 's, Q, F = ()> !UnwindSafe for YoleckEdit<'w, 's, Q, F>
Blanket Implementations§
§impl<T, U> AsBindGroupShaderType<U> for T
impl<T, U> AsBindGroupShaderType<U> for T
§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
§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<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§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