pub struct Layout {
pub order: u32,
pub location: Point<f32>,
pub size: Size<f32>,
pub content_size: Size<f32>,
pub scrollbar_size: Size<f32>,
pub border: Rect<f32>,
pub padding: Rect<f32>,
pub margin: Rect<f32>,
}Expand description
The final result of a layout algorithm for a single node.
Fields§
§order: u32The relative ordering of the node
Nodes with a higher order should be rendered on top of those with a lower order. This is effectively a topological sort of each tree.
location: Point<f32>The top-left corner of the node
size: Size<f32>The width and height of the node
content_size: Size<f32>The width and height of the content inside the node. This may be larger than the size of the node in the case of overflowing content and is useful for computing a “scroll width/height” for scrollable nodes
scrollbar_size: Size<f32>The size of the scrollbars in each dimension. If there is no scrollbar then the size will be zero.
border: Rect<f32>The size of the borders of the node
padding: Rect<f32>The size of the padding of the node
margin: Rect<f32>The size of the margin of the node
Implementations§
Source§impl Layout
impl Layout
Sourcepub const fn with_order(order: u32) -> Layout
pub const fn with_order(order: u32) -> Layout
Creates a new zero-Layout with the supplied order value.
Nodes with a higher order should be rendered on top of those with a lower order. The Zero-layout has size and location set to ZERO.
Sourcepub fn content_box_width(&self) -> f32
pub fn content_box_width(&self) -> f32
Get the width of the node’s content box
Sourcepub fn content_box_height(&self) -> f32
pub fn content_box_height(&self) -> f32
Get the height of the node’s content box
Sourcepub fn content_box_size(&self) -> Size<f32>
pub fn content_box_size(&self) -> Size<f32>
Get the size of the node’s content box
Sourcepub fn content_box_x(&self) -> f32
pub fn content_box_x(&self) -> f32
Get x offset of the node’s content box relative to it’s parent’s border box
Sourcepub fn content_box_y(&self) -> f32
pub fn content_box_y(&self) -> f32
Get x offset of the node’s content box relative to it’s parent’s border box
Source§impl Layout
impl Layout
Sourcepub fn scroll_width(&self) -> f32
pub fn scroll_width(&self) -> f32
Return the scroll width of the node. The scroll width is the difference between the width and the content width, floored at zero
Sourcepub fn scroll_height(&self) -> f32
pub fn scroll_height(&self) -> f32
Return the scroll height of the node. The scroll height is the difference between the height and the content height, floored at zero
Trait Implementations§
impl Copy for Layout
impl StructuralPartialEq for Layout
Auto Trait Implementations§
impl Freeze for Layout
impl RefUnwindSafe for Layout
impl Send for Layout
impl Sync for Layout
impl Unpin for Layout
impl UnwindSafe for Layout
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
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> 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<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
Source§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self from the equivalent element of its
superset. Read moreSource§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self is actually part of its subset T (and can be converted to it).Source§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset but without any property checks. Always succeeds.Source§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self to the equivalent element of its superset.