Layout

Struct Layout 

Source
pub struct Layout {
    pub line_offset: u16,
    pub offset_x: u16,
    pub offset_y: u16,
    pub width: u16,
    pub height: u16,
    pub max_height: u16,
    pub render_region: RenderRegion,
}
Expand description

Layout represents a portion of the screen that is available to be rendered to.

Assume the highlighted part of the block below is the place available for rendering in the given box

 ____________
|            |
|     ███████|
|  ██████████|
|  ██████████|
'------------'

Fields§

§line_offset: u16
 ____________
|  vvv-- line_offset
|     ███████|
|  ██████████|
|  ██████████|
'------------'
§offset_x: u16
 ____________
|vv-- offset_x
|     ███████|
|  ██████████|
|  ██████████|
'------------'
§offset_y: u16
 .-- offset_y
|'>          |
|     ███████|
|  ██████████|
|  ██████████|
'------------'
§width: u16
 ____________
|            |
|     ███████|
|  ██████████|
|  ██████████|
'------------'
 ^^^^^^^^^^^^-- width
§height: u16
 _____ height --.
|            | <'
|     ███████| <'
|  ██████████| <'
|  ██████████| <'
'------------'
§max_height: u16
 ____________
|.-- max_height
|'>   ███████|
|'>██████████|
|'>██████████|
'------------'
§render_region: RenderRegion

The region to render if full text cannot be rendered

Implementations§

Source§

impl Layout

Source

pub fn new(line_offset: u16, size: Size) -> Self

Creates a new Layout.

Source

pub fn with_line_offset(self, line_offset: u16) -> Self

Creates a new Layout with given line_offset.

Source

pub fn with_size(self, size: Size) -> Self

Creates a new Layout with given width and height.

Source

pub fn with_offset(self, offset_x: u16, offset_y: u16) -> Self

Creates a new Layout with new offset_x and offset_y.

Source

pub fn with_render_region(self, region: RenderRegion) -> Self

Creates a new Layout with new render_region.

Source

pub fn with_max_height(self, max_height: u16) -> Self

Creates a new Layout with new max_height.

Source

pub fn with_cursor_pos(self, cursor_pos: (u16, u16)) -> Self

Creates a new Layout that represents a region past the cursor_pos. cursor_pos is relative to offset_x and offset_y.

Source

pub fn set_size(&mut self, terminal_size: Size)

Sets the width and height of the layout.

Source

pub fn offset_cursor(&self, cursor_pos: (u16, u16)) -> (u16, u16)

Converts a cursor_pos relative to (offset_x, offset_y) to be relative to (0, 0)

Source

pub fn line_width(&self) -> u16

Gets the width of renderable space on the first line.

 ____________
|     vvvvvvv-- line_width
|     ███████|
|  ██████████|
|  ██████████|
'------------'
Source

pub fn available_width(&self) -> u16

Gets the width of renderable space on subsequent lines.

 ____________
|  vvvvvvvvvv-- available_width
|     ███████|
|  ██████████|
|  ██████████|
'------------'
Source

pub fn get_start(&self, height: u16) -> u16

Gets the starting line number for the given height taking into account the max_height and the render_region.

If the height of the widget to render is 5 and the max_height is 2, then the start would be:

  • RenderRegion::Top: 0
  • RenderRegion::Middle: 1
  • RenderRegion::Top: 3

Trait Implementations§

Source§

impl Clone for Layout

Source§

fn clone(&self) -> Layout

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 Debug for Layout

Source§

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

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

impl Default for Layout

Source§

fn default() -> Layout

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

impl Hash for Layout

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for Layout

Source§

fn eq(&self, other: &Layout) -> 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 Copy for Layout

Source§

impl Eq for Layout

Source§

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> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
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<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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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