Hovered

Struct Hovered 

Source
pub struct Hovered(pub bool);
Expand description

A component that allows users to use regular Bevy change detection to determine when the pointer enters or leaves an entity. Users should insert this component on an entity to indicate interest in knowing about hover state changes.

The component’s boolean value will be true whenever the pointer is currently directly hovering over the entity, or any of the entity’s descendants (as defined by the ChildOf relationship). This is consistent with the behavior of the CSS :hover pseudo-class, which applies to the element and all of its descendants.

The contained boolean value is guaranteed to only be mutated when the pointer enters or leaves the entity, allowing Bevy change detection to be used efficiently. This is in contrast to the HoverMap resource, which is updated every frame.

Typically, a simple hoverable entity or widget will have this component added to it. More complex widgets can have this component added to each hoverable part.

The computational cost of keeping the Hovered components up to date is relatively cheap, and linear in the number of entities that have the Hovered component inserted.

Tuple Fields§

§0: bool

Implementations§

Source§

impl Hovered

Source

pub fn get(&self) -> bool

Get whether the entity is currently hovered.

Examples found in repository?
examples/ui/standard_widgets.rs (line 235)
210fn update_button_style(
211    mut buttons: Query<
212        (
213            Has<Pressed>,
214            &Hovered,
215            Has<InteractionDisabled>,
216            &mut BackgroundColor,
217            &mut BorderColor,
218            &Children,
219        ),
220        (
221            Or<(
222                Changed<Pressed>,
223                Changed<Hovered>,
224                Added<InteractionDisabled>,
225            )>,
226            With<DemoButton>,
227        ),
228    >,
229    mut text_query: Query<&mut Text>,
230) {
231    for (pressed, hovered, disabled, mut color, mut border_color, children) in &mut buttons {
232        let mut text = text_query.get_mut(children[0]).unwrap();
233        set_button_style(
234            disabled,
235            hovered.get(),
236            pressed,
237            &mut color,
238            &mut border_color,
239            &mut text,
240        );
241    }
242}
243
244/// Supplementary system to detect removed marker components
245fn update_button_style2(
246    mut buttons: Query<
247        (
248            Has<Pressed>,
249            &Hovered,
250            Has<InteractionDisabled>,
251            &mut BackgroundColor,
252            &mut BorderColor,
253            &Children,
254        ),
255        With<DemoButton>,
256    >,
257    mut removed_depressed: RemovedComponents<Pressed>,
258    mut removed_disabled: RemovedComponents<InteractionDisabled>,
259    mut text_query: Query<&mut Text>,
260) {
261    removed_depressed
262        .read()
263        .chain(removed_disabled.read())
264        .for_each(|entity| {
265            if let Ok((pressed, hovered, disabled, mut color, mut border_color, children)) =
266                buttons.get_mut(entity)
267            {
268                let mut text = text_query.get_mut(children[0]).unwrap();
269                set_button_style(
270                    disabled,
271                    hovered.get(),
272                    pressed,
273                    &mut color,
274                    &mut border_color,
275                    &mut text,
276                );
277            }
278        });
279}
More examples
Hide additional examples
examples/ui/standard_widgets_observers.rs (line 185)
161fn button_on_interaction<E: EntityEvent, C: Component>(
162    event: On<E, C>,
163    mut buttons: Query<
164        (
165            &Hovered,
166            Has<InteractionDisabled>,
167            Has<Pressed>,
168            &mut BackgroundColor,
169            &mut BorderColor,
170            &Children,
171        ),
172        With<DemoButton>,
173    >,
174    mut text_query: Query<&mut Text>,
175) {
176    if let Ok((hovered, disabled, pressed, mut color, mut border_color, children)) =
177        buttons.get_mut(event.event_target())
178    {
179        if children.is_empty() {
180            return;
181        }
182        let Ok(mut text) = text_query.get_mut(children[0]) else {
183            return;
184        };
185        let hovered = hovered.get();
186        // These "removal event checks" exist because the `Remove` event is triggered _before_ the component is actually
187        // removed, meaning it still shows up in the query. We're investigating the best way to improve this scenario.
188        let pressed = pressed && !(E::is::<Remove>() && C::is::<Pressed>());
189        let disabled = disabled && !(E::is::<Remove>() && C::is::<InteractionDisabled>());
190        match (disabled, hovered, pressed) {
191            // Disabled button
192            (true, _, _) => {
193                **text = "Disabled".to_string();
194                *color = NORMAL_BUTTON.into();
195                border_color.set_all(GRAY);
196            }
197
198            // Pressed and hovered button
199            (false, true, true) => {
200                **text = "Press".to_string();
201                *color = PRESSED_BUTTON.into();
202                border_color.set_all(RED);
203            }
204
205            // Hovered, unpressed button
206            (false, true, false) => {
207                **text = "Hover".to_string();
208                *color = HOVERED_BUTTON.into();
209                border_color.set_all(WHITE);
210            }
211
212            // Unhovered button (either pressed or not).
213            (false, false, _) => {
214                **text = "Button".to_string();
215                *color = NORMAL_BUTTON.into();
216                border_color.set_all(BLACK);
217            }
218        }
219    }
220}
221
222/// Create a demo slider
223fn slider(min: f32, max: f32, value: f32) -> impl Bundle {
224    (
225        Node {
226            display: Display::Flex,
227            flex_direction: FlexDirection::Column,
228            justify_content: JustifyContent::Center,
229            align_items: AlignItems::Stretch,
230            justify_items: JustifyItems::Center,
231            column_gap: px(4),
232            height: px(12),
233            width: percent(30),
234            ..default()
235        },
236        Name::new("Slider"),
237        Hovered::default(),
238        DemoSlider,
239        Slider::default(),
240        SliderValue(value),
241        SliderRange::new(min, max),
242        TabIndex(0),
243        Children::spawn((
244            // Slider background rail
245            Spawn((
246                Node {
247                    height: px(6),
248                    ..default()
249                },
250                BackgroundColor(SLIDER_TRACK), // Border color for the checkbox
251                BorderRadius::all(px(3)),
252            )),
253            // Invisible track to allow absolute placement of thumb entity. This is narrower than
254            // the actual slider, which allows us to position the thumb entity using simple
255            // percentages, without having to measure the actual width of the slider thumb.
256            Spawn((
257                Node {
258                    display: Display::Flex,
259                    position_type: PositionType::Absolute,
260                    left: px(0),
261                    // Track is short by 12px to accommodate the thumb.
262                    right: px(12),
263                    top: px(0),
264                    bottom: px(0),
265                    ..default()
266                },
267                children![(
268                    // Thumb
269                    DemoSliderThumb,
270                    SliderThumb,
271                    Node {
272                        display: Display::Flex,
273                        width: px(12),
274                        height: px(12),
275                        position_type: PositionType::Absolute,
276                        left: percent(0), // This will be updated by the slider's value
277                        ..default()
278                    },
279                    BorderRadius::MAX,
280                    BackgroundColor(SLIDER_THUMB),
281                )],
282            )),
283        )),
284    )
285}
286
287fn slider_on_interaction<E: EntityEvent, C: Component>(
288    event: On<E, C>,
289    sliders: Query<(Entity, &Hovered, Has<InteractionDisabled>), With<DemoSlider>>,
290    children: Query<&Children>,
291    mut thumbs: Query<(&mut BackgroundColor, Has<DemoSliderThumb>), Without<DemoSlider>>,
292) {
293    if let Ok((slider_ent, hovered, disabled)) = sliders.get(event.event_target()) {
294        // These "removal event checks" exist because the `Remove` event is triggered _before_ the component is actually
295        // removed, meaning it still shows up in the query. We're investigating the best way to improve this scenario.
296        let disabled = disabled && !(E::is::<Remove>() && C::is::<InteractionDisabled>());
297        for child in children.iter_descendants(slider_ent) {
298            if let Ok((mut thumb_bg, is_thumb)) = thumbs.get_mut(child)
299                && is_thumb
300            {
301                thumb_bg.0 = thumb_color(disabled, hovered.0);
302            }
303        }
304    }
305}
306
307fn slider_on_change_value<C: Component>(
308    insert: On<Insert, C>,
309    sliders: Query<(Entity, &SliderValue, &SliderRange), With<DemoSlider>>,
310    children: Query<&Children>,
311    mut thumbs: Query<(&mut Node, Has<DemoSliderThumb>), Without<DemoSlider>>,
312) {
313    if let Ok((slider_ent, value, range)) = sliders.get(insert.entity) {
314        for child in children.iter_descendants(slider_ent) {
315            if let Ok((mut thumb_node, is_thumb)) = thumbs.get_mut(child)
316                && is_thumb
317            {
318                thumb_node.left = percent(range.thumb_position(value.0) * 100.0);
319            }
320        }
321    }
322}
323
324fn thumb_color(disabled: bool, hovered: bool) -> Color {
325    match (disabled, hovered) {
326        (true, _) => GRAY.into(),
327
328        (false, true) => SLIDER_THUMB.lighter(0.3),
329
330        _ => SLIDER_THUMB,
331    }
332}
333
334/// Create a demo checkbox
335fn checkbox(asset_server: &AssetServer, caption: &str) -> impl Bundle {
336    (
337        Node {
338            display: Display::Flex,
339            flex_direction: FlexDirection::Row,
340            justify_content: JustifyContent::FlexStart,
341            align_items: AlignItems::Center,
342            align_content: AlignContent::Center,
343            column_gap: px(4),
344            ..default()
345        },
346        Name::new("Checkbox"),
347        Hovered::default(),
348        DemoCheckbox,
349        Checkbox,
350        TabIndex(0),
351        Children::spawn((
352            Spawn((
353                // Checkbox outer
354                Node {
355                    display: Display::Flex,
356                    width: px(16),
357                    height: px(16),
358                    border: UiRect::all(px(2)),
359                    ..default()
360                },
361                BorderColor::all(CHECKBOX_OUTLINE), // Border color for the checkbox
362                BorderRadius::all(px(3)),
363                children![
364                    // Checkbox inner
365                    (
366                        Node {
367                            display: Display::Flex,
368                            width: px(8),
369                            height: px(8),
370                            position_type: PositionType::Absolute,
371                            left: px(2),
372                            top: px(2),
373                            ..default()
374                        },
375                        BackgroundColor(Srgba::NONE.into()),
376                    ),
377                ],
378            )),
379            Spawn((
380                Text::new(caption),
381                TextFont {
382                    font: asset_server.load("fonts/FiraSans-Bold.ttf"),
383                    font_size: 20.0,
384                    ..default()
385                },
386            )),
387        )),
388    )
389}
390
391fn checkbox_on_interaction<E: EntityEvent, C: Component>(
392    event: On<E, C>,
393    checkboxes: Query<
394        (&Hovered, Has<InteractionDisabled>, Has<Checked>, &Children),
395        With<DemoCheckbox>,
396    >,
397    mut borders: Query<(&mut BorderColor, &mut Children), Without<DemoCheckbox>>,
398    mut marks: Query<&mut BackgroundColor, (Without<DemoCheckbox>, Without<Children>)>,
399) {
400    if let Ok((hovered, disabled, checked, children)) = checkboxes.get(event.event_target()) {
401        let hovered = hovered.get();
402        // These "removal event checks" exist because the `Remove` event is triggered _before_ the component is actually
403        // removed, meaning it still shows up in the query. We're investigating the best way to improve this scenario.
404        let checked = checked && !(E::is::<Remove>() && C::is::<Checked>());
405        let disabled = disabled && !(E::is::<Remove>() && C::is::<InteractionDisabled>());
406
407        let Some(border_id) = children.first() else {
408            return;
409        };
410
411        let Ok((mut border_color, border_children)) = borders.get_mut(*border_id) else {
412            return;
413        };
414
415        let Some(mark_id) = border_children.first() else {
416            warn!("Checkbox does not have a mark entity.");
417            return;
418        };
419
420        let Ok(mut mark_bg) = marks.get_mut(*mark_id) else {
421            warn!("Checkbox mark entity lacking a background color.");
422            return;
423        };
424
425        let color: Color = if disabled {
426            // If the checkbox is disabled, use a lighter color
427            CHECKBOX_OUTLINE.with_alpha(0.2)
428        } else if hovered {
429            // If hovering, use a lighter color
430            CHECKBOX_OUTLINE.lighter(0.2)
431        } else {
432            // Default color for the checkbox
433            CHECKBOX_OUTLINE
434        };
435
436        // Update the background color of the check mark
437        border_color.set_all(color);
438
439        let mark_color: Color = match (disabled, checked) {
440            (true, true) => CHECKBOX_CHECK.with_alpha(0.5),
441            (false, true) => CHECKBOX_CHECK,
442            (_, false) => Srgba::NONE.into(),
443        };
444
445        if mark_bg.0 != mark_color {
446            // Update the color of the check mark
447            mark_bg.0 = mark_color;
448        }
449    }
450}

Trait Implementations§

Source§

impl Clone for Hovered

Source§

fn clone(&self) -> Hovered

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Component for Hovered
where Hovered: Send + Sync + 'static,

Source§

const STORAGE_TYPE: StorageType = bevy_ecs::component::StorageType::Table

A constant indicating the storage type used for this component.
Source§

type Mutability = Immutable

A marker type to assist Bevy with determining if this component is mutable, or immutable. Mutable components will have Component<Mutability = Mutable>, while immutable components will instead have Component<Mutability = Immutable>. Read more
Source§

fn register_required_components( _requiree: ComponentId, required_components: &mut RequiredComponentsRegistrator<'_, '_>, )

Registers required components. Read more
Source§

fn clone_behavior() -> ComponentCloneBehavior

Called when registering this component, allowing to override clone function (or disable cloning altogether) for this component. Read more
Source§

fn on_add() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>

Gets the on_add ComponentHook for this Component if one is defined.
Source§

fn on_insert() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>

Gets the on_insert ComponentHook for this Component if one is defined.
Source§

fn on_replace() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>

Gets the on_replace ComponentHook for this Component if one is defined.
Source§

fn on_remove() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>

Gets the on_remove ComponentHook for this Component if one is defined.
Source§

fn on_despawn() -> Option<for<'w> fn(DeferredWorld<'w>, HookContext)>

Gets the on_despawn ComponentHook for this Component if one is defined.
Source§

fn map_entities<E>(_this: &mut Self, _mapper: &mut E)
where E: EntityMapper,

Maps the entities on this component using the given 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 more
Source§

impl Debug for Hovered

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for Hovered

Source§

fn default() -> Hovered

Returns the “default value” for a type. Read more
Source§

impl FromArg for Hovered

Source§

type This<'from_arg> = Hovered

The type to convert into. Read more
Source§

fn from_arg(arg: Arg<'_>) -> Result<<Hovered as FromArg>::This<'_>, ArgError>

Creates an item from an argument. Read more
Source§

impl FromReflect for Hovered

Source§

fn from_reflect(reflect: &(dyn PartialReflect + 'static)) -> Option<Hovered>

Constructs a concrete instance of Self from a reflected value.
Source§

fn take_from_reflect( reflect: Box<dyn PartialReflect>, ) -> Result<Self, Box<dyn PartialReflect>>

Attempts to downcast the given value to Self using, constructing the value using from_reflect if that fails. Read more
Source§

impl GetOwnership for Hovered

Source§

fn ownership() -> Ownership

Returns the ownership of Self.
Source§

impl GetTypeRegistration for Hovered

Source§

fn get_type_registration() -> TypeRegistration

Returns the default TypeRegistration for this type.
Source§

fn register_type_dependencies(registry: &mut TypeRegistry)

Registers other types needed by this type. Read more
Source§

impl IntoReturn for Hovered

Source§

fn into_return<'into_return>(self) -> Return<'into_return>
where Hovered: 'into_return,

Converts Self into a Return value.
Source§

impl PartialEq for Hovered

Source§

fn eq(&self, other: &Hovered) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl PartialReflect for Hovered

Source§

fn get_represented_type_info(&self) -> Option<&'static TypeInfo>

Returns the TypeInfo of the type represented by this value. Read more
Source§

fn try_apply( &mut self, value: &(dyn PartialReflect + 'static), ) -> Result<(), ApplyError>

Tries to apply a reflected value to this value. Read more
Source§

fn reflect_kind(&self) -> ReflectKind

Returns a zero-sized enumeration of “kinds” of type. Read more
Source§

fn reflect_ref(&self) -> ReflectRef<'_>

Returns an immutable enumeration of “kinds” of type. Read more
Source§

fn reflect_mut(&mut self) -> ReflectMut<'_>

Returns a mutable enumeration of “kinds” of type. Read more
Source§

fn reflect_owned(self: Box<Hovered>) -> ReflectOwned

Returns an owned enumeration of “kinds” of type. Read more
Source§

fn try_into_reflect( self: Box<Hovered>, ) -> Result<Box<dyn Reflect>, Box<dyn PartialReflect>>

Attempts to cast this type to a boxed, fully-reflected value.
Source§

fn try_as_reflect(&self) -> Option<&(dyn Reflect + 'static)>

Attempts to cast this type to a fully-reflected value.
Source§

fn try_as_reflect_mut(&mut self) -> Option<&mut (dyn Reflect + 'static)>

Attempts to cast this type to a mutable, fully-reflected value.
Source§

fn into_partial_reflect(self: Box<Hovered>) -> Box<dyn PartialReflect>

Casts this type to a boxed, reflected value. Read more
Source§

fn as_partial_reflect(&self) -> &(dyn PartialReflect + 'static)

Casts this type to a reflected value. Read more
Source§

fn as_partial_reflect_mut(&mut self) -> &mut (dyn PartialReflect + 'static)

Casts this type to a mutable, reflected value. Read more
Source§

fn reflect_partial_eq( &self, value: &(dyn PartialReflect + 'static), ) -> Option<bool>

Returns a “partial equality” comparison result. Read more
Source§

fn debug(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Debug formatter for the value. Read more
Source§

fn reflect_clone(&self) -> Result<Box<dyn Reflect>, ReflectCloneError>

Attempts to clone Self using reflection. Read more
Source§

fn apply(&mut self, value: &(dyn PartialReflect + 'static))

Applies a reflected value to this value. Read more
Source§

fn to_dynamic(&self) -> Box<dyn PartialReflect>

Converts this reflected value into its dynamic representation based on its kind. Read more
Source§

fn reflect_clone_and_take<T>(&self) -> Result<T, ReflectCloneError>
where T: 'static, Self: Sized + TypePath,

For a type implementing PartialReflect, combines reflect_clone and take in a useful fashion, automatically constructing an appropriate ReflectCloneError if the downcast fails. Read more
Source§

fn reflect_hash(&self) -> Option<u64>

Returns a hash of the value (which includes the type). Read more
Source§

fn is_dynamic(&self) -> bool

Indicates whether or not this type is a dynamic type. Read more
Source§

impl Reflect for Hovered

Source§

fn into_any(self: Box<Hovered>) -> Box<dyn Any>

Returns the value as a Box<dyn Any>. Read more
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Returns the value as a &dyn Any. Read more
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Returns the value as a &mut dyn Any. Read more
Source§

fn into_reflect(self: Box<Hovered>) -> Box<dyn Reflect>

Casts this type to a boxed, fully-reflected value.
Source§

fn as_reflect(&self) -> &(dyn Reflect + 'static)

Casts this type to a fully-reflected value.
Source§

fn as_reflect_mut(&mut self) -> &mut (dyn Reflect + 'static)

Casts this type to a mutable, fully-reflected value.
Source§

fn set(&mut self, value: Box<dyn Reflect>) -> Result<(), Box<dyn Reflect>>

Performs a type-checked assignment of a reflected value to this value. Read more
Source§

impl TupleStruct for Hovered

Source§

fn field(&self, index: usize) -> Option<&(dyn PartialReflect + 'static)>

Returns a reference to the value of the field with index index as a &dyn Reflect.
Source§

fn field_mut( &mut self, index: usize, ) -> Option<&mut (dyn PartialReflect + 'static)>

Returns a mutable reference to the value of the field with index index as a &mut dyn Reflect.
Source§

fn field_len(&self) -> usize

Returns the number of fields in the tuple struct.
Source§

fn iter_fields(&self) -> TupleStructFieldIter<'_>

Returns an iterator over the values of the tuple struct’s fields.
Source§

fn to_dynamic_tuple_struct(&self) -> DynamicTupleStruct

Creates a new DynamicTupleStruct from this tuple struct.
Source§

fn get_represented_tuple_struct_info(&self) -> Option<&'static TupleStructInfo>

Will return None if TypeInfo is not available.
Source§

impl TypePath for Hovered

Source§

fn type_path() -> &'static str

Returns the fully qualified path of the underlying type. Read more
Source§

fn short_type_path() -> &'static str

Returns a short, pretty-print enabled path to the type. Read more
Source§

fn type_ident() -> Option<&'static str>

Returns the name of the type, or None if it is anonymous. Read more
Source§

fn crate_name() -> Option<&'static str>

Returns the name of the crate the type is in, or None if it is anonymous. Read more
Source§

fn module_path() -> Option<&'static str>

Returns the path to the module the type is in, or None if it is anonymous. Read more
Source§

impl Typed for Hovered

Source§

fn type_info() -> &'static TypeInfo

Returns the compile-time info for the underlying type.
Source§

impl Copy for Hovered

Source§

impl Eq for Hovered

Source§

impl StructuralPartialEq for Hovered

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T, U> AsBindGroupShaderType<U> for T
where U: ShaderType, &'a T: for<'a> Into<U>,

Source§

fn as_bind_group_shader_type(&self, _images: &RenderAssets<GpuImage>) -> U

Return the T ShaderType for self. When used in AsBindGroup derives, it is safe to assume that all images in self exist.
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<C> Bundle for C
where C: Component,

Source§

fn component_ids( components: &mut ComponentsRegistrator<'_>, ids: &mut impl FnMut(ComponentId), )

Source§

fn get_component_ids( components: &Components, ids: &mut impl FnMut(Option<ComponentId>), )

Gets this Bundle’s component ids. This will be None if the component has not been registered.
Source§

impl<C> BundleFromComponents for C
where C: Component,

Source§

unsafe fn from_components<T, F>(ctx: &mut T, func: &mut F) -> C
where F: for<'a> FnMut(&'a mut T) -> OwningPtr<'a>,

Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> Conv for T

Source§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts 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>

Converts 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)

Converts &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)

Converts &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> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert 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>

Convert 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)

Convert &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)

Convert &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
where T: Any + Send,

Source§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> DynEq for T
where T: Any + Eq,

Source§

fn dyn_eq(&self, other: &(dyn DynEq + 'static)) -> bool

This method tests for self and other values to be equal. Read more
Source§

impl<C> DynamicBundle for C
where C: Component,

Source§

type Effect = ()

An operation on the entity that happens after inserting this bundle.
Source§

unsafe fn get_components( ptr: MovingPtr<'_, C>, func: &mut impl FnMut(StorageType, OwningPtr<'_>), ) -> <C as DynamicBundle>::Effect

Moves the components out of the bundle. Read more
Source§

unsafe fn apply_effect( _ptr: MovingPtr<'_, MaybeUninit<C>>, _entity: &mut EntityWorldMut<'_>, )

Applies the after-effects of spawning this bundle. Read more
Source§

impl<T> DynamicTypePath for T
where T: TypePath,

Source§

impl<T> DynamicTyped for T
where T: Typed,

Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> FmtForward for T

Source§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
Source§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
Source§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
Source§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
Source§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
Source§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
Source§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
Source§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
Source§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<S> FromSample<S> for S

Source§

fn from_sample_(s: S) -> S

Source§

impl<T> FromWorld for T
where T: Default,

Source§

fn from_world(_world: &mut World) -> T

Creates Self using default().

Source§

impl<T> GetPath for T
where T: Reflect + ?Sized,

Source§

fn reflect_path<'p>( &self, path: impl ReflectPath<'p>, ) -> Result<&(dyn PartialReflect + 'static), ReflectPathError<'p>>

Returns a reference to the value specified by path. Read more
Source§

fn reflect_path_mut<'p>( &mut self, path: impl ReflectPath<'p>, ) -> Result<&mut (dyn PartialReflect + 'static), ReflectPathError<'p>>

Returns a mutable reference to the value specified by path. Read more
Source§

fn path<'p, T>( &self, path: impl ReflectPath<'p>, ) -> Result<&T, ReflectPathError<'p>>
where T: Reflect,

Returns a statically typed reference to the value specified by path. Read more
Source§

fn path_mut<'p, T>( &mut self, path: impl ReflectPath<'p>, ) -> Result<&mut T, ReflectPathError<'p>>
where T: Reflect,

Returns a statically typed mutable reference to the value specified by path. Read more
Source§

impl<S> GetTupleStructField for S
where S: TupleStruct,

Source§

fn get_field<T>(&self, index: usize) -> Option<&T>
where T: Reflect,

Returns a reference to the value of the field with index index, downcast to T.
Source§

fn get_field_mut<T>(&mut self, index: usize) -> Option<&mut T>
where T: Reflect,

Returns a mutable reference to the value of the field with index index, downcast to T.
Source§

impl<T, W> HasTypeWitness<W> for T
where W: MakeTypeWitness<Arg = T>, T: ?Sized,

Source§

const WITNESS: W = W::MAKE

A constant of the type witness
Source§

impl<T> Identity for T
where T: ?Sized,

Source§

const TYPE_EQ: TypeEq<T, <T as Identity>::Type> = TypeEq::NEW

Proof that Self is the same type as Self::Type, provides methods for casting between Self and Self::Type.
Source§

type Type = T

The same type as Self, used to emulate type equality bounds (T == U) with associated type equality constraints (T: Identity<Type = U>).
Source§

impl<T> InitializeFromFunction<T> for T

Source§

fn initialize_from_function(f: fn() -> T) -> T

Create an instance of this type from an initialization function
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts 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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts 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
Source§

impl<T> IntoResult<T> for T

Source§

fn into_result(self) -> Result<T, RunSystemError>

Converts this type into the system output type.
Source§

impl<F, T> IntoSample<T> for F
where T: FromSample<F>,

Source§

fn into_sample(self) -> T

Source§

impl<A> Is for A
where A: Any,

Source§

fn is<T>() -> bool
where T: Any,

Checks if the current type “is” another type, using a TypeId equality comparison. This is most useful in the context of generic logic. Read more
Source§

impl<T> NoneValue for T
where T: Default,

Source§

type NoneType = T

Source§

fn null_value() -> T

The none-equivalent value.
Source§

impl<T> Pipe for T
where T: ?Sized,

Source§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
Source§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
Source§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
Source§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
Source§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
Source§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
Source§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
Source§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
Source§

impl<T> Pointable for T

Source§

const ALIGN: usize

The alignment of pointer.
Source§

type Init = T

The type for initializers.
Source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
Source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
Source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
Source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
Source§

impl<R, P> ReadPrimitive<R> for P
where R: Read + ReadEndian<P>, P: Default,

Source§

fn read_from_little_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_little_endian().
Source§

fn read_from_big_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_big_endian().
Source§

fn read_from_native_endian(read: &mut R) -> Result<Self, Error>

Read this value from the supplied reader. Same as ReadEndian::read_from_native_endian().
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<Ret> SpawnIfAsync<(), Ret> for Ret

Source§

fn spawn(self) -> Ret

Spawn the value into the dioxus runtime if it is an async block
Source§

impl<T, O> SuperFrom<T> for O
where O: From<T>,

Source§

fn super_from(input: T) -> O

Convert from a type to another type.
Source§

impl<T, O, M> SuperInto<O, M> for T
where O: SuperFrom<T, M>,

Source§

fn super_into(self) -> O

Convert from a type to another type.
Source§

impl<T> Tap for T

Source§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
Source§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
Source§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
Source§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
Source§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
Source§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
Source§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
Source§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
Source§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
Source§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
Source§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
Source§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
Source§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> ToSample<U> for T
where U: FromSample<T>,

Source§

fn to_sample_(self) -> U

Source§

impl<T> TryConv for T

Source§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> TypeData for T
where T: 'static + Send + Sync + Clone,

Source§

fn clone_type_data(&self) -> Box<dyn TypeData>

Creates a type-erased clone of this value.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> ConditionalSend for T
where T: Send,

Source§

impl<S, T> Duplex<S> for T
where T: FromSample<S> + ToSample<S>,

Source§

impl<T> Reflectable for T

Source§

impl<T> Settings for T
where T: 'static + Send + Sync,

Source§

impl<T> WasmNotSend for T
where T: Send,

Source§

impl<T> WasmNotSendSync for T

Source§

impl<T> WasmNotSync for T
where T: Sync,