pub struct StyleCx<'a> {
pub window_state: &'a mut WindowState,
/* private fields */
}Fields§
§window_state: &'a mut WindowStateImplementations§
Source§impl<'a> StyleCx<'a>
impl<'a> StyleCx<'a>
pub fn new( window_state: &'a mut WindowState, view_id: ViewId, reason: StyleReason, ) -> Self
Sourcepub fn style_view(&mut self)
pub fn style_view(&mut self)
Compute styles for a view with graduated change propagation.
The change parameter describes what kind of recalculation is needed,
enabling optimizations like:
- Skipping views that don’t need recalc
- Using the inherited-only fast path when only inherited props changed
- Limiting recalc to immediate children vs entire subtrees
See [StyleRecalcChange] for details on the propagation model.
Sourcepub fn resolve_nested_maps(
&self,
base_style: Style,
classes: &[StyleClassRef],
element_id: impl Into<ElementId>,
) -> Style
pub fn resolve_nested_maps( &self, base_style: Style, classes: &[StyleClassRef], element_id: impl Into<ElementId>, ) -> Style
Resolve all nested maps in the base style for the given classes. This will use the current style cx as context and get the interaction state for the given element
Sourcepub fn resolve_nested_maps_with_state(
&self,
base_style: Style,
classes: &[StyleClassRef],
interact_state: InteractionState,
) -> Style
pub fn resolve_nested_maps_with_state( &self, base_style: Style, classes: &[StyleClassRef], interact_state: InteractionState, ) -> Style
The base style the base style for this view that will override any inherited properties
pub fn now(&self) -> Instant
pub fn current_view(&self) -> ViewId
pub fn get_prop<P: StyleProp>(&self, _prop: P) -> Option<P::Type>
pub fn style(&self) -> Style
pub fn direct_style(&self) -> &Style
pub fn indirect_style(&self) -> &Style
pub fn request_transition(&mut self)
Sourcepub fn request_transition_for(&mut self, target: impl Into<ElementId>)
pub fn request_transition_for(&mut self, target: impl Into<ElementId>)
Request a transition-driven style update for a specific style target.
This allows transition requests to target sub-elements instead of always assuming the owning view element.
pub fn get_interact_state( window_state: &WindowState, id: impl Into<ElementId>, ) -> InteractionState
Auto Trait Implementations§
impl<'a> Freeze for StyleCx<'a>
impl<'a> !RefUnwindSafe for StyleCx<'a>
impl<'a> !Send for StyleCx<'a>
impl<'a> !Sync for StyleCx<'a>
impl<'a> Unpin for StyleCx<'a>
impl<'a> UnsafeUnpin for StyleCx<'a>
impl<'a> !UnwindSafe for StyleCx<'a>
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
§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>
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.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
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.§fn as_any(&self) -> &(dyn Any + 'static)
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.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
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.§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>
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 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>
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