pub struct VisibleEntityRanges { /* private fields */ }
Expand description
Stores which entities are in within the VisibilityRange
s of views.
This doesn’t store the results of frustum or occlusion culling; use
super::ViewVisibility
for that. Thus entities in this list may not
actually be visible.
For efficiency, these tables only store entities that have
VisibilityRange
components. Entities without such a component won’t be
in these tables at all.
The table is indexed by entity and stores a 32-bit bitmask with one bit for each camera, where a 0 bit corresponds to “out of range” and a 1 bit corresponds to “in range”. Hence it’s limited to storing information for 32 views.
Implementations§
source§impl VisibleEntityRanges
impl VisibleEntityRanges
sourcepub fn entity_is_in_range_of_view(&self, entity: Entity, view: Entity) -> bool
pub fn entity_is_in_range_of_view(&self, entity: Entity, view: Entity) -> bool
Returns true if the entity is in range of the given camera.
This only checks VisibilityRange
s and doesn’t perform any frustum or
occlusion culling. Thus the entity might not actually be visible.
The entity is assumed to have a VisibilityRange
component. If the
entity doesn’t have that component, this method will return false.
sourcepub fn entity_is_in_range_of_any_view(&self, entity: Entity) -> bool
pub fn entity_is_in_range_of_any_view(&self, entity: Entity) -> bool
Returns true if the entity is in range of any view.
This only checks VisibilityRange
s and doesn’t perform any frustum or
occlusion culling. Thus the entity might not actually be visible.
The entity is assumed to have a VisibilityRange
component. If the
entity doesn’t have that component, this method will return false.
Trait Implementations§
source§impl Default for VisibleEntityRanges
impl Default for VisibleEntityRanges
source§fn default() -> VisibleEntityRanges
fn default() -> VisibleEntityRanges
impl Resource for VisibleEntityRanges
Auto Trait Implementations§
impl Freeze for VisibleEntityRanges
impl RefUnwindSafe for VisibleEntityRanges
impl Send for VisibleEntityRanges
impl Sync for VisibleEntityRanges
impl Unpin for VisibleEntityRanges
impl UnwindSafe for VisibleEntityRanges
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>
. 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<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
Creates Self
using default()
.
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