[go: up one dir, main page]

Struct Rect

Source
pub struct Rect {
    pub x: u16,
    pub y: u16,
    pub width: u16,
    pub height: u16,
}
Expand description

A rectangular area in the terminal.

A Rect represents a rectangular region in the terminal coordinate system, defined by its top-left corner position and dimensions. This is the fundamental building block for all layout operations and widget rendering in Ratatui.

Rectangles are used throughout the layout system to define areas where widgets can be rendered. They are typically created by Layout operations that divide terminal space, but can also be manually constructed for specific positioning needs.

The coordinate system uses the top-left corner as the origin (0, 0), with x increasing to the right and y increasing downward. All measurements are in character cells.

§Construction and Conversion

  • new - Create a new rectangle from coordinates and dimensions
  • as_position - Convert to a position at the top-left corner
  • as_size - Convert to a size representing the dimensions
  • from((Position, Size)) - Create from (Position, Size) tuple
  • from(((u16, u16), (u16, u16))) - Create from ((u16, u16), (u16, u16)) coordinate and dimension tuples
  • [into((Position, Size))] - Convert to (Position, Size) tuple
  • default - Create a zero-sized rectangle at origin

§Geometry and Properties

§Spatial Operations

  • inner, outer - Apply margins to shrink or expand
  • offset - Move the rectangle by a relative amount
  • union - Combine with another rectangle to create a bounding box
  • intersection - Find the overlapping area with another rectangle
  • clamp - Constrain the rectangle to fit within another

§Positioning and Centering

§Testing and Iteration

  • contains - Check if a position is within the rectangle
  • intersects - Check if it overlaps with another rectangle
  • rows - Iterate over horizontal rows within the rectangle
  • columns - Iterate over vertical columns within the rectangle
  • positions - Iterate over all positions within the rectangle

§Examples

use ratatui_core::layout::{Position, Rect, Size};

// Create a rectangle manually
let rect = Rect::new(10, 5, 80, 20);
assert_eq!(rect.x, 10);
assert_eq!(rect.y, 5);
assert_eq!(rect.width, 80);
assert_eq!(rect.height, 20);

// Create from position and size
let rect = Rect::from((Position::new(10, 5), Size::new(80, 20)));

For comprehensive layout documentation and examples, see the layout module.

Fields§

§x: u16

The x coordinate of the top left corner of the Rect.

§y: u16

The y coordinate of the top left corner of the Rect.

§width: u16

The width of the Rect.

§height: u16

The height of the Rect.

Implementations§

Source§

impl Rect

Source

pub const ZERO: Rect

A zero sized Rect at position 0,0

Source

pub const fn new(x: u16, y: u16, width: u16, height: u16) -> Rect

Creates a new Rect, with width and height limited to keep both bounds within u16.

If the width or height would cause the right or bottom coordinate to be larger than the maximum value of u16, the width or height will be clamped to keep the right or bottom coordinate within u16.

§Examples
use ratatui_core::layout::Rect;

let rect = Rect::new(1, 2, 3, 4);
Source

pub const fn area(self) -> u32

The area of the Rect. If the area is larger than the maximum value of u16, it will be clamped to u16::MAX.

Source

pub const fn is_empty(self) -> bool

Returns true if the Rect has no area.

Source

pub const fn left(self) -> u16

Returns the left coordinate of the Rect.

Source

pub const fn right(self) -> u16

Returns the right coordinate of the Rect. This is the first coordinate outside of the Rect.

If the right coordinate is larger than the maximum value of u16, it will be clamped to u16::MAX.

Source

pub const fn top(self) -> u16

Returns the top coordinate of the Rect.

Source

pub const fn bottom(self) -> u16

Returns the bottom coordinate of the Rect. This is the first coordinate outside of the Rect.

If the bottom coordinate is larger than the maximum value of u16, it will be clamped to u16::MAX.

Source

pub const fn inner(self, margin: Margin) -> Rect

Returns a new Rect inside the current one, with the given margin on each side.

If the margin is larger than the Rect, the returned Rect will have no area.

Source

pub const fn outer(self, margin: Margin) -> Rect

Returns a new Rect outside the current one, with the given margin applied on each side.

If the margin causes the Rect’s bounds to outsdie the range of a u16, the Rect will be truncated to keep the bounds within u16. This will cause the size of the Rect to change.

The generated Rect may not fit inside the buffer or containing area, so it consider constraining the resulting Rect with Rect::clamp before using it.

Source

pub fn offset(self, offset: Offset) -> Rect

Moves the Rect without modifying its size.

Moves the Rect according to the given offset without modifying its width or height.

  • Positive x moves the whole Rect to the right, negative to the left.
  • Positive y moves the whole Rect to the bottom, negative to the top.

See Offset for details.

Source

pub fn union(self, other: Rect) -> Rect

Returns a new Rect that contains both the current one and the given one.

Source

pub fn intersection(self, other: Rect) -> Rect

Returns a new Rect that is the intersection of the current one and the given one.

If the two Rects do not intersect, the returned Rect will have no area.

Source

pub const fn intersects(self, other: Rect) -> bool

Returns true if the two Rects intersect.

Source

pub const fn contains(self, position: Position) -> bool

Returns true if the given position is inside the Rect.

The position is considered inside the Rect if it is on the Rect’s border.

§Examples
use ratatui_core::layout::{Position, Rect};

let rect = Rect::new(1, 2, 3, 4);
assert!(rect.contains(Position { x: 1, y: 2 }));
Source

pub fn clamp(self, other: Rect) -> Rect

Clamp this Rect to fit inside the other Rect.

If the width or height of this Rect is larger than the other Rect, it will be clamped to the other Rect’s width or height.

If the left or top coordinate of this Rect is smaller than the other Rect, it will be clamped to the other Rect’s left or top coordinate.

If the right or bottom coordinate of this Rect is larger than the other Rect, it will be clamped to the other Rect’s right or bottom coordinate.

This is different from Rect::intersection because it will move this Rect to fit inside the other Rect, while Rect::intersection instead would keep this Rect’s position and truncate its size to only that which is inside the other Rect.

§Examples
use ratatui_core::layout::Rect;

let area = Rect::new(0, 0, 100, 100);
let rect = Rect::new(80, 80, 30, 30).clamp(area);
assert_eq!(rect, Rect::new(70, 70, 30, 30));
Source

pub const fn rows(self) -> Rows

An iterator over rows within the Rect.

Each row is a full Rect region with height 1 that can be used for rendering widgets or as input to further layout methods.

§Example
use ratatui_core::buffer::Buffer;
use ratatui_core::layout::{Constraint, Layout, Rect};
use ratatui_core::widgets::Widget;

fn render_list(area: Rect, buf: &mut Buffer) {
    // Renders "Item 0", "Item 1", etc. in each row
    for (i, row) in area.rows().enumerate() {
        format!("Item {i}").render(row, buf);
    }
}

fn render_with_nested_layout(area: Rect, buf: &mut Buffer) {
    // Splits each row into left/right areas and renders labels and content
    for (i, row) in area.rows().take(3).enumerate() {
        let [left, right] =
            Layout::horizontal([Constraint::Percentage(30), Constraint::Fill(1)]).areas(row);

        format!("{i}:").render(left, buf);
        "Content".render(right, buf);
    }
}
Source

pub const fn columns(self) -> Columns

An iterator over columns within the Rect.

Each column is a full Rect region with width 1 that can be used for rendering widgets or as input to further layout methods.

§Example
use ratatui_core::buffer::Buffer;
use ratatui_core::layout::Rect;
use ratatui_core::widgets::Widget;

fn render_columns(area: Rect, buf: &mut Buffer) {
    // Renders column indices (0-9 repeating) in each column
    for (i, column) in area.columns().enumerate() {
        format!("{}", i % 10).render(column, buf);
    }
}
Source

pub const fn positions(self) -> Positions

An iterator over the positions within the Rect.

The positions are returned in a row-major order (left-to-right, top-to-bottom). Each position is a Position that represents a single cell coordinate.

§Example
use ratatui_core::buffer::Buffer;
use ratatui_core::layout::{Position, Rect};
use ratatui_core::widgets::Widget;

fn render_positions(area: Rect, buf: &mut Buffer) {
    // Renders position indices (0-9 repeating) at each cell position
    for (i, position) in area.positions().enumerate() {
        buf[position].set_symbol(&format!("{}", i % 10));
    }
}
Source

pub const fn as_position(self) -> Position

Returns a Position with the same coordinates as this Rect.

§Examples
use ratatui_core::layout::Rect;

let rect = Rect::new(1, 2, 3, 4);
let position = rect.as_position();
Source

pub const fn as_size(self) -> Size

Converts the Rect into a size struct.

Source

pub fn centered_horizontally(self, constraint: Constraint) -> Rect

Returns a new Rect, centered horizontally based on the provided constraint.

§Examples
use ratatui_core::layout::Constraint;
use ratatui_core::terminal::Frame;

fn render(frame: &mut Frame) {
    let area = frame.area().centered_horizontally(Constraint::Ratio(1, 2));
}
Source

pub fn centered_vertically(self, constraint: Constraint) -> Rect

Returns a new Rect, centered vertically based on the provided constraint.

§Examples
use ratatui_core::layout::Constraint;
use ratatui_core::terminal::Frame;

fn render(frame: &mut Frame) {
    let area = frame.area().centered_vertically(Constraint::Ratio(1, 2));
}
Source

pub fn centered( self, horizontal_constraint: Constraint, vertical_constraint: Constraint, ) -> Rect

Returns a new Rect, centered horizontally and vertically based on the provided constraints.

§Examples
use ratatui_core::layout::Constraint;
use ratatui_core::terminal::Frame;

fn render(frame: &mut Frame) {
    let area = frame
        .area()
        .centered(Constraint::Ratio(1, 2), Constraint::Ratio(1, 3));
}
Source

pub fn layout<const N: usize>(self, layout: &Layout) -> [Rect; N]

Split the rect into a number of sub-rects according to the given Layout.

An ergonomic wrapper around Layout::split that returns an array of Rects instead of Rc<[Rect]>.

This method requires the number of constraints to be known at compile time. If you don’t know the number of constraints at compile time, use Layout::split instead.

§Panics

Panics if the number of constraints is not equal to the length of the returned array.

§Examples
use ratatui_core::layout::{Constraint, Layout, Rect};

let area = Rect::new(0, 0, 10, 10);
let layout = Layout::vertical([Constraint::Length(1), Constraint::Min(0)]);
let [top, main] = area.layout(&layout);
assert_eq!(top, Rect::new(0, 0, 10, 1));
assert_eq!(main, Rect::new(0, 1, 10, 9));

// or explicitly specify the number of constraints:
let areas = area.layout::<2>(&layout);
assert_eq!(areas, [Rect::new(0, 0, 10, 1), Rect::new(0, 1, 10, 9),]);
Source

pub fn layout_vec(self, layout: &Layout) -> Vec<Rect>

Split the rect into a number of sub-rects according to the given Layout.

An ergonomic wrapper around Layout::split that returns a Vec of Rects instead of Rc<[Rect]>.

§Examples
use ratatui_core::layout::{Constraint, Layout, Rect};

let area = Rect::new(0, 0, 10, 10);
let layout = Layout::vertical([Constraint::Length(1), Constraint::Min(0)]);
let areas = area.layout_vec(&layout);
assert_eq!(areas, vec![Rect::new(0, 0, 10, 1), Rect::new(0, 1, 10, 9),]);
Source

pub fn try_layout<const N: usize>( self, layout: &Layout, ) -> Result<[Rect; N], TryFromSliceError>

Try to split the rect into a number of sub-rects according to the given Layout.

An ergonomic wrapper around Layout::split that returns an array of Rects instead of Rc<[Rect]>.

§Errors

Returns an error if the number of constraints is not equal to the length of the returned array.

§Examples
use ratatui_core::layout::{Constraint, Layout, Rect};

let area = Rect::new(0, 0, 10, 10);
let layout = Layout::vertical([Constraint::Length(1), Constraint::Min(0)]);
let [top, main] = area.try_layout(&layout)?;
assert_eq!(top, Rect::new(0, 0, 10, 1));
assert_eq!(main, Rect::new(0, 1, 10, 9));

// or explicitly specify the number of constraints:
let areas = area.try_layout::<2>(&layout)?;
assert_eq!(areas, [Rect::new(0, 0, 10, 1), Rect::new(0, 1, 10, 9),]);

Trait Implementations§

Source§

impl Clone for Rect

Source§

fn clone(&self) -> Rect

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

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

Performs copy-assignment from source. Read more
Source§

impl Debug for Rect

Source§

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

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

impl Default for Rect

Source§

fn default() -> Rect

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

impl<'de> Deserialize<'de> for Rect

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<Rect, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Display for Rect

Source§

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

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

impl From<(Position, Size)> for Rect

Source§

fn from(_: (Position, Size)) -> Rect

Converts to this type from the input type.
Source§

impl From<Rect> for Position

Source§

fn from(rect: Rect) -> Position

Converts to this type from the input type.
Source§

impl From<Rect> for Size

Source§

fn from(rect: Rect) -> Size

Converts to this type from the input type.
Source§

impl Hash for Rect

Source§

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

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 Rect

Source§

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

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

const 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 Serialize for Rect

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Copy for Rect

Source§

impl Eq for Rect

Source§

impl StructuralPartialEq for Rect

Auto Trait Implementations§

§

impl Freeze for Rect

§

impl RefUnwindSafe for Rect

§

impl Send for Rect

§

impl Sync for Rect

§

impl Unpin for Rect

§

impl UnwindSafe for Rect

Blanket Implementations§

Source§

impl<S, D, Swp, Dwp, T> AdaptInto<D, Swp, Dwp, T> for S
where T: Real + Zero + Arithmetics + Clone, Swp: WhitePoint<T>, Dwp: WhitePoint<T>, D: AdaptFrom<S, Swp, Dwp, T>,

Source§

fn adapt_into_using<M>(self, method: M) -> D
where M: TransformMatrix<T>,

Convert the source color to the destination color using the specified method.
Source§

fn adapt_into(self) -> D

Convert the source color to the destination color using the bradford method by default.
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, C> ArraysFrom<C> for T
where C: IntoArrays<T>,

Source§

fn arrays_from(colors: C) -> T

Cast a collection of colors into a collection of arrays.
Source§

impl<T, C> ArraysInto<C> for T
where C: FromArrays<T>,

Source§

fn arrays_into(self) -> C

Cast this collection of arrays into a collection of colors.
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<WpParam, T, U> Cam16IntoUnclamped<WpParam, T> for U
where T: FromCam16Unclamped<WpParam, U>,

Source§

type Scalar = <T as FromCam16Unclamped<WpParam, U>>::Scalar

The number type that’s used in parameters when converting.
Source§

fn cam16_into_unclamped( self, parameters: BakedParameters<WpParam, <U as Cam16IntoUnclamped<WpParam, T>>::Scalar>, ) -> T

Converts self into C, using the provided parameters.
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, C> ComponentsFrom<C> for T
where C: IntoComponents<T>,

Source§

fn components_from(colors: C) -> T

Cast a collection of colors into a collection of color components.
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<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromAngle<T> for T

Source§

fn from_angle(angle: T) -> T

Performs a conversion from angle.
Source§

impl<T, U> FromStimulus<U> for T
where U: IntoStimulus<T>,

Source§

fn from_stimulus(other: U) -> T

Converts other into Self, while performing the appropriate scaling, rounding and clamping.
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, U> IntoAngle<U> for T
where U: FromAngle<T>,

Source§

fn into_angle(self) -> U

Performs a conversion into T.
Source§

impl<WpParam, T, U> IntoCam16Unclamped<WpParam, T> for U
where T: Cam16FromUnclamped<WpParam, U>,

Source§

type Scalar = <T as Cam16FromUnclamped<WpParam, U>>::Scalar

The number type that’s used in parameters when converting.
Source§

fn into_cam16_unclamped( self, parameters: BakedParameters<WpParam, <U as IntoCam16Unclamped<WpParam, T>>::Scalar>, ) -> T

Converts self into C, using the provided parameters.
Source§

impl<T, U> IntoColor<U> for T
where U: FromColor<T>,

Source§

fn into_color(self) -> U

Convert into T with values clamped to the color defined bounds Read more
Source§

impl<T, U> IntoColorUnclamped<U> for T
where U: FromColorUnclamped<T>,

Source§

fn into_color_unclamped(self) -> U

Convert into T. The resulting color might be invalid in its color space Read more
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> IntoStimulus<T> for T

Source§

fn into_stimulus(self) -> T

Converts self into T, while performing the appropriate scaling, rounding and clamping.
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToCompactString for T
where T: Display,

Source§

impl<T> ToLine for T
where T: Display,

Source§

fn to_line(&self) -> Line<'_>

Converts the value to a Line.
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> ToSpan for T
where T: Display,

Source§

fn to_span(&self) -> Span<'_>

Converts the value to a Span.
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T> ToText for T
where T: Display,

Source§

fn to_text(&self) -> Text<'_>

Converts the value to a Text.
Source§

impl<T, C> TryComponentsInto<C> for T
where C: TryFromComponents<T>,

Source§

type Error = <C as TryFromComponents<T>>::Error

The error for when try_into_colors fails to cast.
Source§

fn try_components_into(self) -> Result<C, <T as TryComponentsInto<C>>::Error>

Try to cast this collection of color components into a collection of colors. 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, U> TryIntoColor<U> for T
where U: TryFromColor<T>,

Source§

fn try_into_color(self) -> Result<U, OutOfBounds<U>>

Convert into T, returning ok if the color is inside of its defined range, otherwise an OutOfBounds error is returned which contains the unclamped color. Read more
Source§

impl<C, U> UintsFrom<C> for U
where C: IntoUints<U>,

Source§

fn uints_from(colors: C) -> U

Cast a collection of colors into a collection of unsigned integers.
Source§

impl<C, U> UintsInto<C> for U
where C: FromUints<U>,

Source§

fn uints_into(self) -> C

Cast this collection of unsigned integers into a collection of colors.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,